mirror of
https://github.com/MoleskiCoder/EightBit.git
synced 2024-09-24 13:57:32 +00:00
d59c72cf00
Signed-off-by: Adrian Conlon <adrian.conlon@gmail.com>
79 lines
2.6 KiB
C++
79 lines
2.6 KiB
C++
#include "stdafx.h"
|
|
|
|
#include <chrono>
|
|
#include <iostream>
|
|
#include <filesystem>
|
|
|
|
#include "TestRunner.h"
|
|
#include "test_t.h"
|
|
#include "opcode_test_suite_t.h"
|
|
|
|
int main() {
|
|
|
|
std::filesystem::path location = "C:\\github\\spectrum\\libraries\\EightBit\\modules\\ProcessorTests\\6502\\v1";
|
|
|
|
const auto start_time = std::chrono::steady_clock::now();
|
|
|
|
int undocumented_opcode_count = 0;
|
|
int unimplemented_opcode_count = 0;
|
|
int invalid_opcode_count = 0;
|
|
|
|
for (const auto& entry : std::filesystem::directory_iterator{ location }) {
|
|
|
|
const auto path = entry.path();
|
|
|
|
std::cout << "Processing: " << path.filename() << "\n";
|
|
opcode_test_suite_t opcode(path.string());
|
|
opcode.load();
|
|
opcode.parse();
|
|
|
|
const auto opcode_test_array = opcode.raw().get_array();
|
|
|
|
bool opcode_undocumented = false;
|
|
bool opcode_unimplemented = false;
|
|
bool opcode_invalid = false;
|
|
|
|
for (const auto& opcode_test_element : opcode_test_array) {
|
|
|
|
const auto opcode_test = test_t(opcode_test_element);
|
|
|
|
TestRunner runner(opcode_test);
|
|
runner.check();
|
|
|
|
auto undocumented = runner.undocumented();
|
|
auto unimplemented = runner.unimplemented();
|
|
auto implemented = runner.implemented();
|
|
auto invalid = runner.invalid();
|
|
|
|
if (invalid) {
|
|
opcode_invalid = true;
|
|
if (unimplemented)
|
|
opcode_unimplemented = true;
|
|
if (undocumented)
|
|
opcode_undocumented = true;
|
|
std::cout << "** Failed: " << opcode_test.name() << "\n";
|
|
for (const auto& message : runner.messages())
|
|
std::cout << "**** " << message << "\n";
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (opcode_undocumented)
|
|
++undocumented_opcode_count;
|
|
if (opcode_unimplemented)
|
|
++unimplemented_opcode_count;
|
|
if (opcode_invalid)
|
|
++invalid_opcode_count;
|
|
}
|
|
|
|
const auto finish_time = std::chrono::steady_clock::now();
|
|
const auto elapsed_time = finish_time - start_time;
|
|
const auto seconds = std::chrono::duration_cast<std::chrono::duration<double>>(elapsed_time).count();
|
|
std::cout
|
|
<< "Elapsed time: " << seconds << " seconds"
|
|
<< ", undocumented opcode count: " << undocumented_opcode_count
|
|
<< ", unimplemented opcode count: " << unimplemented_opcode_count
|
|
<< ", invalid opcode count: " << (invalid_opcode_count - unimplemented_opcode_count)
|
|
<< std::endl;
|
|
}
|