CMakeLists.txt 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. #
  2. # Licensed to the Apache Software Foundation (ASF) under one
  3. # or more contributor license agreements. See the NOTICE file
  4. # distributed with this work for additional information
  5. # regarding copyright ownership. The ASF licenses this file
  6. # to you under the Apache License, Version 2.0 (the
  7. # "License"); you may not use this file except in compliance
  8. # with the License. You may obtain a copy of the License at
  9. #
  10. # http://www.apache.org/licenses/LICENSE-2.0
  11. #
  12. # Unless required by applicable law or agreed to in writing, software
  13. # distributed under the License is distributed on an "AS IS" BASIS,
  14. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. # See the License for the specific language governing permissions and
  16. # limitations under the License.
  17. #
  18. # Delegate some functionality to libhdfs, until libhdfspp is complete.
  19. set (LIBHDFS_SRC_DIR ../../libhdfs)
  20. set (LIBHDFS_TESTS_DIR ../../libhdfs-tests)
  21. set (LIBHDFSPP_SRC_DIR ..)
  22. set (LIBHDFSPP_LIB_DIR ${LIBHDFSPP_SRC_DIR}/lib)
  23. set (LIBHDFSPP_BINDING_C ${LIBHDFSPP_LIB_DIR}/bindings/c)
  24. include_directories(
  25. ${GENERATED_JAVAH}
  26. ${CMAKE_CURRENT_SOURCE_DIR}
  27. ${CMAKE_BINARY_DIR}
  28. ${JNI_INCLUDE_DIRS}
  29. ${LIBHDFS_SRC_DIR}/include
  30. ${LIBHDFS_SRC_DIR}/..
  31. ${LIBHDFS_SRC_DIR}
  32. ${OS_DIR}
  33. )
  34. add_library(hdfspp_test_shim_static STATIC hdfs_shim.c libhdfs_wrapper.c libhdfspp_wrapper.cc ${LIBHDFSPP_BINDING_C}/hdfs.cc)
  35. add_library(test_common OBJECT mock_connection.cc)
  36. set(PROTOBUF_IMPORT_DIRS ${PROTO_HADOOP_TEST_DIR})
  37. protobuf_generate_cpp(PROTO_TEST_SRCS PROTO_TEST_HDRS
  38. ${PROTO_HADOOP_TEST_DIR}/test.proto
  39. ${PROTO_HADOOP_TEST_DIR}/test_rpc_service.proto
  40. )
  41. add_executable(remote_block_reader_test remote_block_reader_test.cc $<TARGET_OBJECTS:test_common>)
  42. target_link_libraries(remote_block_reader_test reader proto common connection ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} gmock_main ${CMAKE_THREAD_LIBS_INIT})
  43. add_test(remote_block_reader remote_block_reader_test)
  44. add_executable(sasl_digest_md5_test sasl_digest_md5_test.cc)
  45. target_link_libraries(sasl_digest_md5_test common ${OPENSSL_LIBRARIES} gmock_main ${CMAKE_THREAD_LIBS_INIT})
  46. add_test(sasl_digest_md5 sasl_digest_md5_test)
  47. include_directories(${CMAKE_CURRENT_BINARY_DIR})
  48. add_executable(rpc_engine_test rpc_engine_test.cc ${PROTO_TEST_SRCS} ${PROTO_TEST_HDRS} $<TARGET_OBJECTS:test_common>)
  49. target_link_libraries(rpc_engine_test rpc proto common ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} gmock_main ${CMAKE_THREAD_LIBS_INIT})
  50. add_test(rpc_engine rpc_engine_test)
  51. add_executable(bad_datanode_test bad_datanode_test.cc)
  52. target_link_libraries(bad_datanode_test rpc reader proto fs bindings_c rpc proto common reader connection ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} gmock_main ${CMAKE_THREAD_LIBS_INIT})
  53. add_test(bad_datanode bad_datanode_test)
  54. add_executable(node_exclusion_test node_exclusion_test.cc)
  55. target_link_libraries(node_exclusion_test fs gmock_main common ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} ${CMAKE_THREAD_LIBS_INIT})
  56. add_test(node_exclusion node_exclusion_test)
  57. add_executable(configuration_test configuration_test.cc)
  58. target_link_libraries(configuration_test common gmock_main ${CMAKE_THREAD_LIBS_INIT})
  59. add_test(configuration configuration_test)
  60. build_libhdfs_test(libhdfs_threaded hdfspp_test_shim_static expect.c test_libhdfs_threaded.c ${OS_DIR}/thread.c)
  61. link_libhdfs_test(libhdfs_threaded hdfspp_test_shim_static fs reader rpc proto common connection ${PROTOBUF_LIBRARIES} ${OPENSSL_LIBRARIES} native_mini_dfs ${JAVA_JVM_LIBRARY})
  62. add_libhdfs_test(libhdfs_threaded hdfspp_test_shim_static)