diff --git a/crypto3/libs/marshalling/zk/test/CMakeLists.txt b/crypto3/libs/marshalling/zk/test/CMakeLists.txt index fba9aa60d3..f5fa15e7b2 100644 --- a/crypto3/libs/marshalling/zk/test/CMakeLists.txt +++ b/crypto3/libs/marshalling/zk/test/CMakeLists.txt @@ -32,6 +32,7 @@ macro(define_marshalling_test test) cm_test(NAME ${full_test_name} SOURCES ${test}.cpp) target_include_directories(marshalling_zk_${name}_test PRIVATE + "$" "$" "$" diff --git a/crypto3/libs/marshalling/zk/test/lpc_commitment.cpp b/crypto3/libs/marshalling/zk/test/lpc_commitment.cpp index 01fe347716..a951089cc2 100644 --- a/crypto3/libs/marshalling/zk/test/lpc_commitment.cpp +++ b/crypto3/libs/marshalling/zk/test/lpc_commitment.cpp @@ -170,7 +170,7 @@ BOOST_AUTO_TEST_SUITE(marshalling_random) using LPC = typename nil::crypto3::zk::commitments::batched_list_polynomial_commitment; using lpc_scheme_type = nil::crypto3::zk::commitments::lpc_commitment_scheme>; -BOOST_FIXTURE_TEST_CASE(lpc_proof_test, zk::test_tools::random_test_initializer) { +BOOST_FIXTURE_TEST_CASE(lpc_proof_test, test_tools::random_test_initializer) { typename FRI::params_type fri_params(1, r + 1, lambda, 4); @@ -185,7 +185,7 @@ BOOST_FIXTURE_TEST_CASE(lpc_proof_test, zk::test_tools::random_test_initializer< test_lpc_proof(proof, fri_params); } -BOOST_FIXTURE_TEST_CASE(lpc_aggregated_proof_test, zk::test_tools::random_test_initializer) { +BOOST_FIXTURE_TEST_CASE(lpc_aggregated_proof_test, test_tools::random_test_initializer) { typename FRI::params_type fri_params(1, r + 1, lambda, 4); auto proof = generate_random_lpc_aggregated_proof( @@ -210,7 +210,7 @@ BOOST_AUTO_TEST_SUITE(marshalling_real) using transcript_hash_type = nil::crypto3::hashes::keccak_1600<256>; using merkle_tree_type = typename containers::merkle_tree; -BOOST_FIXTURE_TEST_CASE(batches_num_3_test, zk::test_tools::random_test_initializer){ +BOOST_FIXTURE_TEST_CASE(batches_num_3_test, test_tools::random_test_initializer){ // Setup types. constexpr static const std::size_t lambda = 40; constexpr static const std::size_t k = 1; diff --git a/crypto3/libs/marshalling/zk/test/placeholder_common_data.cpp b/crypto3/libs/marshalling/zk/test/placeholder_common_data.cpp index 5615616f39..f972641a5a 100644 --- a/crypto3/libs/marshalling/zk/test/placeholder_common_data.cpp +++ b/crypto3/libs/marshalling/zk/test/placeholder_common_data.cpp @@ -53,7 +53,7 @@ #include #include #include -#include +#include #include #include diff --git a/crypto3/libs/marshalling/zk/test/placeholder_preprocessed_public_data.cpp b/crypto3/libs/marshalling/zk/test/placeholder_preprocessed_public_data.cpp index 11ea97d8c8..c6d685525a 100644 --- a/crypto3/libs/marshalling/zk/test/placeholder_preprocessed_public_data.cpp +++ b/crypto3/libs/marshalling/zk/test/placeholder_preprocessed_public_data.cpp @@ -49,7 +49,7 @@ #include #include #include -#include +#include #include #include diff --git a/crypto3/libs/marshalling/zk/test/placeholder_proof.cpp b/crypto3/libs/marshalling/zk/test/placeholder_proof.cpp index cafb311f26..eb4657c625 100644 --- a/crypto3/libs/marshalling/zk/test/placeholder_proof.cpp +++ b/crypto3/libs/marshalling/zk/test/placeholder_proof.cpp @@ -82,7 +82,7 @@ #include #include #include -#include +#include #include #include diff --git a/crypto3/libs/marshalling/zk/test/plonk_assignment_table.cpp b/crypto3/libs/marshalling/zk/test/plonk_assignment_table.cpp index 353d779b8f..a3e5948803 100644 --- a/crypto3/libs/marshalling/zk/test/plonk_assignment_table.cpp +++ b/crypto3/libs/marshalling/zk/test/plonk_assignment_table.cpp @@ -26,7 +26,7 @@ #include #include #include -#include +#include #include #include @@ -236,7 +236,7 @@ BOOST_FIXTURE_TEST_CASE(assignment_table_marshalling_test, test_tools::random_te test_assignment_table(desc.usable_rows_amount, assignments, "circuit2"); else test_assignment_table(desc.usable_rows_amount, assignments); - + test_assignment_table_description>(desc); } BOOST_AUTO_TEST_SUITE_END() @@ -295,7 +295,7 @@ BOOST_FIXTURE_TEST_CASE(assignment_table_marshalling_test, test_tools::random_te test_assignment_table(desc.usable_rows_amount, assignments, "circuit3"); else test_assignment_table(desc.usable_rows_amount, assignments); - + test_assignment_table_description>(desc); } BOOST_AUTO_TEST_SUITE_END() @@ -356,7 +356,7 @@ BOOST_FIXTURE_TEST_CASE(assignment_table_marshalling_test, test_tools::random_te test_assignment_table(desc.usable_rows_amount, assignments, "circuit4"); else test_assignment_table(desc.usable_rows_amount, assignments); - + test_assignment_table_description>(desc); } BOOST_AUTO_TEST_SUITE_END() @@ -477,7 +477,7 @@ BOOST_FIXTURE_TEST_CASE(assignment_table_marshalling_test, test_tools::random_te test_assignment_table(desc.usable_rows_amount, assignments, "circuit6"); else test_assignment_table(desc.usable_rows_amount, assignments); - + test_assignment_table_description>(desc); } BOOST_AUTO_TEST_SUITE_END() @@ -535,7 +535,7 @@ BOOST_FIXTURE_TEST_CASE(assignment_table_marshalling_test, test_tools::random_te test_assignment_table(desc.usable_rows_amount, assignments, "circuit7"); else test_assignment_table(desc.usable_rows_amount, assignments); - + test_assignment_table_description>(desc); } BOOST_AUTO_TEST_SUITE_END() diff --git a/crypto3/libs/marshalling/zk/test/plonk_constraint_system.cpp b/crypto3/libs/marshalling/zk/test/plonk_constraint_system.cpp index 3d36ceadc1..30a4a26d4d 100644 --- a/crypto3/libs/marshalling/zk/test/plonk_constraint_system.cpp +++ b/crypto3/libs/marshalling/zk/test/plonk_constraint_system.cpp @@ -32,7 +32,7 @@ #include #include #include -#include +#include #include #include diff --git a/crypto3/libs/marshalling/zk/test/polys_evaluator.cpp b/crypto3/libs/marshalling/zk/test/polys_evaluator.cpp index 52d61f795e..5c5c0727d1 100644 --- a/crypto3/libs/marshalling/zk/test/polys_evaluator.cpp +++ b/crypto3/libs/marshalling/zk/test/polys_evaluator.cpp @@ -111,7 +111,7 @@ BOOST_AUTO_TEST_SUITE(marshalling_real) using transcript_hash_type = nil::crypto3::hashes::keccak_1600<256>; using merkle_tree_type = typename containers::merkle_tree; -BOOST_FIXTURE_TEST_CASE(batches_num_3_test, zk::test_tools::random_test_initializer){ +BOOST_FIXTURE_TEST_CASE(batches_num_3_test, test_tools::random_test_initializer){ // Setup types. constexpr static const std::size_t lambda = 40; constexpr static const std::size_t k = 1; diff --git a/crypto3/libs/marshalling/zk/test/random_test_data_generation.hpp b/crypto3/libs/marshalling/zk/test/random_test_data_generation.hpp index 5301742098..76ae35998d 100644 --- a/crypto3/libs/marshalling/zk/test/random_test_data_generation.hpp +++ b/crypto3/libs/marshalling/zk/test/random_test_data_generation.hpp @@ -67,7 +67,7 @@ #include #include -#include +#include using namespace nil::crypto3; diff --git a/crypto3/libs/zk/test/CMakeLists.txt b/crypto3/libs/zk/test/CMakeLists.txt index 4173028d7f..2b9469a6b3 100644 --- a/crypto3/libs/zk/test/CMakeLists.txt +++ b/crypto3/libs/zk/test/CMakeLists.txt @@ -9,6 +9,7 @@ include(CMTest) target_include_directories(${CMAKE_WORKSPACE_NAME}_${CURRENT_PROJECT_NAME} INTERFACE + "$" "$" "$") diff --git a/crypto3/libs/zk/test/include/nil/crypto3/zk/test_tools/random_test_initializer.hpp b/crypto3/libs/zk/test/include/nil/crypto3/zk/test_tools/random_test_initializer.hpp deleted file mode 100644 index 2740db924c..0000000000 --- a/crypto3/libs/zk/test/include/nil/crypto3/zk/test_tools/random_test_initializer.hpp +++ /dev/null @@ -1,98 +0,0 @@ -//---------------------------------------------------------------------------// -// Copyright (c) 2022 Mikhail Komarov -// Copyright (c) 2022 Nikita Kaskov -// Copyright (c) 2022 Ilia Shirobokov -// Copyright (c) 2022 Alisa Cherniaeva -// Copyright (c) 2023 Elena Tatuzova -// -// MIT License -// -// Permission is hereby granted, free of charge, to any person obtaining a copy -// of this software and associated documentation files (the "Software"), to deal -// in the Software without restriction, including without limitation the rights -// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -// copies of the Software, and to permit persons to whom the Software is -// furnished to do so, subject to the following conditions: -// -// The above copyright notice and this permission notice shall be included in all -// copies or substantial portions of the Software. -// -// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -// SOFTWARE. -//---------------------------------------------------------------------------// - -#ifndef CRYPTO3_ZK_TEST_TOOLS_RANDOM_TEST_INITIALIZER_HPP -#define CRYPTO3_ZK_TEST_TOOLS_RANDOM_TEST_INITIALIZER_HPP - -#include -#include - -#include -#include -#include - - -namespace nil { - namespace crypto3 { - namespace zk { - namespace test_tools { - - // ******************************************************************************* - // * Randomness setup - // *******************************************************************************/ - // Template structure to include algebraic random engines for multiple field types - template - struct random_engine_container { - std::size_t seed; - std::tuple...> alg_rnd_engines; - - explicit random_engine_container(std::size_t init_seed = 0) - : alg_rnd_engines(nil::crypto3::random::algebraic_engine(init_seed)...) { - } - - // Template method to access a specific engine by type - template - nil::crypto3::random::algebraic_engine& get_alg_engine() { - return std::get>(alg_rnd_engines); - } - }; - - template - struct random_test_initializer { - random_test_initializer() { - for (std::size_t i = 0; i < std::size_t(boost::unit_test::framework::master_test_suite().argc - 1); i++) { - if (std::string(boost::unit_test::framework::master_test_suite().argv[i]) == "--seed") { - if (std::string(boost::unit_test::framework::master_test_suite().argv[i + 1]) == "random") { - std::random_device rd; - seed = rd(); - break; - } - if (std::regex_match(boost::unit_test::framework::master_test_suite().argv[i + 1], - std::regex(("((\\+|-)?[[:digit:]]+)(\\.(([[:digit:]]+)?))?")))) { - seed = atoi(boost::unit_test::framework::master_test_suite().argv[i + 1]); - break; - } - } - } - - BOOST_TEST_MESSAGE("seed = " << seed); - alg_random_engines = random_engine_container(seed); - generic_random_engine = boost::random::mt11213b(seed); - } - - std::size_t seed = 0; - random_engine_container alg_random_engines; - boost::random::mt11213b generic_random_engine; - }; - - } // namespace test_tools - } // namespace zk - } // namespace crypto3 -} // namespace nil - -#endif // CRYPTO3_ZK_TEST_TOOLS_RANDOM_TEST_INITIALIZER_HPP diff --git a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_circuits.cpp b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_circuits.cpp index fa36662651..0e0c02f817 100644 --- a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_circuits.cpp +++ b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_circuits.cpp @@ -38,7 +38,7 @@ #include #include -#include +#include #include "circuits.hpp" #include "placeholder_test_runner.hpp" diff --git a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_curves.cpp b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_curves.cpp index 494bd5e871..f4c358a131 100644 --- a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_curves.cpp +++ b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_curves.cpp @@ -53,7 +53,7 @@ #include #include -#include +#include #include "circuits.hpp" #include "placeholder_test_runner.hpp" diff --git a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_goldilocks.cpp b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_goldilocks.cpp index 5aba05528c..32d3d2e45e 100644 --- a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_goldilocks.cpp +++ b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_goldilocks.cpp @@ -39,7 +39,7 @@ #include #include -#include +#include #include "circuits.hpp" #include "placeholder_test_runner.hpp" diff --git a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_hashes.cpp b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_hashes.cpp index 45d17d2d3f..09aa37808b 100644 --- a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_hashes.cpp +++ b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_hashes.cpp @@ -44,7 +44,7 @@ #include #include -#include +#include #include "circuits.hpp" #include "placeholder_test_runner.hpp" diff --git a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_kzg.cpp b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_kzg.cpp index 66ef6c6f73..acfb535c6d 100644 --- a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_kzg.cpp +++ b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_kzg.cpp @@ -62,7 +62,7 @@ #include #include #include -#include +#include #include "circuits.hpp" #include "placeholder_test_runner.hpp" diff --git a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_lookup_argument.cpp b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_lookup_argument.cpp index dcf7e2427f..6a37bbe055 100644 --- a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_lookup_argument.cpp +++ b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_lookup_argument.cpp @@ -62,7 +62,7 @@ #include #include -#include +#include #include "circuits.hpp" diff --git a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_permutation_argument.cpp b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_permutation_argument.cpp index 7a5afba270..ea5133e9c6 100644 --- a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_permutation_argument.cpp +++ b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_permutation_argument.cpp @@ -61,7 +61,7 @@ #include #include #include -#include +#include #include "circuits.hpp" diff --git a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_quotient_polynomial_chunks.cpp b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_quotient_polynomial_chunks.cpp index 2e7b5354a2..aeb5db7ffc 100644 --- a/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_quotient_polynomial_chunks.cpp +++ b/crypto3/libs/zk/test/systems/plonk/placeholder/placeholder_quotient_polynomial_chunks.cpp @@ -39,7 +39,7 @@ #include #include -#include +#include #include "circuits.hpp" #include "placeholder_test_runner.hpp" diff --git a/crypto3/test_tools/include/nil/crypto3/test_tools/random_test_initializer.hpp b/crypto3/test_tools/include/nil/crypto3/test_tools/random_test_initializer.hpp new file mode 100644 index 0000000000..64b42c7ab5 --- /dev/null +++ b/crypto3/test_tools/include/nil/crypto3/test_tools/random_test_initializer.hpp @@ -0,0 +1,96 @@ +//---------------------------------------------------------------------------// +// Copyright (c) 2022 Mikhail Komarov +// Copyright (c) 2022 Nikita Kaskov +// Copyright (c) 2022 Ilia Shirobokov +// Copyright (c) 2022 Alisa Cherniaeva +// Copyright (c) 2023 Elena Tatuzova +// +// MIT License +// +// Permission is hereby granted, free of charge, to any person obtaining a copy +// of this software and associated documentation files (the "Software"), to deal +// in the Software without restriction, including without limitation the rights +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +// copies of the Software, and to permit persons to whom the Software is +// furnished to do so, subject to the following conditions: +// +// The above copyright notice and this permission notice shall be included in all +// copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +// SOFTWARE. +//---------------------------------------------------------------------------// + +#ifndef CRYPTO3_ZK_TEST_TOOLS_RANDOM_TEST_INITIALIZER_HPP +#define CRYPTO3_ZK_TEST_TOOLS_RANDOM_TEST_INITIALIZER_HPP + +#include +#include + +#include +#include +#include + + +namespace nil { + namespace crypto3 { + namespace test_tools { + + // ******************************************************************************* + // * Randomness setup + // *******************************************************************************/ + // Template structure to include algebraic random engines for multiple field types + template + struct random_engine_container { + std::size_t seed; + std::tuple...> alg_rnd_engines; + + explicit random_engine_container(std::size_t init_seed = 0) + : alg_rnd_engines(nil::crypto3::random::algebraic_engine(init_seed)...) { + } + + // Template method to access a specific engine by type + template + nil::crypto3::random::algebraic_engine& get_alg_engine() { + return std::get>(alg_rnd_engines); + } + }; + + template + struct random_test_initializer { + random_test_initializer() { + for (std::size_t i = 0; i < std::size_t(boost::unit_test::framework::master_test_suite().argc - 1); i++) { + if (std::string(boost::unit_test::framework::master_test_suite().argv[i]) == "--seed") { + if (std::string(boost::unit_test::framework::master_test_suite().argv[i + 1]) == "random") { + std::random_device rd; + seed = rd(); + break; + } + if (std::regex_match(boost::unit_test::framework::master_test_suite().argv[i + 1], + std::regex(("((\\+|-)?[[:digit:]]+)(\\.(([[:digit:]]+)?))?")))) { + seed = atoi(boost::unit_test::framework::master_test_suite().argv[i + 1]); + break; + } + } + } + + BOOST_TEST_MESSAGE("seed = " << seed); + alg_random_engines = random_engine_container(seed); + generic_random_engine = boost::random::mt11213b(seed); + } + + std::size_t seed = 0; + random_engine_container alg_random_engines; + boost::random::mt11213b generic_random_engine; + }; + + } // namespace test_tools + } // namespace crypto3 +} // namespace nil + +#endif // CRYPTO3_ZK_TEST_TOOLS_RANDOM_TEST_INITIALIZER_HPP