test: Add initial support for catch2
This will be used by future test cases in place of googletest.
Change-Id: I41bf1d4f85ebffd1353e6d33a8eaee49803cb254
Signed-off-by: William A. Kennington III <wak@google.com>
diff --git a/test/meson.build b/test/meson.build
index 4f77a56..a748b70 100644
--- a/test/meson.build
+++ b/test/meson.build
@@ -15,7 +15,7 @@
endif
endif
-tests = [
+gtests = [
'signal',
'handle/copyable',
'handle/managed',
@@ -23,8 +23,49 @@
'util/string',
]
-foreach t : tests
+foreach t : gtests
test(t, executable(t.underscorify(), t + '.cpp',
implicit_include_directories: false,
dependencies: [stdplus, gtest, gmock]))
endforeach
+
+# catch2 might not have a pkg-config. It is header only so just make
+# sure we can access the needed symbols from the header.
+catch2_dep = dependency('Catch2', required: false)
+has_catch2 = meson.get_compiler('cpp').has_header_symbol(
+ 'catch2/catch.hpp',
+ 'Approx',
+ dependencies: catch2_dep,
+ required: false)
+if not has_catch2
+ catch2_proj = import('cmake').subproject(
+ 'Catch2',
+ cmake_options: [
+ '-DBUILD_TESTING=OFF'
+ ],
+ required: false)
+ if catch2_proj.found()
+ catch2_dep = catch2_proj.dependency('Catch2')
+ has_catch2 = true
+ else
+ assert(not build_tests.enabled(), 'Catch2 is required')
+ endif
+endif
+
+catch2_tests = [
+]
+
+if has_catch2
+ libcatch2 = static_library(
+ 'catch2', 'catch2_main.cpp',
+ implicit_include_directories: false,
+ build_by_default: false,
+ dependencies: catch2_dep)
+
+ foreach t : catch2_tests
+ test(t, executable(t.underscorify(), t + '.cpp',
+ implicit_include_directories: false,
+ link_with: libcatch2,
+ dependencies: [stdplus, catch2_dep]))
+ endforeach
+endif