Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
sha256.test.cpp
Go to the documentation of this file.
2
3#include <gmock/gmock.h>
4#include <gtest/gtest.h>
5
15
16namespace bb::avm2::simulation {
17namespace {
18
19using ::testing::Return;
20using ::testing::ReturnRef;
21using ::testing::StrictMock;
22
23using simulation::MockExecutionIdManager;
24
25TEST(Sha256CompressionSimulationTest, Sha256Compression)
26{
27 MemoryStore mem;
28 StrictMock<MockExecutionIdManager> execution_id_manager;
29 EXPECT_CALL(execution_id_manager, get_execution_id()).WillRepeatedly(Return(1));
30 FakeGreaterThan gt;
31 FakeBitwise bitwise;
32
33 EventEmitter<Sha256CompressionEvent> sha256_event_emitter;
34 Sha256 sha256(execution_id_manager, bitwise, gt, sha256_event_emitter);
35
36 // TODO: actually can choose to mock, not even use a memory, check the events, etc.
37 std::array<uint32_t, 8> state = { 0, 1, 2, 3, 4, 5, 6, 7 };
38 MemoryAddress state_addr = 0;
39 for (uint32_t i = 0; i < 8; ++i) {
40 mem.set(state_addr + i, MemoryValue::from<uint32_t>(state[i]));
41 }
42
43 std::array<uint32_t, 16> input = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 };
44 MemoryAddress input_addr = 8;
45 for (uint32_t i = 0; i < 16; ++i) {
46 mem.set(input_addr + i, MemoryValue::from<uint32_t>(input[i]));
47 }
49
50 sha256.compression(mem, state_addr, input_addr, dst_addr);
51
52 auto result = sha256_block(state, input);
53
54 std::array<uint32_t, 8> result_from_memory;
55 for (uint32_t i = 0; i < 8; ++i) {
56 auto c = mem.get(dst_addr + i);
57 result_from_memory[i] = c.as<uint32_t>();
58 }
59 EXPECT_EQ(result_from_memory, result);
60}
61
62} // namespace
63} // namespace bb::avm2::simulation
void set(MemoryAddress index, MemoryValue value) override
Definition memory.hpp:98
const MemoryValue & get(MemoryAddress index) const override
Definition memory.hpp:92
ExecutionIdManager execution_id_manager
MemoryStore mem
uint32_t dst_addr
GreaterThan gt
TEST(EmitUnencryptedLogTest, Basic)
std::array< uint32_t, 8 > sha256_block(const std::array< uint32_t, 8 > &h_init, const std::array< uint32_t, 16 > &input)
uint32_t MemoryAddress
Sha256Hash sha256(const ByteContainer &input)
Definition sha256.cpp:142
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Definition tuple.hpp:13
Bitwise bitwise