|
@@ -43,34 +43,44 @@ protobuf_generate_cpp(PROTO_TEST_SRCS PROTO_TEST_HDRS
|
|
|
${PROTO_HADOOP_TEST_DIR}/test_rpc_service.proto
|
|
|
)
|
|
|
|
|
|
+# Shamelessly stolen from
|
|
|
+# http://stackoverflow.com/questions/9303711/how-do-i-make-ctest-run-a-program-with-valgrind-without-dart
|
|
|
+function(add_memcheck_test name binary)
|
|
|
+ set(memcheck_command "${MEMORYCHECK_COMMAND} ${MEMORYCHECK_COMMAND_OPTIONS}")
|
|
|
+ separate_arguments(memcheck_command)
|
|
|
+ add_test(${name} ${binary} ${ARGN})
|
|
|
+ add_test(memcheck_${name} ${memcheck_command} ./${binary} ${ARGN})
|
|
|
+endfunction(add_memcheck_test)
|
|
|
+
|
|
|
+
|
|
|
add_executable(remote_block_reader_test remote_block_reader_test.cc $<TARGET_OBJECTS:test_common>)
|
|
|
target_link_libraries(remote_block_reader_test reader proto common ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} gmock_main ${CMAKE_THREAD_LIBS_INIT})
|
|
|
-add_test(remote_block_reader remote_block_reader_test)
|
|
|
+add_memcheck_test(remote_block_reader remote_block_reader_test)
|
|
|
|
|
|
add_executable(sasl_digest_md5_test sasl_digest_md5_test.cc)
|
|
|
target_link_libraries(sasl_digest_md5_test common ${OPENSSL_LIBRARIES} gmock_main ${CMAKE_THREAD_LIBS_INIT})
|
|
|
-add_test(sasl_digest_md5 sasl_digest_md5_test)
|
|
|
+add_memcheck_test(sasl_digest_md5 sasl_digest_md5_test)
|
|
|
|
|
|
add_executable(inputstream_test inputstream_test.cc)
|
|
|
target_link_libraries(inputstream_test fs rpc reader proto common ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} gmock_main ${CMAKE_THREAD_LIBS_INIT})
|
|
|
-add_test(inputstream inputstream_test)
|
|
|
+add_memcheck_test(inputstream inputstream_test)
|
|
|
|
|
|
include_directories(${CMAKE_CURRENT_BINARY_DIR})
|
|
|
add_executable(rpc_engine_test rpc_engine_test.cc ${PROTO_TEST_SRCS} ${PROTO_TEST_HDRS} $<TARGET_OBJECTS:test_common>)
|
|
|
target_link_libraries(rpc_engine_test rpc proto common ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} gmock_main ${CMAKE_THREAD_LIBS_INIT})
|
|
|
-add_test(rpc_engine rpc_engine_test)
|
|
|
+add_memcheck_test(rpc_engine rpc_engine_test)
|
|
|
|
|
|
add_executable(bad_datanode_test bad_datanode_test.cc)
|
|
|
target_link_libraries(bad_datanode_test rpc reader proto fs bindings_c rpc proto common reader ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} gmock_main ${CMAKE_THREAD_LIBS_INIT})
|
|
|
-add_test(bad_datanode bad_datanode_test)
|
|
|
+add_memcheck_test(bad_datanode bad_datanode_test)
|
|
|
|
|
|
add_executable(node_exclusion_test node_exclusion_test.cc)
|
|
|
target_link_libraries(node_exclusion_test fs gmock_main common ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} ${CMAKE_THREAD_LIBS_INIT})
|
|
|
-add_test(node_exclusion node_exclusion_test)
|
|
|
+add_memcheck_test(node_exclusion node_exclusion_test)
|
|
|
|
|
|
add_executable(configuration_test configuration_test.cc)
|
|
|
target_link_libraries(configuration_test common gmock_main ${CMAKE_THREAD_LIBS_INIT})
|
|
|
-add_test(configuration configuration_test)
|
|
|
+add_memcheck_test(configuration configuration_test)
|
|
|
|
|
|
build_libhdfs_test(libhdfs_threaded hdfspp_test_shim_static expect.c test_libhdfs_threaded.c ${OS_DIR}/thread.c)
|
|
|
link_libhdfs_test(libhdfs_threaded hdfspp_test_shim_static fs reader rpc proto common ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} native_mini_dfs ${JAVA_JVM_LIBRARY})
|