2016-12-27 19:03:46 -05:00
|
|
|
//
|
|
|
|
// CRCTests.m
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 27/12/2016.
|
2018-05-13 15:19:52 -04:00
|
|
|
// Copyright 2016 Thomas Harte. All rights reserved.
|
2016-12-27 19:03:46 -05:00
|
|
|
//
|
|
|
|
|
|
|
|
#import <XCTest/XCTest.h>
|
|
|
|
#include "CRC.hpp"
|
2018-05-23 22:21:57 -04:00
|
|
|
#include <string>
|
2016-12-27 19:03:46 -05:00
|
|
|
|
|
|
|
@interface CRCTests : XCTestCase
|
|
|
|
@end
|
|
|
|
|
|
|
|
@implementation CRCTests
|
|
|
|
|
2018-05-23 22:21:57 -04:00
|
|
|
- (uint16_t)crcOfData:(uint8_t *)data length:(size_t)length generator:(CRC::CCITT &)generator
|
2016-12-27 19:03:46 -05:00
|
|
|
{
|
|
|
|
generator.reset();
|
2016-12-28 18:29:37 -05:00
|
|
|
for(size_t c = 0; c < length; c++)
|
|
|
|
generator.add(data[c]);
|
2016-12-27 19:03:46 -05:00
|
|
|
return generator.get_value();
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void)testIDMark
|
|
|
|
{
|
|
|
|
uint8_t IDMark[] =
|
|
|
|
{
|
|
|
|
0xa1, 0xa1, 0xa1, 0xfe, 0x00, 0x00, 0x01, 0x01
|
|
|
|
};
|
|
|
|
uint16_t crc = 0xfa0c;
|
2018-05-23 22:21:57 -04:00
|
|
|
CRC::CCITT crcGenerator;
|
2016-12-27 19:03:46 -05:00
|
|
|
|
|
|
|
uint16_t computedCRC = [self crcOfData:IDMark length:sizeof(IDMark) generator:crcGenerator];
|
|
|
|
XCTAssert(computedCRC == crc, @"Calculated CRC should have been %04x, was %04x", crc, computedCRC);
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void)testData
|
|
|
|
{
|
|
|
|
uint8_t sectorData[] =
|
|
|
|
{
|
|
|
|
0xa1, 0xa1, 0xa1, 0xfb, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x01, 0x00, 0x53, 0x45, 0x44, 0x4f,
|
|
|
|
0x52, 0x49, 0x43, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x53, 0x45, 0x44, 0x4f, 0x52, 0x49, 0x43, 0x20, 0x56, 0x31, 0x2e, 0x30,
|
|
|
|
0x30, 0x36, 0x20, 0x30, 0x31, 0x2f, 0x30, 0x31, 0x2f, 0x38, 0x36, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x20, 0x20, 0x20, 0x20
|
|
|
|
};
|
|
|
|
uint16_t crc = 0x4de7;
|
2018-05-23 22:21:57 -04:00
|
|
|
CRC::CCITT crcGenerator;
|
2016-12-27 19:03:46 -05:00
|
|
|
|
|
|
|
uint16_t computedCRC = [self crcOfData:sectorData length:sizeof(sectorData) generator:crcGenerator];
|
|
|
|
XCTAssert(computedCRC == crc, @"Calculated CRC should have been %04x, was %04x", crc, computedCRC);
|
|
|
|
}
|
|
|
|
|
2018-05-23 22:21:57 -04:00
|
|
|
- (void)testCCITTCheck {
|
|
|
|
CRC::CCITT crcGenerator;
|
|
|
|
for(auto c: std::string("123456789")) {
|
|
|
|
crcGenerator.add(c);
|
|
|
|
}
|
|
|
|
XCTAssertEqual(crcGenerator.get_value(), 0x29b1);
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void)testCRC32Check {
|
|
|
|
CRC::CRC32 crcGenerator;
|
|
|
|
for(auto c: std::string("123456789")) {
|
|
|
|
crcGenerator.add(c);
|
|
|
|
}
|
|
|
|
XCTAssertEqual(crcGenerator.get_value(), 0xcbf43926);
|
|
|
|
}
|
|
|
|
|
2016-12-27 19:03:46 -05:00
|
|
|
@end
|