Fix the linking of various tests against GMock
authorChristopher Dykes <cdykes@fb.com>
Sat, 20 May 2017 03:57:10 +0000 (20:57 -0700)
committerFacebook Github Bot <facebook-github-bot@users.noreply.github.com>
Sat, 20 May 2017 04:06:38 +0000 (21:06 -0700)
Summary: A define was needed to be able to link when built against a shared-library version of gmock and gtest.

Reviewed By: yfeldblum

Differential Revision: D5100409

fbshipit-source-id: 9a4c9df20f682a25edde642c451476b2d1e1ae22

CMake/FindGMock.cmake
CMakeLists.txt

index d4f615250210e2f4efd26e9285a753cf91b7a245..9078c2c137b24ec4e0d1c1f0491c237df723c115 100755 (executable)
@@ -1,6 +1,7 @@
 #
 # Find libgmock
 #
+#  LIBGMOCK_DEFINES     - List of defines when using libgmock.
 #  LIBGMOCK_INCLUDE_DIR - where to find gmock/gmock.h, etc.
 #  LIBGMOCK_LIBRARY     - List of libraries when using libgmock.
 #  LIBGMOCK_FOUND       - True if libgmock found.
@@ -15,9 +16,14 @@ FIND_PATH(LIBGMOCK_INCLUDE_DIR gmock/gmock.h)
 
 FIND_LIBRARY(LIBGMOCK_LIBRARY gmock_main)
 
+# There isn't currently an easy way to determine if a library was compiled as
+# a shared library on Windows, so just assume we've been built against a shared
+# build of gmock for now.
+SET(LIBGMOCK_DEFINES "GTEST_LINKED_AS_SHARED_LIBRARY=1" CACHE STRING "")
+
 # handle the QUIETLY and REQUIRED arguments and set LIBGMOCK_FOUND to TRUE if
 # all listed variables are TRUE
 INCLUDE(FindPackageHandleStandardArgs)
-FIND_PACKAGE_HANDLE_STANDARD_ARGS(LIBGMOCK DEFAULT_MSG LIBGMOCK_LIBRARY LIBGMOCK_INCLUDE_DIR)
+FIND_PACKAGE_HANDLE_STANDARD_ARGS(LIBGMOCK DEFAULT_MSG LIBGMOCK_DEFINES LIBGMOCK_LIBRARY LIBGMOCK_INCLUDE_DIR)
 
-MARK_AS_ADVANCED(LIBGMOCK_LIBRARY LIBGMOCK_INCLUDE_DIR)
+MARK_AS_ADVANCED(LIBGMOCK_DEFINES LIBGMOCK_LIBRARY LIBGMOCK_INCLUDE_DIR)
index 38886d6599ab08e0eed0d65f678a967a2836d5df..c17760a2ed731b3d2c9e21cc81206a24c3d6f9d8 100755 (executable)
@@ -263,6 +263,10 @@ if (BUILD_TESTS)
     ${FOLLY_DIR}/io/async/test/UndelayedDestruction.h
     ${FOLLY_DIR}/io/async/test/Util.h
   )
+  target_compile_definitions(folly_test_support
+    PUBLIC
+      ${LIBGMOCK_DEFINES}
+  )
   target_include_directories(folly_test_support
     PUBLIC
       ${LIBGMOCK_INCLUDE_DIR}