/* Arduino SdFat Library
* Copyright (C) 2011 by William Greiman
*
* This file is part of the Arduino SdFat Library
*
* This Library is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This Library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with the Arduino SdFat Library. If not, see
* .
*/
#include
static uint16_t failCount;
static uint16_t testCount;
static Print* testOut = &Serial;
//------------------------------------------------------------------------------
static size_t strlenPGM(PGM_P str) {
PGM_P end = str;
while (pgm_read_byte(end++)) {}
return end - str;
}
//------------------------------------------------------------------------------
void testBegin() {
Serial.begin(9600);
while (!Serial) {} // wait for leonardo
testOut = &Serial;
SerialPrintln_P(PSTR("Type any character to begin."));
while (Serial.read() <= 0) {}
delay(200); // Catch Due reset problem
print_P(testOut, PSTR("FreeRam: "));
testOut->println(FreeRam());
testOut->println();
failCount = 0;
testCount = 0;
}
//------------------------------------------------------------------------------
void testEnd() {
testOut->println();
println_P(testOut, PSTR("Compiled: " __DATE__ " " __TIME__));
print_P(testOut, PSTR("FreeRam: "));
testOut->println(FreeRam());
print_P(testOut, PSTR("Test count: "));
testOut->println(testCount);
print_P(testOut, PSTR("Fail count: "));
testOut->println(failCount);
}
//------------------------------------------------------------------------------
static void testResult(bool b, uint8_t n) {
while (n++ < 60) testOut->write(' ');
if (b) {
println_P(testOut, PSTR("..ok"));
} else {
println_P(testOut, PSTR("FAIL"));
failCount++;
}
testCount++;
}
//------------------------------------------------------------------------------
void testVerify_P(char* result, PGM_P expect) {
testOut->write('"');
testOut->print(result);
testOut->print("\",\"");
print_P(testOut, expect);
testOut->write('"');
uint8_t n = strlen(result) + strlenPGM(expect) + 5;
testResult(!strcmp_P(result, expect), n);
}
//------------------------------------------------------------------------------
void testVerify_P(bool b, PGM_P msg) {
print_P(testOut, msg);
uint8_t n = strlenPGM(msg);
testResult(b, n);
}