3#include <gmock/gmock.h>
4#include <gtest/gtest.h>
6#include "absl/status/status.h"
7#include "absl/status/statusor.h"
14using ::testing::Return;
16const static std::vector<uint8_t> kMockRomData = {
17 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A,
18 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15,
19 0x16, 0x17, 0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F,
41 EXPECT_EQ(rom_.size(), 0);
42 EXPECT_EQ(rom_.data(),
nullptr);
49 EXPECT_OK(rom_.LoadFromFile(
"zelda3.sfc"));
50 EXPECT_EQ(rom_.size(), 0x200000);
51 EXPECT_NE(rom_.data(),
nullptr);
55 EXPECT_THAT(rom_.LoadFromFile(
"invalid.sfc"),
56 StatusIs(absl::StatusCode::kNotFound));
57 EXPECT_EQ(rom_.size(), 0);
58 EXPECT_EQ(rom_.data(),
nullptr);
62 EXPECT_THAT(rom_.LoadFromFile(
""),
63 StatusIs(absl::StatusCode::kInvalidArgument));
67 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
69 for (
size_t i = 0; i < kMockRomData.size(); ++i) {
72 EXPECT_EQ(
byte, kMockRomData[i]);
77 EXPECT_THAT(rom_.ReadByte(0).status(),
78 StatusIs(absl::StatusCode::kFailedPrecondition));
82 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
84 for (
size_t i = 0; i < kMockRomData.size(); i += 2) {
93 EXPECT_THAT(rom_.ReadWord(0).status(),
94 StatusIs(absl::StatusCode::kFailedPrecondition));
98 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
100 for (
size_t i = 0; i < kMockRomData.size(); i += 4) {
102 EXPECT_THAT(rom_.ReadLong(i),
104 kMockRomData[i + 1] << 8 |
105 kMockRomData[i + 2] << 16));
110 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
112 std::vector<uint8_t> bytes;
114 EXPECT_THAT(bytes, ::testing::ContainerEq(kMockRomData));
118 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
120 std::vector<uint8_t> bytes;
121 EXPECT_THAT(rom_.ReadByteVector(kMockRomData.size() + 1, 1).status(),
122 StatusIs(absl::StatusCode::kOutOfRange));
126 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
128 for (
size_t i = 0; i < kMockRomData.size(); ++i) {
132 EXPECT_EQ(
byte, 0xFF);
137 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
139 for (
size_t i = 0; i < kMockRomData.size(); i += 2) {
143 EXPECT_EQ(word, 0xFFFF);
148 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
150 for (
size_t i = 0; i < kMockRomData.size(); i += 4) {
154 EXPECT_EQ(word, 0xFFFFFF);
162 EXPECT_CALL(mock_rom, WriteHelper(_))
163 .WillRepeatedly(Return(absl::OkStatus()));
175 EXPECT_CALL(mock_rom, WriteHelper(_))
176 .WillOnce(Return(absl::OkStatus()))
177 .WillOnce(Return(absl::InternalError(
"Write failed")));
182 absl::InternalError(
"Write failed"));
193 EXPECT_EQ(byte_val, 0x00);
194 EXPECT_EQ(word_val, 0x0201);
203 absl::FailedPreconditionError(
"Offset out of range"));
The Rom class is used to load, save, and modify Rom data.
absl::Status ReadTransaction(T &var, int address, Args &&... args)
absl::Status LoadFromData(const std::vector< uint8_t > &data, bool z3_load=true)
absl::StatusOr< uint16_t > ReadWord(int offset)
absl::Status WriteTransaction(Args... args)
virtual absl::Status WriteHelper(const WriteAction &action)
absl::StatusOr< uint32_t > ReadLong(int offset)
absl::Status ReadHelper(T &var, int address)
absl::StatusOr< uint8_t > ReadByte(int offset)
MOCK_METHOD2(ReadHelper, absl::Status(uint8_t &, int))
MOCK_METHOD(absl::StatusOr< uint16_t >, ReadWord,(int))
MOCK_METHOD(absl::StatusOr< uint8_t >, ReadByte,(int))
MOCK_METHOD2(ReadHelper, absl::Status(std::vector< uint8_t > &, int))
MOCK_METHOD(absl::Status, WriteHelper,(const WriteAction &),(override))
MOCK_METHOD2(ReadHelper, absl::Status(uint16_t &, int))
MOCK_METHOD(absl::StatusOr< uint32_t >, ReadLong,(int))
TEST_F(CpuTest, AsmParserTokenizerOk)
::testing::AssertionResult IsOkAndHolds(const absl::StatusOr< T > &status_or, const T &value)
Main namespace for the application.
#define ASSERT_OK_AND_ASSIGN(lhs, rexpr)