3#include <gtest/gtest.h>
19using FlavorTypes = ::testing::Types<MegaFlavor, MegaZKFlavor>;
21template <
typename Flavor>
class DataBusTests :
public ::testing::Test {
37 Prover prover{ prover_instance, verification_key };
38 auto proof = prover.construct_proof();
39 Verifier verifier{ verification_key };
40 bool result = verifier.template verify_proof<DefaultIO>(proof).result;
45 static Builder construct_test_builder()
63 static Builder construct_circuit_with_databus_reads(
65 const std::function<
void(
Builder&, uint32_t)>& add_bus_data,
66 const std::function<uint32_t(
Builder&, uint32_t)>& read_bus_data)
69 const uint32_t NUM_BUS_ENTRIES = 5;
70 const uint32_t NUM_READS = 7;
73 for (
size_t i = 0; i < NUM_BUS_ENTRIES; ++i) {
75 uint32_t val_witness_idx =
builder.add_variable(val);
76 add_bus_data(
builder, val_witness_idx);
80 for (
size_t i = 0; i < NUM_READS; ++i) {
82 uint32_t read_idx_witness_idx =
builder.add_variable(
FF(read_idx));
83 read_bus_data(
builder, read_idx_witness_idx);
92 auto add_method = [](
Builder&
builder, uint32_t witness_idx) {
builder.add_public_calldata(witness_idx); };
93 auto read_method = [](
Builder&
builder, uint32_t witness_idx) {
return builder.read_calldata(witness_idx); };
95 return construct_circuit_with_databus_reads(
builder, add_method, read_method);
102 builder.add_public_secondary_calldata(witness_idx);
105 return builder.read_secondary_calldata(witness_idx);
108 return construct_circuit_with_databus_reads(
builder, add_method, read_method);
114 auto add_method = [](
Builder&
builder, uint32_t witness_idx) {
builder.add_public_return_data(witness_idx); };
115 auto read_method = [](
Builder&
builder, uint32_t witness_idx) {
return builder.read_return_data(witness_idx); };
117 return construct_circuit_with_databus_reads(
builder, add_method, read_method);
129 typename TypeParam::CircuitBuilder
builder = this->construct_test_builder();
130 this->construct_circuit_with_calldata_reads(
builder);
132 EXPECT_TRUE(this->construct_and_verify_proof(
builder));
141 typename TypeParam::CircuitBuilder
builder = this->construct_test_builder();
142 this->construct_circuit_with_secondary_calldata_reads(
builder);
144 EXPECT_TRUE(this->construct_and_verify_proof(
builder));
153 typename TypeParam::CircuitBuilder
builder = this->construct_test_builder();
154 this->construct_circuit_with_return_data_reads(
builder);
156 EXPECT_TRUE(this->construct_and_verify_proof(
builder));
165 typename TypeParam::CircuitBuilder
builder = this->construct_test_builder();
166 this->construct_circuit_with_calldata_reads(
builder);
167 this->construct_circuit_with_secondary_calldata_reads(
builder);
168 this->construct_circuit_with_return_data_reads(
builder);
170 EXPECT_TRUE(this->construct_and_verify_proof(
builder));
178TYPED_TEST(DataBusTests, CallDataDuplicateRead)
181 typename TypeParam::CircuitBuilder
builder = this->construct_test_builder();
182 using FF = TypeParam::FF;
186 std::vector<FF> calldata_values = { 7, 10, 3, 12, 1 };
187 for (
auto& val : calldata_values) {
192 std::vector<uint32_t> read_indices = { 1, 4, 1 };
195 std::vector<uint32_t> result_witness_indices;
196 for (uint32_t& read_idx : read_indices) {
198 uint32_t read_idx_witness_idx =
builder.add_variable(
FF(read_idx));
200 auto value_witness_idx =
builder.read_calldata(read_idx_witness_idx);
201 result_witness_indices.emplace_back(value_witness_idx);
205 auto expected_read_result_at_1 = calldata_values[1];
206 auto expected_read_result_at_4 = calldata_values[4];
207 auto duplicate_read_result_0 =
builder.get_variable(result_witness_indices[0]);
208 auto duplicate_read_result_1 =
builder.get_variable(result_witness_indices[1]);
209 auto duplicate_read_result_2 =
builder.get_variable(result_witness_indices[2]);
210 EXPECT_EQ(duplicate_read_result_0, expected_read_result_at_1);
211 EXPECT_EQ(duplicate_read_result_1, expected_read_result_at_4);
212 EXPECT_EQ(duplicate_read_result_2, expected_read_result_at_1);
215 bool result = this->construct_and_verify_proof(
builder);
ECCVMCircuitBuilder CircuitBuilder
static void construct_simple_circuit(MegaBuilder &builder)
Generate a simple test circuit with some ECC op gates and conventional arithmetic gates.
static bool check(const Builder &circuit)
Check the witness satisifies the circuit.
virtual uint32_t get_random_uint32()=0
RNG & get_debug_randomness(bool reset, std::uint_fast64_t seed)
std::filesystem::path bb_crs_path()
void init_file_crs_factory(const std::filesystem::path &path)
Entry point for Barretenberg command-line interface.
TYPED_TEST_SUITE(ShpleminiTest, TestSettings)
TYPED_TEST(ShpleminiTest, CorrectnessOfMultivariateClaimBatching)
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
static field random_element(numeric::RNG *engine=nullptr) noexcept