3#include <gmock/gmock.h>
4#include <gtest/gtest.h>
6#include "absl/status/status.h"
7#include "absl/status/statusor.h"
15using ::testing::Return;
17const static std::vector<uint8_t> kMockRomData = {
18 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A,
19 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15,
20 0x16, 0x17, 0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F,
29 EXPECT_EQ(rom_.size(), 0);
30 EXPECT_EQ(rom_.data(),
nullptr);
37 EXPECT_OK(rom_.LoadFromFile(
"zelda3.sfc"));
38 EXPECT_EQ(rom_.size(), 0x200000);
39 EXPECT_NE(rom_.data(),
nullptr);
43 EXPECT_THAT(rom_.LoadFromFile(
"invalid.sfc"),
44 StatusIs(absl::StatusCode::kNotFound));
45 EXPECT_EQ(rom_.size(), 0);
46 EXPECT_EQ(rom_.data(),
nullptr);
50 EXPECT_THAT(rom_.LoadFromFile(
""),
51 StatusIs(absl::StatusCode::kInvalidArgument));
55 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
57 for (
size_t i = 0; i < kMockRomData.size(); ++i) {
60 EXPECT_EQ(
byte, kMockRomData[i]);
65 EXPECT_THAT(rom_.ReadByte(0).status(),
66 StatusIs(absl::StatusCode::kFailedPrecondition));
70 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
72 for (
size_t i = 0; i < kMockRomData.size(); i += 2) {
81 EXPECT_THAT(rom_.ReadWord(0).status(),
82 StatusIs(absl::StatusCode::kFailedPrecondition));
86 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
88 for (
size_t i = 0; i < kMockRomData.size(); i += 4) {
90 EXPECT_THAT(rom_.ReadLong(i),
92 kMockRomData[i + 1] << 8 |
93 kMockRomData[i + 2] << 16));
98 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
100 std::vector<uint8_t> bytes;
102 EXPECT_THAT(bytes, ::testing::ContainerEq(kMockRomData));
106 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
108 std::vector<uint8_t> bytes;
109 EXPECT_THAT(rom_.ReadByteVector(kMockRomData.size() + 1, 1).status(),
110 StatusIs(absl::StatusCode::kOutOfRange));
114 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
116 for (
size_t i = 0; i < kMockRomData.size(); ++i) {
120 EXPECT_EQ(
byte, 0xFF);
125 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
127 for (
size_t i = 0; i < kMockRomData.size(); i += 2) {
131 EXPECT_EQ(word, 0xFFFF);
136 EXPECT_OK(rom_.LoadFromData(kMockRomData,
false));
138 for (
size_t i = 0; i < kMockRomData.size(); i += 4) {
142 EXPECT_EQ(word, 0xFFFFFF);
150 EXPECT_CALL(mock_rom, WriteHelper(_))
151 .WillRepeatedly(Return(absl::OkStatus()));
163 EXPECT_CALL(mock_rom, WriteHelper(_))
164 .WillOnce(Return(absl::OkStatus()))
165 .WillOnce(Return(absl::InternalError(
"Write failed")));
170 absl::InternalError(
"Write failed"));
181 EXPECT_EQ(byte_val, 0x00);
182 EXPECT_EQ(word_val, 0x0201);
191 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::Status WriteTransaction(Args... args)
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)