summaryrefslogtreecommitdiff
path: root/test/CMakeLists.txt
diff options
context:
space:
mode:
authorRalf Habacker <ralf.habacker@freenet.de>2019-01-10 19:42:52 +0100
committerRalf Habacker <ralf.habacker@freenet.de>2019-01-22 09:57:40 +0100
commit3bf97922bd8df563169f9a448ecc8b2dd6658efc (patch)
tree882fd8701984e8212a538f75e5be910dd4bf6638 /test/CMakeLists.txt
parent8747c9b5a06209b22d6b5c89c6ef44d88a74197f (diff)
downloaddbus-3bf97922bd8df563169f9a448ecc8b2dd6658efc.tar.gz
Move cmake related build system to top level
Signed-off-by: Ralf Habacker <ralf.habacker@freenet.de>
Diffstat (limited to 'test/CMakeLists.txt')
-rw-r--r--test/CMakeLists.txt253
1 files changed, 253 insertions, 0 deletions
diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt
new file mode 100644
index 00000000..6acb35de
--- /dev/null
+++ b/test/CMakeLists.txt
@@ -0,0 +1,253 @@
+
+add_definitions(${DBUS_INTERNAL_CLIENT_DEFINITIONS})
+
+include_directories(.)
+
+set(DBUS_SESSION_BUS_LISTEN_ADDRESS ${TEST_LISTEN})
+
+add_library(dbus-testutils STATIC
+ disable-crash-handling.c
+ disable-crash-handling.h
+ test-utils.h
+ test-utils.c
+)
+target_link_libraries(dbus-testutils ${DBUS_INTERNAL_LIBRARIES})
+
+add_subdirectory( name-test )
+
+set (manual-dir-iter_SOURCES
+ manual-dir-iter.c
+)
+
+set (test-service_SOURCES
+ test-service.c
+)
+
+set (test-names_SOURCES
+ test-names.c
+)
+
+set (break_loader_SOURCES
+ break-loader.c
+)
+
+set (test-shell-service_SOURCES
+ test-shell-service.c
+)
+
+set (test-shell_SOURCES
+ shell-test.c
+)
+
+set (test-spawn_SOURCES
+ spawn-test.c
+)
+
+set (test-exit_SOURCES
+ test-exit.c
+)
+
+# We have to compile a separate copy of disable-crash-handling.c for
+# test-segfault rather than using the libdbus-testutils library, because
+# otherwise it would fail to link when using the AddressSanitizer.
+set (test-segfault_SOURCES
+ disable-crash-handling.c
+ disable-crash-handling.h
+ test-segfault.c
+)
+
+set (test-sleep-forever_SOURCES
+ test-sleep-forever.c
+)
+
+set (manual-tcp_SOURCES
+ manual-tcp.c
+)
+
+set (manual-paths_SOURCES
+ manual-paths.c
+)
+
+add_helper_executable(manual-dir-iter ${manual-dir-iter_SOURCES} ${DBUS_INTERNAL_LIBRARIES})
+add_helper_executable(test-service ${test-service_SOURCES} dbus-testutils)
+add_helper_executable(test-names ${test-names_SOURCES} dbus-testutils)
+add_test_executable(test-shell ${test-shell_SOURCES} ${DBUS_INTERNAL_LIBRARIES})
+add_test_executable(test-printf internals/printf.c dbus-testutils)
+add_helper_executable(test-privserver test-privserver.c dbus-testutils)
+add_helper_executable(test-shell-service ${test-shell-service_SOURCES} dbus-testutils)
+add_helper_executable(test-spawn ${test-spawn_SOURCES} ${DBUS_INTERNAL_LIBRARIES})
+if(NOT WINCE)
+ add_test_executable(test-spawn-oom internals/spawn-oom.c dbus-testutils)
+endif()
+add_helper_executable(test-exit ${test-exit_SOURCES} ${DBUS_INTERNAL_LIBRARIES})
+# the second argument of add_helper_executable() is a whitespace-separated
+# list of source files and the third and subsequent arguments are libraries
+# to link, hence the quoting here
+add_helper_executable(test-segfault "${test-segfault_SOURCES}")
+add_helper_executable(test-sleep-forever ${test-sleep-forever_SOURCES} ${DBUS_INTERNAL_LIBRARIES})
+add_helper_executable(manual-tcp ${manual-tcp_SOURCES} ${DBUS_INTERNAL_LIBRARIES})
+add_helper_executable(manual-backtrace manual-backtrace.c dbus-1)
+if(WIN32)
+ add_helper_executable(manual-paths ${manual-paths_SOURCES} ${DBUS_INTERNAL_LIBRARIES})
+endif()
+
+if(DBUS_ENABLE_EMBEDDED_TESTS)
+ add_test_executable(test-hash internals/hash.c dbus-testutils)
+ set_target_properties(test-hash PROPERTIES COMPILE_FLAGS ${DBUS_INTERNAL_CLIENT_DEFINITIONS})
+
+ set(SOURCES internals/dbus-marshal-recursive-util.c
+ internals/dbus-marshal-recursive-util.h
+ internals/marshal-recursive.c)
+ add_test_executable(test-marshal-recursive "${SOURCES}" dbus-testutils)
+ set_target_properties(test-marshal-recursive PROPERTIES COMPILE_FLAGS ${DBUS_INTERNAL_CLIENT_DEFINITIONS})
+
+ set(SOURCES internals/dbus-marshal-recursive-util.c
+ internals/dbus-marshal-recursive-util.h
+ internals/dbus-message-factory.c
+ internals/dbus-message-factory.h
+ internals/dbus-message-util.c
+ internals/dbus-message-util.h
+ internals/message-internals.c)
+ add_test_executable(test-message-internals "${SOURCES}" dbus-testutils)
+ set_target_properties(test-message-internals PROPERTIES COMPILE_FLAGS ${DBUS_INTERNAL_CLIENT_DEFINITIONS})
+
+ set(SOURCES internals/dbus-auth-script.c
+ internals/dbus-auth-script.h
+ internals/dbus-auth-util.c
+ internals/dbus-credentials-util.c
+ internals/dbus-marshal-byteswap-util.c
+ internals/dbus-marshal-recursive-util.c
+ internals/dbus-marshal-recursive-util.h
+ internals/dbus-marshal-validate-util.c
+ internals/dbus-string-util.c
+ internals/dbus-sysdeps-util.c
+ internals/misc-internals.c
+ internals/misc-internals.h)
+ add_test_executable(test-misc-internals "${SOURCES}" dbus-testutils)
+ set_target_properties(test-misc-internals PROPERTIES COMPILE_FLAGS ${DBUS_INTERNAL_CLIENT_DEFINITIONS})
+
+ set(SOURCES bus/main.c)
+ add_test_executable(test-bus "${SOURCES}" dbus-daemon-internal dbus-testutils ${EXPAT_LIBRARIES})
+ set_target_properties(test-bus PROPERTIES COMPILE_FLAGS ${DBUS_INTERNAL_CLIENT_DEFINITIONS})
+
+ set(SOURCES bus/dispatch.c)
+ add_test_executable(test-bus-dispatch "${SOURCES}" dbus-daemon-internal dbus-testutils ${EXPAT_LIBRARIES})
+ set_target_properties(test-bus-dispatch PROPERTIES COMPILE_FLAGS ${DBUS_INTERNAL_CLIENT_DEFINITIONS})
+
+ set(SOURCES bus/dispatch-sha1.c)
+ add_test_executable(test-bus-dispatch-sha1 "${SOURCES}" dbus-daemon-internal dbus-testutils ${EXPAT_LIBRARIES})
+ set_target_properties(test-bus-dispatch-sha1 PROPERTIES COMPILE_FLAGS ${DBUS_INTERNAL_CLIENT_DEFINITIONS})
+
+ if(NOT WIN32)
+ add_test_executable(test-bus-system bus/system.c launch-helper-internal dbus-testutils)
+ add_test_executable(test-bus-launch-helper-oom bus/launch-helper-oom.c launch-helper-internal dbus-testutils)
+ add_helper_executable(dbus-daemon-launch-helper-for-tests bus/launch-helper-for-tests.c launch-helper-internal)
+ endif()
+endif()
+
+if(DBUS_WITH_GLIB)
+ message(STATUS "with glib test apps")
+
+ add_library(dbus-testutils-glib STATIC
+ test-utils-glib.h
+ test-utils-glib.c
+ )
+ target_link_libraries(dbus-testutils-glib dbus-testutils ${DBUS_INTERNAL_LIBRARIES})
+
+ add_definitions(
+ ${GLIB2_DEFINITIONS}
+ )
+ include_directories(
+ ${GLIB2_INCLUDE_DIR}
+ )
+
+ set(TEST_LIBRARIES ${DBUS_INTERNAL_LIBRARIES} dbus-testutils dbus-testutils-glib ${GLIB2_LIBRARIES})
+
+ add_test_executable(test-assertions internals/assertions.c ${TEST_LIBRARIES})
+ add_test_executable(test-corrupt corrupt.c ${TEST_LIBRARIES})
+ add_test_executable(test-dbus-daemon dbus-daemon.c ${TEST_LIBRARIES})
+ add_test_executable(test-dbus-daemon-eavesdrop dbus-daemon-eavesdrop.c ${TEST_LIBRARIES})
+ add_test_executable(test-desktop-file internals/desktop-file.c ${TEST_LIBRARIES})
+ add_test_executable(test-fdpass fdpass.c ${TEST_LIBRARIES})
+ add_test_executable(test-loopback loopback.c ${TEST_LIBRARIES})
+ add_test_executable(test-marshal marshal.c ${TEST_LIBRARIES})
+ add_test_executable(test-monitor monitor.c ${TEST_LIBRARIES})
+ add_test_executable(test-refs internals/refs.c ${TEST_LIBRARIES})
+ add_test_executable(test-relay relay.c ${TEST_LIBRARIES})
+ add_test_executable(test-server-oom internals/server-oom.c ${TEST_LIBRARIES})
+ add_test_executable(test-syntax syntax.c ${TEST_LIBRARIES})
+ add_test_executable(test-sysdeps internals/sysdeps.c ${TEST_LIBRARIES})
+ add_test_executable(test-syslog internals/syslog.c ${TEST_LIBRARIES})
+ add_test_executable(test-uid-permissions uid-permissions.c ${TEST_LIBRARIES})
+ add_helper_executable(manual-authz manual-authz.c ${TEST_LIBRARIES})
+ add_helper_executable(manual-test-thread-blocking thread-blocking.c ${TEST_LIBRARIES})
+endif()
+
+### keep these in creation order, i.e. uppermost dirs first
+set (TESTDIRS
+ data
+ data/invalid-messages
+ data/auth
+ data/sha-1
+ data/systemd-activation
+ data/valid-config-files
+ data/valid-config-files/basic.d
+ data/valid-config-files/session.d
+ data/valid-config-files-system
+ data/valid-config-files-system/system.d
+ data/valid-service-files
+ data/valid-service-files-system
+ data/invalid-config-files
+ data/invalid-config-files-system
+ data/invalid-messages
+ data/invalid-service-files-system
+ data/equiv-config-files
+ data/equiv-config-files/basic
+ data/equiv-config-files/basic/basic.d
+ data/equiv-config-files/entities
+ data/equiv-config-files/entities/basic.d
+)
+set (CONFIG_VERBOSE 1)
+
+FOREACH(DIR ${TESTDIRS})
+ FILE(MAKE_DIRECTORY ${CMAKE_BINARY_DIR}/${DIR})
+ENDFOREACH(DIR)
+
+### copy tests to builddir so that generated tests and static tests
+### are all in one place.
+MESSAGE(STATUS "Copying test files to test directory")
+FOREACH(FILE_TYPE *.message-raw *.auth-script *.sha1 *.txt *.conf *.service)
+ FOREACH(DIR ${TESTDIRS})
+ FILE(GLOB FILES "${DIR}/${FILE_TYPE}" )
+ FOREACH(FILE ${FILES})
+ GET_FILENAME_COMPONENT(FILENAME ${FILE} NAME)
+ SET (TARGET ${CMAKE_CURRENT_BINARY_DIR}/${DIR}/${FILENAME})
+ configure_file(${FILE} ${TARGET} COPYONLY)
+ IF (CONFIG_VERBOSE)
+ MESSAGE("${FILE}")
+ ENDIF (CONFIG_VERBOSE)
+ ENDFOREACH(FILE)
+ ENDFOREACH(DIR)
+ENDFOREACH(FILE_TYPE)
+
+### generate test files
+MESSAGE(STATUS "Generating test files from templates into test directory")
+
+FOREACH(FILE_TYPE *.conf.in *.service.in)
+ FOREACH(DIR ${TESTDIRS})
+ FILE(GLOB FILES "${DIR}/${FILE_TYPE}" )
+ FOREACH(FILE ${FILES})
+ GET_FILENAME_COMPONENT(FILENAME ${FILE} NAME)
+ STRING(REGEX REPLACE "\\.in$" "" FILENAME ${FILENAME})
+ SET (TARGET ${CMAKE_CURRENT_BINARY_DIR}/${DIR}/${FILENAME})
+ configure_file(${FILE} ${TARGET} @ONLY IMMEDIATE)
+ IF (CONFIG_VERBOSE)
+ MESSAGE("${FILE}")
+ ENDIF (CONFIG_VERBOSE)
+ ENDFOREACH(FILE)
+ ENDFOREACH(DIR)
+ENDFOREACH(FILE_TYPE)
+
+MESSAGE(STATUS "Copying generated bus config files to test directory")
+configure_file(../bus/session.conf.in ${CMAKE_BINARY_DIR}/test/data/valid-config-files/session.conf @ONLY)
+configure_file(../bus/system.conf.in ${CMAKE_BINARY_DIR}/test/data/valid-config-files-system/system.conf @ONLY)