3#include <gmock/gmock.h>
4#include <gtest/gtest.h>
19using ::testing::Return;
20using ::testing::ReturnRef;
21using ::testing::StrictMock;
23using simulation::MockExecutionIdManager;
25TEST(Sha256CompressionSimulationTest, Sha256Compression)
33 EventEmitter<Sha256CompressionEvent> sha256_event_emitter;
37 std::array<uint32_t, 8> state = { 0, 1, 2, 3, 4, 5, 6, 7 };
39 for (uint32_t i = 0; i < 8; ++i) {
40 mem.
set(state_addr + i, MemoryValue::from<uint32_t>(state[i]));
43 std::array<uint32_t, 16> input = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 };
45 for (uint32_t i = 0; i < 16; ++i) {
46 mem.
set(input_addr + i, MemoryValue::from<uint32_t>(input[i]));
54 std::array<uint32_t, 8> result_from_memory;
55 for (uint32_t i = 0; i < 8; ++i) {
57 result_from_memory[i] = c.
as<uint32_t>();
59 EXPECT_EQ(result_from_memory, result);
void set(MemoryAddress index, MemoryValue value) override
const MemoryValue & get(MemoryAddress index) const override
ExecutionIdManager execution_id_manager
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)
Sha256Hash sha256(const ByteContainer &input)
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept