Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
crs_factory.test.cpp
Go to the documentation of this file.
11#include <fstream>
12#include <gtest/gtest.h>
13#include <utility>
14
15using namespace bb;
16using namespace bb::srs::factories;
17using namespace bb::curve;
18namespace fs = std::filesystem;
19
20namespace {
21// BN254 consistency checker
22void check_bn254_consistency(const fs::path& crs_download_path, size_t num_points, bool allow_download)
23{
24 NativeBn254CrsFactory file_crs(crs_download_path, allow_download);
25
26 // read G1
27 std::vector<g1::affine_element> g1_points(num_points);
28 auto g1_buf = read_file(bb::srs::bb_crs_path() / "bn254_g1.dat", num_points * sizeof(g1::affine_element));
29 for (size_t i = 0; i < num_points; ++i) {
30 g1_points[i] = from_buffer<g1::affine_element>(g1_buf, i * sizeof(g1::affine_element));
31 }
32
33 // read G2
34 auto g2_buf = read_file(bb::srs::bb_crs_path() / "bn254_g2.dat", sizeof(g2::affine_element));
35 auto g2_point = from_buffer<g2::affine_element>(g2_buf);
36
37 // build in-memory CRS
38 MemBn254CrsFactory mem_crs(g1_points, g2_point);
39
40 // prover CRS
41 auto f_prover = file_crs.get_crs(num_points);
42 auto m_prover = mem_crs.get_crs(num_points);
43 EXPECT_EQ(m_prover->get_monomial_size(), f_prover->get_monomial_size());
44 for (size_t i = 0; i < num_points; ++i) {
45 EXPECT_EQ(std::make_pair(i, m_prover->get_monomial_points()[i]),
46 std::make_pair(i, f_prover->get_monomial_points()[i]));
47 }
48 // verifier CRS
49 auto f_ver = file_crs.get_verifier_crs();
50 auto m_ver = mem_crs.get_verifier_crs();
51 EXPECT_EQ(m_ver->get_g2x(), f_ver->get_g2x());
52 EXPECT_EQ(0,
53 memcmp(m_ver->get_precomputed_g2_lines(),
54 f_ver->get_precomputed_g2_lines(),
55 sizeof(pairing::miller_lines) * 2));
56}
57
58// Grumpkin consistency checker
59void check_grumpkin_consistency(const fs::path& crs_download_path, size_t num_points, bool allow_download)
60{
61 NativeGrumpkinCrsFactory file_crs(crs_download_path, allow_download);
62
63 // read G1
64 std::vector<Grumpkin::AffineElement> points(num_points);
65 auto data =
66 read_file(bb::srs::bb_crs_path() / "grumpkin_g1.flat.dat", num_points * sizeof(Grumpkin::AffineElement));
67
68 for (size_t i = 0; i < num_points; ++i) {
69 points[i] = from_buffer<Grumpkin::AffineElement>(data, i * sizeof(g1::affine_element));
70 }
71 MemGrumpkinCrsFactory mem_crs(points);
72
73 // prover CRS
74 auto f_prover = file_crs.get_crs(num_points);
75 auto m_prover = mem_crs.get_crs(num_points);
76 EXPECT_EQ(m_prover->get_monomial_size(), f_prover->get_monomial_size());
77 for (size_t i = 0; i < num_points; ++i) {
78 EXPECT_EQ(std::make_pair(i, m_prover->get_monomial_points()[i]),
79 std::make_pair(i, f_prover->get_monomial_points()[i]));
80 }
81}
82} // namespace
83
85{
86 check_bn254_consistency(bb::srs::bb_crs_path(), 1024, /*allow_download=*/false);
87 const std::filesystem::path& temp_crs_path = "barretenberg_srs_test_crs_bn254";
88 fs::remove_all(temp_crs_path);
89 fs::create_directories(temp_crs_path);
90 // Tiny download check to test the 'net CRS' path
91 ASSERT_ANY_THROW(check_bn254_consistency(temp_crs_path, 1, /*allow_download=*/false));
92 check_bn254_consistency(temp_crs_path, 1, /*allow_download=*/true);
93}
94
95TEST(CrsFactory, grumpkin)
96{
97 check_grumpkin_consistency(bb::srs::bb_crs_path(), 1024, /*allow_download=*/false);
98 const std::filesystem::path& temp_crs_path = "barretenberg_srs_test_crs_grumpkin";
99 fs::remove_all(temp_crs_path);
100 fs::create_directories(temp_crs_path);
101 // Tiny download check to test the 'net CRS' path
102 ASSERT_ANY_THROW(check_grumpkin_consistency(temp_crs_path, 1, /*allow_download=*/false));
103 check_grumpkin_consistency(temp_crs_path, 1, /*allow_download=*/true);
104}
105
106TEST(CrsFactory, Bn254Fallback)
107{
108 // Test that fallback works when primary URL fails
109 const std::filesystem::path& temp_crs_path = "barretenberg_srs_test_crs_bn254_fallback";
110 fs::remove_all(temp_crs_path);
111 fs::create_directories(temp_crs_path);
112
113 // Use a bad primary URL that will fail, forcing fallback to the real S3 URL
114 std::string bad_primary = "http://nonexistent.invalid/g1.dat";
115 std::string good_fallback = "http://crs.aztec-labs.com/g1.dat";
116
117 // This should succeed by falling back to the working URL
118 auto points = bb::get_bn254_g1_data(temp_crs_path, 1, /*allow_download=*/true, bad_primary, good_fallback);
119 EXPECT_EQ(points.size(), 1);
120 // Verify the downloaded point matches the expected first element
121 EXPECT_EQ(points[0], bb::srs::BN254_G1_FIRST_ELEMENT);
122
123 fs::remove_all(temp_crs_path);
124}
typename Group::affine_element AffineElement
Definition grumpkin.hpp:63
const std::vector< MemoryValue > data
const size_t num_points
std::filesystem::path bb_crs_path()
constexpr g1::affine_element BN254_G1_FIRST_ELEMENT
Expected first G1 element from BN254 CRS.
Entry point for Barretenberg command-line interface.
Definition api.hpp:5
std::vector< g1::affine_element > get_bn254_g1_data(const std::filesystem::path &path, size_t num_points, bool allow_download, const std::string &primary_url, const std::string &fallback_url)
std::vector< uint8_t > read_file(const std::string &filename, size_t bytes=0)
Definition file_io.hpp:30
TEST(BoomerangMegaCircuitBuilder, BasicCircuit)
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Definition tuple.hpp:13