413 lines
15 KiB
CMake
413 lines
15 KiB
CMake
set(test_prefix memgraph__unit__)
|
|
|
|
find_package(fmt REQUIRED)
|
|
find_package(gflags REQUIRED)
|
|
find_package(Threads REQUIRED)
|
|
|
|
add_custom_target(memgraph__unit)
|
|
|
|
set(memgraph_unit_main main.cpp)
|
|
|
|
function(add_unit_test test_cpp)
|
|
_add_unit_test(${test_cpp} FALSE ${ARGN})
|
|
endfunction(add_unit_test)
|
|
|
|
function(add_unit_test_with_custom_main test_cpp)
|
|
_add_unit_test(${test_cpp} TRUE ${ARGN})
|
|
endfunction(add_unit_test_with_custom_main)
|
|
|
|
function(_add_unit_test test_cpp custom_main)
|
|
# get exec name (remove extension from the abs path)
|
|
get_filename_component(exec_name ${test_cpp} NAME_WE)
|
|
set(target_name ${test_prefix}${exec_name})
|
|
|
|
set(source_files
|
|
${test_cpp}
|
|
${ARGN})
|
|
|
|
if(NOT ${custom_main})
|
|
set(source_files
|
|
${source_files}
|
|
${memgraph_unit_main})
|
|
endif()
|
|
|
|
add_executable(${target_name} ${source_files})
|
|
|
|
# OUTPUT_NAME sets the real name of a target when it is built and can be
|
|
# used to help create two targets of the same name even though CMake
|
|
# requires unique logical target names
|
|
set_target_properties(${target_name} PROPERTIES OUTPUT_NAME ${exec_name})
|
|
target_link_libraries(${target_name} mg-memory mg-utils gtest gmock Threads::Threads dl)
|
|
|
|
# register test
|
|
if(TEST_COVERAGE)
|
|
add_test(${target_name} env LLVM_PROFILE_FILE=${exec_name}.profraw ./${exec_name})
|
|
else()
|
|
add_test(${target_name} ${exec_name})
|
|
endif()
|
|
|
|
# add to memgraph__unit target
|
|
add_dependencies(memgraph__unit ${target_name})
|
|
endfunction(_add_unit_test)
|
|
|
|
# Test utilities
|
|
add_library(storage_test_utils storage_test_utils.cpp)
|
|
target_link_libraries(storage_test_utils mg-storage-v2)
|
|
|
|
# Test integrations-kafka
|
|
add_library(kafka-mock STATIC kafka_mock.cpp)
|
|
target_link_libraries(kafka-mock mg-utils librdkafka++ librdkafka Threads::Threads gtest)
|
|
|
|
# Include directories are intentionally not set, because kafka-mock isn't meant to be used apart from unit tests
|
|
add_unit_test(integrations_kafka_consumer.cpp kafka_mock.cpp)
|
|
target_link_libraries(${test_prefix}integrations_kafka_consumer kafka-mock mg-integrations-kafka)
|
|
|
|
add_unit_test(mgp_kafka_c_api.cpp)
|
|
target_link_libraries(${test_prefix}mgp_kafka_c_api mg-query mg-integrations-kafka)
|
|
|
|
add_unit_test(mgp_trans_c_api.cpp)
|
|
target_link_libraries(${test_prefix}mgp_trans_c_api mg-query)
|
|
|
|
# Test mg-query
|
|
add_unit_test(bfs_single_node.cpp)
|
|
target_link_libraries(${test_prefix}bfs_single_node mg-query)
|
|
|
|
add_unit_test(cypher_main_visitor.cpp)
|
|
target_link_libraries(${test_prefix}cypher_main_visitor mg-query)
|
|
|
|
add_unit_test(interpreter.cpp ${CMAKE_SOURCE_DIR}/src/glue/communication.cpp)
|
|
target_link_libraries(${test_prefix}interpreter mg-communication mg-query)
|
|
|
|
add_unit_test(plan_pretty_print.cpp)
|
|
target_link_libraries(${test_prefix}plan_pretty_print mg-query)
|
|
|
|
add_unit_test(query_cost_estimator.cpp)
|
|
target_link_libraries(${test_prefix}query_cost_estimator mg-query)
|
|
|
|
# TODO Fix later on
|
|
# add_unit_test(query_dump.cpp ${CMAKE_SOURCE_DIR}/src/glue/communication.cpp)
|
|
# target_link_libraries(${test_prefix}query_dump mg-communication mg-query)
|
|
add_unit_test(query_expression_evaluator.cpp)
|
|
target_link_libraries(${test_prefix}query_expression_evaluator mg-query)
|
|
|
|
add_unit_test(query_plan.cpp)
|
|
target_link_libraries(${test_prefix}query_plan mg-query)
|
|
|
|
add_unit_test(query_v2_plan.cpp)
|
|
target_link_libraries(${test_prefix}query_v2_plan mg-query-v2)
|
|
|
|
add_unit_test(query_plan_accumulate_aggregate.cpp)
|
|
target_link_libraries(${test_prefix}query_plan_accumulate_aggregate mg-query)
|
|
|
|
add_unit_test(query_plan_bag_semantics.cpp)
|
|
target_link_libraries(${test_prefix}query_plan_bag_semantics mg-query)
|
|
|
|
add_unit_test(query_plan_create_set_remove_delete.cpp)
|
|
target_link_libraries(${test_prefix}query_plan_create_set_remove_delete mg-query)
|
|
|
|
add_unit_test(query_plan_edge_cases.cpp ${CMAKE_SOURCE_DIR}/src/glue/communication.cpp)
|
|
target_link_libraries(${test_prefix}query_plan_edge_cases mg-communication mg-query)
|
|
|
|
add_unit_test(query_plan_match_filter_return.cpp)
|
|
target_link_libraries(${test_prefix}query_plan_match_filter_return mg-query)
|
|
|
|
add_unit_test(query_plan_read_write_typecheck.cpp
|
|
${CMAKE_SOURCE_DIR}/src/query/plan/read_write_type_checker.cpp)
|
|
target_link_libraries(${test_prefix}query_plan_read_write_typecheck mg-query)
|
|
|
|
add_unit_test(query_plan_v2_create_set_remove_delete.cpp)
|
|
target_link_libraries(${test_prefix}query_plan_v2_create_set_remove_delete mg-query)
|
|
|
|
add_unit_test(query_pretty_print.cpp)
|
|
target_link_libraries(${test_prefix}query_pretty_print mg-query)
|
|
|
|
add_unit_test(query_trigger.cpp)
|
|
target_link_libraries(${test_prefix}query_trigger mg-query)
|
|
|
|
add_unit_test(query_serialization_property_value.cpp)
|
|
target_link_libraries(${test_prefix}query_serialization_property_value mg-query)
|
|
|
|
add_unit_test(query_streams.cpp)
|
|
target_link_libraries(${test_prefix}query_streams mg-query kafka-mock)
|
|
|
|
# Test query functions
|
|
add_unit_test(query_function_mgp_module.cpp)
|
|
target_link_libraries(${test_prefix}query_function_mgp_module mg-query)
|
|
target_include_directories(${test_prefix}query_function_mgp_module PRIVATE ${CMAKE_SOURCE_DIR}/include)
|
|
|
|
# Test query/procedure
|
|
add_unit_test(query_procedure_mgp_type.cpp)
|
|
target_link_libraries(${test_prefix}query_procedure_mgp_type mg-query)
|
|
target_include_directories(${test_prefix}query_procedure_mgp_type PRIVATE ${CMAKE_SOURCE_DIR}/include)
|
|
|
|
add_unit_test(query_procedure_mgp_module.cpp)
|
|
target_link_libraries(${test_prefix}query_procedure_mgp_module mg-query)
|
|
target_include_directories(${test_prefix}query_procedure_mgp_module PRIVATE ${CMAKE_SOURCE_DIR}/include)
|
|
|
|
add_unit_test_with_custom_main(query_procedure_py_module.cpp)
|
|
target_link_libraries(${test_prefix}query_procedure_py_module mg-query)
|
|
target_include_directories(${test_prefix}query_procedure_py_module PRIVATE ${CMAKE_SOURCE_DIR}/include)
|
|
|
|
add_unit_test(query_procedures_mgp_graph.cpp)
|
|
target_link_libraries(${test_prefix}query_procedures_mgp_graph mg-query storage_test_utils)
|
|
target_include_directories(${test_prefix}query_procedures_mgp_graph PRIVATE ${CMAKE_SOURCE_DIR}/include)
|
|
|
|
# END query/procedure
|
|
add_unit_test(query_profile.cpp)
|
|
target_link_libraries(${test_prefix}query_profile mg-query)
|
|
|
|
add_unit_test(query_required_privileges.cpp)
|
|
target_link_libraries(${test_prefix}query_required_privileges mg-query)
|
|
|
|
add_unit_test(query_semantic.cpp)
|
|
target_link_libraries(${test_prefix}query_semantic mg-query)
|
|
|
|
add_unit_test(query_variable_start_planner.cpp)
|
|
target_link_libraries(${test_prefix}query_variable_start_planner mg-query)
|
|
|
|
add_unit_test(stripped.cpp)
|
|
target_link_libraries(${test_prefix}stripped mg-query)
|
|
|
|
add_unit_test(typed_value.cpp)
|
|
target_link_libraries(${test_prefix}typed_value mg-query)
|
|
|
|
# Test mg-communication
|
|
add_unit_test(bolt_chunked_decoder_buffer.cpp)
|
|
target_link_libraries(${test_prefix}bolt_chunked_decoder_buffer mg-communication)
|
|
|
|
add_unit_test(bolt_chunked_encoder_buffer.cpp)
|
|
target_link_libraries(${test_prefix}bolt_chunked_encoder_buffer mg-communication)
|
|
|
|
add_unit_test(bolt_decoder.cpp)
|
|
target_link_libraries(${test_prefix}bolt_decoder mg-communication)
|
|
|
|
add_unit_test(bolt_encoder.cpp ${CMAKE_SOURCE_DIR}/src/glue/communication.cpp)
|
|
target_link_libraries(${test_prefix}bolt_encoder mg-communication mg-query)
|
|
|
|
add_unit_test(bolt_session.cpp)
|
|
target_link_libraries(${test_prefix}bolt_session mg-communication mg-utils)
|
|
|
|
add_unit_test(communication_buffer.cpp)
|
|
target_link_libraries(${test_prefix}communication_buffer mg-communication mg-utils)
|
|
|
|
add_unit_test(network_timeouts.cpp)
|
|
target_link_libraries(${test_prefix}network_timeouts mg-communication)
|
|
|
|
# Test mg-kvstore
|
|
add_unit_test(kvstore.cpp)
|
|
target_link_libraries(${test_prefix}kvstore mg-kvstore mg-utils)
|
|
|
|
# Test data structures
|
|
add_unit_test(ring_buffer.cpp)
|
|
target_link_libraries(${test_prefix}ring_buffer mg-utils)
|
|
|
|
# Test mg-io
|
|
add_unit_test(network_endpoint.cpp)
|
|
target_link_libraries(${test_prefix}network_endpoint mg-io)
|
|
|
|
add_unit_test(network_utils.cpp)
|
|
target_link_libraries(${test_prefix}network_utils mg-io)
|
|
|
|
add_unit_test(socket.cpp)
|
|
target_link_libraries(${test_prefix}socket mg-io)
|
|
|
|
# Test mg-utils
|
|
add_unit_test(utils_algorithm.cpp)
|
|
target_link_libraries(${test_prefix}utils_algorithm mg-utils)
|
|
|
|
add_unit_test(utils_exceptions.cpp)
|
|
target_link_libraries(${test_prefix}utils_exceptions mg-utils)
|
|
|
|
add_unit_test(utils_file.cpp)
|
|
target_link_libraries(${test_prefix}utils_file mg-utils)
|
|
|
|
add_unit_test(utils_math.cpp)
|
|
target_link_libraries(${test_prefix}utils_math mg-utils)
|
|
|
|
add_unit_test(utils_memory.cpp)
|
|
target_link_libraries(${test_prefix}utils_memory mg-utils)
|
|
|
|
add_unit_test(utils_memory_tracker.cpp)
|
|
target_link_libraries(${test_prefix}utils_memory_tracker mg-utils)
|
|
|
|
add_unit_test(utils_on_scope_exit.cpp)
|
|
target_link_libraries(${test_prefix}utils_on_scope_exit mg-utils)
|
|
|
|
add_unit_test(utils_rwlock.cpp)
|
|
target_link_libraries(${test_prefix}utils_rwlock mg-utils)
|
|
|
|
add_unit_test(utils_scheduler.cpp)
|
|
target_link_libraries(${test_prefix}utils_scheduler mg-utils)
|
|
|
|
add_unit_test(utils_signals.cpp)
|
|
target_link_libraries(${test_prefix}utils_signals mg-utils)
|
|
|
|
add_unit_test(utils_string.cpp)
|
|
target_link_libraries(${test_prefix}utils_string mg-utils)
|
|
|
|
add_unit_test(utils_synchronized.cpp)
|
|
target_link_libraries(${test_prefix}utils_synchronized mg-utils)
|
|
|
|
add_unit_test(utils_timestamp.cpp)
|
|
target_link_libraries(${test_prefix}utils_timestamp mg-utils)
|
|
|
|
add_unit_test(skip_list.cpp)
|
|
target_link_libraries(${test_prefix}skip_list mg-utils)
|
|
|
|
add_unit_test(small_vector.cpp)
|
|
target_link_libraries(${test_prefix}small_vector mg-utils)
|
|
|
|
add_unit_test(utils_file_locker.cpp)
|
|
target_link_libraries(${test_prefix}utils_file_locker mg-utils fmt)
|
|
|
|
add_unit_test(utils_thread_pool.cpp)
|
|
target_link_libraries(${test_prefix}utils_thread_pool mg-utils fmt)
|
|
|
|
add_unit_test(utils_csv_parsing.cpp ${CMAKE_SOURCE_DIR}/src/utils/csv_parsing.cpp)
|
|
target_link_libraries(${test_prefix}utils_csv_parsing mg-utils fmt)
|
|
|
|
add_unit_test(utils_async_timer.cpp)
|
|
target_link_libraries(${test_prefix}utils_async_timer mg-utils)
|
|
|
|
add_unit_test(utils_license.cpp)
|
|
target_link_libraries(${test_prefix}utils_license mg-utils mg-license)
|
|
|
|
add_unit_test(utils_settings.cpp)
|
|
target_link_libraries(${test_prefix}utils_settings mg-utils mg-settings)
|
|
|
|
add_unit_test(utils_temporal utils_temporal.cpp)
|
|
target_link_libraries(${test_prefix}utils_temporal mg-utils)
|
|
|
|
add_unit_test(utils_histogram.cpp)
|
|
target_link_libraries(${test_prefix}utils_histogram mg-utils)
|
|
|
|
# Test mg-storage-v3
|
|
add_library(storage_v3_test_utils storage_v3_test_utils.cpp)
|
|
target_link_libraries(storage_v3_test_utils mg-storage-v3)
|
|
|
|
add_unit_test(storage_v3.cpp)
|
|
target_link_libraries(${test_prefix}storage_v3 mg-storage-v3 storage_v3_test_utils)
|
|
|
|
add_unit_test(storage_v3_expr.cpp)
|
|
target_link_libraries(${test_prefix}storage_v3_expr mg-storage-v3 mg-expr)
|
|
|
|
add_unit_test(storage_v3_schema.cpp)
|
|
target_link_libraries(${test_prefix}storage_v3_schema mg-storage-v3)
|
|
|
|
# Test mg-query-v2
|
|
# These are commented out because of the new TypedValue in the query engine
|
|
# add_unit_test(query_v2_interpreter.cpp ${CMAKE_SOURCE_DIR}/src/glue/v2/communication.cpp)
|
|
# target_link_libraries(${test_prefix}query_v2_interpreter mg-storage-v3 mg-query-v2 mg-communication)
|
|
#
|
|
# add_unit_test(query_v2_query_plan_accumulate_aggregate.cpp)
|
|
# target_link_libraries(${test_prefix}query_v2_query_plan_accumulate_aggregate mg-query-v2)
|
|
#
|
|
# add_unit_test(query_v2_query_plan_create_set_remove_delete.cpp)
|
|
# target_link_libraries(${test_prefix}query_v2_query_plan_create_set_remove_delete mg-query-v2 mg-expr)
|
|
#
|
|
# add_unit_test(query_v2_query_plan_bag_semantics.cpp)
|
|
# target_link_libraries(${test_prefix}query_v2_query_plan_bag_semantics mg-query-v2)
|
|
#
|
|
# add_unit_test(query_v2_query_plan_edge_cases.cpp ${CMAKE_SOURCE_DIR}/src/glue/v2/communication.cpp)
|
|
# target_link_libraries(${test_prefix}query_v2_query_plan_edge_cases mg-communication mg-query-v2)
|
|
#
|
|
# add_unit_test(query_v2_query_plan_v2_create_set_remove_delete.cpp)
|
|
# target_link_libraries(${test_prefix}query_v2_query_plan_v2_create_set_remove_delete mg-query-v2)
|
|
#
|
|
# add_unit_test(query_v2_query_plan_match_filter_return.cpp)
|
|
# target_link_libraries(${test_prefix}query_v2_query_plan_match_filter_return mg-query-v2)
|
|
#
|
|
# add_unit_test(query_v2_cypher_main_visitor.cpp)
|
|
# target_link_libraries(${test_prefix}query_v2_cypher_main_visitor mg-query-v2)
|
|
#
|
|
# add_unit_test(query_v2_query_required_privileges.cpp)
|
|
# target_link_libraries(${test_prefix}query_v2_query_required_privileges mg-query-v2)
|
|
#
|
|
# add_unit_test(replication_persistence_helper.cpp)
|
|
# target_link_libraries(${test_prefix}replication_persistence_helper mg-storage-v2)
|
|
add_unit_test(query_v2_dummy_test.cpp)
|
|
target_link_libraries(${test_prefix}query_v2_dummy_test mg-query-v2)
|
|
|
|
add_unit_test(storage_v3_property_store.cpp)
|
|
target_link_libraries(${test_prefix}storage_v3_property_store mg-storage-v3 fmt)
|
|
|
|
add_unit_test(storage_v3_indices.cpp)
|
|
target_link_libraries(${test_prefix}storage_v3_indices mg-storage-v3)
|
|
|
|
add_unit_test(storage_v3_vertex_accessors.cpp)
|
|
target_link_libraries(${test_prefix}storage_v3_vertex_accessors mg-storage-v3)
|
|
|
|
add_unit_test(storage_v3_edge.cpp)
|
|
target_link_libraries(${test_prefix}storage_v3_edge mg-storage-v3)
|
|
|
|
add_unit_test(storage_v3_isolation_level.cpp)
|
|
target_link_libraries(${test_prefix}storage_v3_isolation_level mg-storage-v3)
|
|
|
|
add_unit_test(storage_v3_shard_rsm.cpp)
|
|
target_link_libraries(${test_prefix}storage_v3_shard_rsm mg-storage-v3)
|
|
|
|
add_unit_test(replication_persistence_helper.cpp)
|
|
target_link_libraries(${test_prefix}replication_persistence_helper mg-storage-v2)
|
|
|
|
# Test mg-auth
|
|
if(MG_ENTERPRISE)
|
|
add_unit_test(auth.cpp)
|
|
target_link_libraries(${test_prefix}auth mg-auth mg-license)
|
|
endif()
|
|
|
|
# Test mg-slk
|
|
if(MG_ENTERPRISE)
|
|
add_unit_test(slk_advanced.cpp)
|
|
target_link_libraries(${test_prefix}slk_advanced mg-storage-v2)
|
|
endif()
|
|
|
|
if(MG_ENTERPRISE)
|
|
add_unit_test(slk_core.cpp)
|
|
target_link_libraries(${test_prefix}slk_core mg-slk gflags fmt)
|
|
|
|
add_unit_test(slk_streams.cpp)
|
|
target_link_libraries(${test_prefix}slk_streams mg-slk gflags fmt)
|
|
endif()
|
|
|
|
# Test mg-rpc
|
|
if(MG_ENTERPRISE)
|
|
add_unit_test(rpc.cpp)
|
|
target_link_libraries(${test_prefix}rpc mg-rpc)
|
|
endif()
|
|
|
|
# Test LCP
|
|
add_custom_command(
|
|
OUTPUT test_lcp
|
|
DEPENDS ${lcp_src_files} lcp test_lcp.lisp
|
|
COMMAND sbcl --script ${CMAKE_CURRENT_SOURCE_DIR}/test_lcp.lisp)
|
|
add_custom_target(test_lcp ALL DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/test_lcp)
|
|
add_test(test_lcp ${CMAKE_CURRENT_BINARY_DIR}/test_lcp)
|
|
add_dependencies(memgraph__unit test_lcp)
|
|
|
|
# Test Future
|
|
add_unit_test(future.cpp)
|
|
target_link_libraries(${test_prefix}future mg-io)
|
|
|
|
# Test LocalTransport
|
|
add_unit_test(local_transport.cpp)
|
|
target_link_libraries(${test_prefix}local_transport mg-io)
|
|
|
|
# Test MachineManager with LocalTransport
|
|
add_unit_test(machine_manager.cpp)
|
|
target_link_libraries(${test_prefix}machine_manager mg-io mg-coordinator mg-storage-v3 mg-query-v2)
|
|
|
|
add_unit_test(pretty_print_ast_to_original_expression_test.cpp)
|
|
target_link_libraries(${test_prefix}pretty_print_ast_to_original_expression_test mg-io mg-expr mg-query-v2)
|
|
|
|
# Tests for mg-coordinator
|
|
add_unit_test(coordinator_shard_map.cpp)
|
|
target_link_libraries(${test_prefix}coordinator_shard_map mg-coordinator)
|
|
|
|
# Tests for many shards, many creates, scan
|
|
add_unit_test(high_density_shard_create_scan.cpp)
|
|
target_link_libraries(${test_prefix}high_density_shard_create_scan mg-io mg-coordinator mg-storage-v3 mg-query-v2)
|
|
|
|
# Tests for awesome_memgraph_functions
|
|
add_unit_test(query_v2_expression_evaluator.cpp)
|
|
target_link_libraries(${test_prefix}query_v2_expression_evaluator mg-query-v2)
|