75950664a7
Summary: This diff splits single node and distributed storage from each other. Currently all of the storage code is copied into two directories (one single node, one distributed). The logic used in the storage implementation isn't touched, it will be refactored in following diffs. To clean the working directory after this diff you should execute: ``` rm database/state_delta.capnp rm database/state_delta.hpp rm storage/concurrent_id_mapper_rpc_messages.capnp rm storage/concurrent_id_mapper_rpc_messages.hpp ``` Reviewers: teon.banek, buda, msantl Reviewed By: teon.banek, msantl Subscribers: teon.banek, pullbot Differential Revision: https://phabricator.memgraph.io/D1625
62 lines
2.6 KiB
CMake
62 lines
2.6 KiB
CMake
set(test_prefix memgraph__benchmark__)
|
|
|
|
add_custom_target(memgraph__benchmark)
|
|
|
|
function(add_benchmark test_cpp)
|
|
# 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})
|
|
add_executable(${target_name} ${test_cpp})
|
|
# 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} benchmark)
|
|
target_include_directories(${target_name} PRIVATE ${BENCHMARK_INCLUDE_DIR})
|
|
# register test
|
|
set(output_path
|
|
${CMAKE_BINARY_DIR}/test_results/benchmark/${target_name}.json)
|
|
add_test(${target_name} ${exec_name}
|
|
--benchmark_out_format=json --benchmark_out=${output_path})
|
|
add_dependencies(memgraph__benchmark ${target_name})
|
|
endfunction(add_benchmark)
|
|
|
|
add_benchmark(data_structures/concurrent/map_mix_concurrent.cpp)
|
|
target_link_libraries(${test_prefix}map_mix_concurrent mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(data_structures/concurrent/skiplist_insert.cpp)
|
|
target_link_libraries(${test_prefix}skiplist_insert mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(data_structures/concurrent/skiplist_reverse_iteration.cpp)
|
|
target_link_libraries(${test_prefix}skiplist_reverse_iteration mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(data_structures/concurrent/map_concurrent.cpp)
|
|
target_link_libraries(${test_prefix}map_concurrent mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(data_structures/ring_buffer.cpp)
|
|
target_link_libraries(${test_prefix}ring_buffer mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(query/eval.cpp)
|
|
target_link_libraries(${test_prefix}eval mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(query/planner.cpp)
|
|
target_link_libraries(${test_prefix}planner mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(query/stripped.cpp)
|
|
target_link_libraries(${test_prefix}stripped mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(edge_storage.cpp)
|
|
target_link_libraries(${test_prefix}edge_storage mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(mvcc.cpp)
|
|
target_link_libraries(${test_prefix}mvcc mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(serialization.cpp)
|
|
target_link_libraries(${test_prefix}serialization mg-distributed kvstore_dummy_lib)
|
|
|
|
add_benchmark(tx_engine.cpp)
|
|
target_link_libraries(${test_prefix}tx_engine mg-single-node kvstore_dummy_lib)
|
|
|
|
add_benchmark(expansion.cpp)
|
|
target_link_libraries(${test_prefix}expansion mg-single-node kvstore_dummy_lib)
|