cad97c08a1
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> *fix-up merge conflicts due to qga-ssh-test being disabled in earlier patch due to G_TEST_OPTION_ISOLATE_DIRS triggering build-oss-fuzz leak detector. *fix up style and disallowed g_assert* usage reported by checkpatch Signed-off-by: Michael Roth <michael.roth@amd.com>
115 lines
3.7 KiB
Meson
115 lines
3.7 KiB
Meson
qga_qapi_outputs = [
|
|
'qga-qapi-commands.c',
|
|
'qga-qapi-commands.h',
|
|
'qga-qapi-emit-events.c',
|
|
'qga-qapi-emit-events.h',
|
|
'qga-qapi-events.c',
|
|
'qga-qapi-events.h',
|
|
'qga-qapi-init-commands.c',
|
|
'qga-qapi-init-commands.h',
|
|
'qga-qapi-introspect.c',
|
|
'qga-qapi-introspect.h',
|
|
'qga-qapi-types.c',
|
|
'qga-qapi-types.h',
|
|
'qga-qapi-visit.c',
|
|
'qga-qapi-visit.h',
|
|
]
|
|
|
|
qga_qapi_files = custom_target('QGA QAPI files',
|
|
output: qga_qapi_outputs,
|
|
input: 'qapi-schema.json',
|
|
command: [ qapi_gen, '-o', 'qga', '-p', 'qga-', '@INPUT0@' ],
|
|
depend_files: qapi_gen_depends)
|
|
|
|
qga_ss = ss.source_set()
|
|
qga_ss.add(qga_qapi_files.to_list())
|
|
qga_ss.add(files(
|
|
'commands.c',
|
|
'guest-agent-command-state.c',
|
|
'main.c',
|
|
))
|
|
qga_ss.add(when: 'CONFIG_POSIX', if_true: files(
|
|
'channel-posix.c',
|
|
'commands-posix.c',
|
|
'commands-posix-ssh.c',
|
|
))
|
|
qga_ss.add(when: 'CONFIG_WIN32', if_true: files(
|
|
'channel-win32.c',
|
|
'commands-win32.c',
|
|
'service-win32.c',
|
|
'vss-win32.c'
|
|
))
|
|
|
|
qga_ss = qga_ss.apply(config_host, strict: false)
|
|
|
|
qga = executable('qemu-ga', qga_ss.sources(),
|
|
link_args: config_host['LIBS_QGA'].split(),
|
|
dependencies: [qemuutil, libudev],
|
|
install: true)
|
|
all_qga = [qga]
|
|
|
|
if targetos == 'windows'
|
|
if 'CONFIG_QGA_VSS' in config_host
|
|
subdir('vss-win32')
|
|
else
|
|
gen_tlb = []
|
|
endif
|
|
|
|
wixl = find_program('wixl', required: false)
|
|
if wixl.found()
|
|
deps = [gen_tlb, qga]
|
|
if 'CONFIG_QGA_VSS' in config_host and 'QEMU_GA_MSI_WITH_VSS' in config_host
|
|
deps += qga_vss
|
|
endif
|
|
qga_msi = custom_target('QGA MSI',
|
|
input: files('installer/qemu-ga.wxs'),
|
|
output: 'qemu-ga-@0@.msi'.format(config_host['ARCH']),
|
|
depends: deps,
|
|
command: [
|
|
find_program('env'),
|
|
'QEMU_GA_VERSION=' + config_host['QEMU_GA_VERSION'],
|
|
'QEMU_GA_MANUFACTURER=' + config_host['QEMU_GA_MANUFACTURER'],
|
|
'QEMU_GA_DISTRO=' + config_host['QEMU_GA_DISTRO'],
|
|
'BUILD_DIR=' + meson.build_root(),
|
|
wixl, '-o', '@OUTPUT0@', '@INPUT0@',
|
|
config_host['QEMU_GA_MSI_ARCH'].split(),
|
|
config_host['QEMU_GA_MSI_WITH_VSS'].split(),
|
|
config_host['QEMU_GA_MSI_MINGW_DLL_PATH'].split(),
|
|
])
|
|
all_qga += [qga_msi]
|
|
alias_target('msi', qga_msi)
|
|
endif
|
|
else
|
|
install_subdir('run', install_dir: get_option('localstatedir'))
|
|
endif
|
|
|
|
alias_target('qemu-ga', all_qga)
|
|
|
|
test_env = environment()
|
|
test_env.set('G_TEST_SRCDIR', meson.current_source_dir())
|
|
test_env.set('G_TEST_BUILDDIR', meson.current_build_dir())
|
|
|
|
# disable qga-ssh-test for now. glib's G_TEST_OPTION_ISOLATE_DIRS triggers
|
|
# the leak detector in build-oss-fuzz Gitlab CI test. we should re-enable
|
|
# this when an alternative is implemented or when the underlying glib
|
|
# issue is identified/fix
|
|
#if 'CONFIG_POSIX' in config_host
|
|
if false
|
|
srcs = [files('commands-posix-ssh.c')]
|
|
i = 0
|
|
foreach output: qga_qapi_outputs
|
|
if output.startswith('qga-qapi-types') or output.startswith('qga-qapi-visit')
|
|
srcs += qga_qapi_files[i]
|
|
endif
|
|
i = i + 1
|
|
endforeach
|
|
qga_ssh_test = executable('qga-ssh-test', srcs,
|
|
dependencies: [qemuutil],
|
|
c_args: ['-DQGA_BUILD_UNIT_TEST'])
|
|
|
|
test('qga-ssh-test',
|
|
qga_ssh_test,
|
|
env: test_env,
|
|
suite: ['unit', 'qga'])
|
|
endif
|