XPlor/tests/360/autotest_cod8_360.cpp
2025-04-23 00:09:35 -04:00

153 lines
5.5 KiB
C++

#include <QtTest/QtTest>
#include <QDirIterator>
#include <QFileInfo>
#include "autotest_cod.h"
#include "compression.h"
class AutoTest_COD8_360 : public AutoTest_COD {
Q_OBJECT
const QString EXPORT_DIR = "./exports/cod8/360";
private slots:
void initTestCase();
// Data-driven test for decompression
void testDecompression_data();
void testDecompression();
// Data-driven test for recompression (compression)
void testCompression_data();
void testCompression();
void cleanupTestCase();
};
void AutoTest_COD8_360::initTestCase() {
// Ensure the exports directory exists.
createDirectory(EXPORT_DIR);
}
void AutoTest_COD8_360::testDecompression_data() {
QTest::addColumn<QString>("fastFilePath_cod8_360");
QStringList ffFiles = findFastFiles(getFastFileDirectory());
for (const QString &filePath : ffFiles) {
QString fileName = QFileInfo(filePath).fileName();
QTest::newRow(qPrintable(fileName)) << filePath;
break;
}
}
void AutoTest_COD8_360::testDecompression() {
QFETCH(QString, fastFilePath_cod8_360);
const QString testName = "Decompress: " + fastFilePath_cod8_360;
// Open the original .ff file.
QFile testFastFile(fastFilePath_cod8_360);
QVERIFY2(testFastFile.open(QIODevice::ReadOnly),
qPrintable("Failed to open test fastfile: " + fastFilePath_cod8_360));
const QByteArray testFFData = testFastFile.readAll();
testFastFile.close();
//const QByteArray testData = Compression::CompressXMem("Hello World!");
//const QByteArray testOutData = Compression::DecompressXMem(testData);
//qDebug() << "Input: Hello World! - Output: " << testData.toHex() << " - New: " << testOutData;
QByteArray pattern;
pattern.append(static_cast<unsigned char>(0xFF));
QByteArray testZoneData;
for (int i = 12; i < testFFData.size(); i++) {
// Assume the first 12 bytes are a header; the rest is zlib-compressed zone data.
const QByteArray compressedData = testFFData.mid(i);
testZoneData = Compression::DecompressXMem(compressedData);
//QVERIFY2(!testZoneData.isEmpty(), qPrintable("Result was empty!"));
if (!testZoneData.isEmpty()) {
qDebug() << QString("Suceeded at %1!").arg(i);
//break;
}
qDebug() << QString("Failed at %1!").arg(i);
}
// Verify the decompressed data via its embedded zone size.
QDataStream zoneStream(testZoneData);
zoneStream.setByteOrder(QDataStream::LittleEndian);
quint32 zoneSize;
zoneStream >> zoneSize;
if (abs(zoneSize - testZoneData.size()) != 44) {
qDebug() << "Zone Size: " << zoneSize;
qDebug() << "Test zone Size: " << testZoneData.size();
qDebug() << "Difference: " << abs(zoneSize - testZoneData.size());
}
//QVERIFY2(zoneSize + 44 == testZoneData.size(),
// qPrintable("Decompression validation failed for: " + fastFilePath_cod8_360));
// Write the decompressed zone data to the exports folder with a .zone extension.
QFileInfo fi(fastFilePath_cod8_360);
QString outputFileName = fi.completeBaseName() + ".zone";
QString outputFilePath = QDir(EXPORT_DIR).filePath(outputFileName);
QFile outputFile(outputFilePath);
QVERIFY2(outputFile.open(QIODevice::WriteOnly),
qPrintable("Failed to open output file for writing: " + outputFilePath));
outputFile.write(testZoneData);
outputFile.close();
}
void AutoTest_COD8_360::testCompression_data() {
QTest::addColumn<QString>("zoneFilePath_cod8_360");
QStringList zoneFiles = findZoneFiles(getZoneFileDirectory());
for (const QString &filePath : zoneFiles) {
break;
QString fileName = QFileInfo(filePath).fileName();
QTest::newRow(qPrintable(fileName)) << filePath;
}
}
void AutoTest_COD8_360::testCompression() {
QFETCH(QString, zoneFilePath_cod8_360);
QFile zoneFile(zoneFilePath_cod8_360);
QVERIFY2(zoneFile.open(QIODevice::ReadOnly), qPrintable("Failed to open zone file: " + zoneFilePath_cod8_360));
QByteArray decompressedData = zoneFile.readAll();
zoneFile.close();
QFileInfo fi(zoneFilePath_cod8_360);
QString originalFFPath = QDir(getFastFileDirectory()).filePath(fi.completeBaseName() + ".ff");
QFile originalFile(originalFFPath);
QVERIFY2(originalFile.open(QIODevice::ReadOnly), qPrintable("Failed to open original .ff file: " + originalFFPath));
QByteArray originalFFData = originalFile.readAll();
originalFile.close();
QByteArray header = originalFFData.left(12);
QByteArray newCompressedData;// = Compressor::CompressZLIB(decompressedData, Z_BEST_COMPRESSION);
newCompressedData = Compression::CompressZLIBWithSettings(decompressedData, Z_BEST_COMPRESSION, MAX_WBITS, 8, Z_DEFAULT_STRATEGY, {});
int remainder = (newCompressedData.size() + 12) % 32;
if (remainder != 0) {
int paddingNeeded = 32 - remainder;
newCompressedData.append(QByteArray(paddingNeeded, '\0'));
}
QByteArray recompressedData = header + newCompressedData;
QString recompressedFilePath = QDir(EXPORT_DIR).filePath(fi.completeBaseName() + ".ff");
QFile recompressedFile(recompressedFilePath);
QVERIFY2(recompressedFile.open(QIODevice::WriteOnly), qPrintable("Failed to write recompressed file."));
recompressedFile.write(recompressedData);
recompressedFile.close();
QCOMPARE(recompressedData, originalFFData);
}
void AutoTest_COD8_360::cleanupTestCase() {
// Any cleanup if necessary.
}
// Don't generate a main() function
#include "autotest_cod8_360.moc"