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
16
17namespace bb::avm2::simulation {
18namespace {
19
20using ::testing::Return;
21using ::testing::ReturnRef;
22using ::testing::StrictMock;
23
24using simulation::MockExecutionIdManager;
25
26TEST(Sha256CompressionSimulationTest, Sha256Compression)
27{
28 MemoryStore mem;
29 StrictMock<MockExecutionIdManager> execution_id_manager;
30 EXPECT_CALL(execution_id_manager, get_execution_id()).WillRepeatedly(Return(1));
31 PureGreaterThan gt;
32 PureBitwise bitwise;
33
34 EventEmitter<Sha256CompressionEvent> sha256_event_emitter;
35 Sha256 sha256(execution_id_manager, bitwise, gt, sha256_event_emitter);
36
37 // TODO: actually can choose to mock, not even use a memory, check the events, etc.
38 std::array<uint32_t, 8> state = { 0, 1, 2, 3, 4, 5, 6, 7 };
39 MemoryAddress state_addr = 0;
40 for (uint32_t i = 0; i < 8; ++i) {
41 mem.set(state_addr + i, MemoryValue::from<uint32_t>(state[i]));
42 }
43
44 std::array<uint32_t, 16> input = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 };
45 MemoryAddress input_addr = 8;
46 for (uint32_t i = 0; i < 16; ++i) {
47 mem.set(input_addr + i, MemoryValue::from<uint32_t>(input[i]));
48 }
50
51 sha256.compression(mem, state_addr, input_addr, dst_addr);
52
53 auto result = sha256_block(state, input);
54
55 std::array<uint32_t, 8> result_from_memory;
56 for (uint32_t i = 0; i < 8; ++i) {
57 auto c = mem.get(dst_addr + i);
58 result_from_memory[i] = c.as<uint32_t>();
59 }
60 EXPECT_EQ(result_from_memory, result);
61}
62
63} // namespace
64} // namespace bb::avm2::simulation
void set(MemoryAddress index, MemoryValue value) override
const MemoryValue & get(MemoryAddress index) const override
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