acc655f4fd
This PR adds support for generating randomized workloads that will be executed against a simulated cluster, as well as against a correctness model. Initially this just generates ScanAll and CreateVertex requests, and anything that it creates, it also inserts into a `std::set`, and when we do a ScanAll, it asserts that we get the same number of requests back. This will become much more sophisticated over time, but it's already hitting pay-dirt.
35 lines
1.3 KiB
CMake
35 lines
1.3 KiB
CMake
set(test_prefix memgraph__simulation__)
|
|
|
|
find_package(gflags)
|
|
find_package(Boost REQUIRED)
|
|
find_package(OpenSSL REQUIRED)
|
|
|
|
add_custom_target(memgraph__simulation)
|
|
|
|
function(add_simulation_test 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} mg-storage-v3 mg-communication mg-utils mg-io mg-io-simulator mg-coordinator mg-query-v2)
|
|
target_link_libraries(${target_name} Boost::headers)
|
|
target_link_libraries(${target_name} gtest gtest_main gmock rapidcheck rapidcheck_gtest)
|
|
|
|
# register test
|
|
add_test(${target_name} ${exec_name})
|
|
add_dependencies(memgraph__simulation ${target_name})
|
|
endfunction(add_simulation_test)
|
|
|
|
add_simulation_test(basic_request.cpp)
|
|
add_simulation_test(raft.cpp)
|
|
add_simulation_test(trial_query_storage/query_storage_test.cpp)
|
|
add_simulation_test(sharded_map.cpp)
|
|
add_simulation_test(shard_rsm.cpp)
|
|
add_simulation_test(cluster_property_test.cpp)
|