mirror of
https://github.com/RobTillaart/Arduino.git
synced 2024-10-03 18:09:02 -04:00
514 lines
16 KiB
C++
514 lines
16 KiB
C++
//
|
|
// FILE: unit_test_001.cpp
|
|
// AUTHOR: Rob Tillaart
|
|
// DATE: 2020-12-03
|
|
// PURPOSE: unit tests for the Cozir CO2 library
|
|
// https://github.com/RobTillaart/Cozir
|
|
// https://github.com/Arduino-CI/arduino_ci/blob/master/REFERENCE.md
|
|
//
|
|
|
|
// supported assertions
|
|
// https://github.com/Arduino-CI/arduino_ci/blob/master/cpp/unittest/Assertion.h#L33-L42
|
|
// ----------------------------
|
|
// assertEqual(expected, actual); // a == b
|
|
// assertNotEqual(unwanted, actual); // a != b
|
|
// assertComparativeEquivalent(expected, actual); // abs(a - b) == 0 or (!(a > b) && !(a < b))
|
|
// assertComparativeNotEquivalent(unwanted, actual); // abs(a - b) > 0 or ((a > b) || (a < b))
|
|
// assertLess(upperBound, actual); // a < b
|
|
// assertMore(lowerBound, actual); // a > b
|
|
// assertLessOrEqual(upperBound, actual); // a <= b
|
|
// assertMoreOrEqual(lowerBound, actual); // a >= b
|
|
// assertTrue(actual);
|
|
// assertFalse(actual);
|
|
// assertNull(actual);
|
|
|
|
// // special cases for floats
|
|
// assertEqualFloat(expected, actual, epsilon); // fabs(a - b) <= epsilon
|
|
// assertNotEqualFloat(unwanted, actual, epsilon); // fabs(a - b) >= epsilon
|
|
// assertInfinity(actual); // isinf(a)
|
|
// assertNotInfinity(actual); // !isinf(a)
|
|
// assertNAN(arg); // isnan(a)
|
|
// assertNotNAN(arg); // !isnan(a)
|
|
|
|
|
|
#include <ArduinoUnitTests.h>
|
|
|
|
|
|
#include "Arduino.h"
|
|
#include "cozir.h"
|
|
#include "SoftwareSerial.h"
|
|
|
|
|
|
// NOTE: normally the COZIR lib is tested with software serial, at least in sketches
|
|
// to get the unit test up and running I (tried to) use Serial here.
|
|
|
|
// aspects of software serial
|
|
bool bigEndian = false;
|
|
|
|
|
|
unittest_setup()
|
|
{
|
|
fprintf(stderr, "COZIR_LIB_VERSION: %s\n", (char *) COZIR_LIB_VERSION);
|
|
}
|
|
|
|
|
|
unittest_teardown()
|
|
{
|
|
}
|
|
|
|
|
|
unittest(test_constants)
|
|
{
|
|
fprintf(stderr, "\noutput fields\n");
|
|
assertEqual(0x2000, CZR_LIGHT );
|
|
assertEqual(0x1000, CZR_HUMIDITY );
|
|
assertEqual(0x0800, CZR_FILTLED );
|
|
assertEqual(0x0400, CZR_RAWLED );
|
|
assertEqual(0x0200, CZR_MAXLED );
|
|
|
|
assertEqual(0x0100, CZR_ZEROPOINT );
|
|
assertEqual(0x0080, CZR_RAWTEMP );
|
|
assertEqual(0x0040, CZR_FILTTEMP );
|
|
assertEqual(0x0020, CZR_FILTLEDSIGNAL);
|
|
assertEqual(0x0010, CZR_RAWLEDSIGNAL );
|
|
|
|
assertEqual(0x0008, CZR_SENSTEMP );
|
|
assertEqual(0x0004, CZR_FILTCO2 );
|
|
assertEqual(0x0002, CZR_RAWCO2 );
|
|
assertEqual(0x0001, CZR_NONE );
|
|
assertEqual(0x1082, CZR_HTC );
|
|
|
|
assertEqual(0x3FFE, CZR_ALL );
|
|
|
|
fprintf(stderr, "\nmodi operandi\n");
|
|
assertEqual(0x00, CZR_COMMAND);
|
|
assertEqual(0x01, CZR_STREAMING);
|
|
assertEqual(0x02, CZR_POLLING);
|
|
}
|
|
|
|
|
|
|
|
unittest(test_software_serial)
|
|
{
|
|
int receivePin = 4;
|
|
int transmitPin = 5;
|
|
|
|
GodmodeState* state = GODMODE();
|
|
|
|
SoftwareSerial sws(receivePin, transmitPin);
|
|
COZIR co(&sws);
|
|
|
|
fprintf(stderr, "COZIR.init()\n");
|
|
co.init();
|
|
assertEqual("K 2\r\n", state->digitalPin[transmitPin].toAscii(1, bigEndian));
|
|
delay(1300);
|
|
assertTrue(co.isInitialized());
|
|
}
|
|
|
|
|
|
unittest(test_constructor)
|
|
{
|
|
GodmodeState* state = GODMODE();
|
|
|
|
state->serialPort[0].dataIn = ""; // the queue of data waiting to be read
|
|
state->serialPort[0].dataOut = ""; // the history of data written
|
|
|
|
fprintf(stderr, "default there is no data on the Serial bus\n");
|
|
assertEqual(-1, Serial.peek());
|
|
assertEqual("", state->serialPort[0].dataIn);
|
|
assertEqual("", state->serialPort[0].dataOut);
|
|
|
|
COZIR co(&Serial);
|
|
|
|
fprintf(stderr, "COZIR.init()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.init();
|
|
assertEqual("K 2\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.getVersionSerial()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.getVersionSerial();
|
|
assertEqual("K 0\r\nY\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.getConfiguration()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.getConfiguration();
|
|
assertEqual("K 0\r\n*\r\n", state->serialPort[0].dataOut);
|
|
}
|
|
|
|
|
|
unittest(test_setOperatingMode)
|
|
{
|
|
GodmodeState* state = GODMODE();
|
|
|
|
COZIR co(&Serial);
|
|
|
|
fprintf(stderr, "COZIR.init()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.init();
|
|
// init() sets CZR_POLLING
|
|
assertEqual("K 2\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(co.getOperatingMode(), CZR_POLLING);
|
|
|
|
fprintf(stderr, "COZIR.SetOperatingMode(CZR_COMMAND)\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setOperatingMode(CZR_COMMAND);
|
|
assertEqual("K 0\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(co.getOperatingMode(), CZR_COMMAND);
|
|
|
|
fprintf(stderr, "COZIR.SetOperatingMode(CZR_STREAMING)\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setOperatingMode(CZR_STREAMING);
|
|
assertEqual("K 1\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(co.getOperatingMode(), CZR_STREAMING);
|
|
|
|
fprintf(stderr, "COZIR.SetOperatingMode(CZR_POLLING)\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setOperatingMode(CZR_POLLING);
|
|
assertEqual("K 2\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(co.getOperatingMode(), CZR_POLLING);
|
|
}
|
|
|
|
|
|
unittest(test_read_sensor)
|
|
{
|
|
GodmodeState* state = GODMODE();
|
|
|
|
COZIR co(&Serial);
|
|
|
|
fprintf(stderr, "COZIR.init()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.init();
|
|
assertEqual("K 2\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.Celsius()\n");
|
|
state->serialPort[0].dataIn = "T 750\r\n"; // 1000 = 0°C
|
|
state->serialPort[0].dataOut = "";
|
|
float celsius = co.celsius();
|
|
assertEqual("T\r\n", state->serialPort[0].dataOut);
|
|
assertEqualFloat(-25.0, celsius, 0.0001);
|
|
|
|
state->serialPort[0].dataIn = "T 1257\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
celsius = co.celsius();
|
|
assertEqual("T\r\n", state->serialPort[0].dataOut);
|
|
assertEqualFloat(25.7, celsius, 0.0001);
|
|
|
|
fprintf(stderr, "COZIR.humidity()\n");
|
|
state->serialPort[0].dataIn = "H 627\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
float humidity = co.humidity();
|
|
assertEqual("H\r\n", state->serialPort[0].dataOut);
|
|
assertEqualFloat(62.7, humidity, 0.0001);
|
|
|
|
fprintf(stderr, "COZIR.light()\n");
|
|
state->serialPort[0].dataIn = "L 189\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
float light = co.light();
|
|
assertEqual("L\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(189, light);
|
|
|
|
fprintf(stderr, "COZIR.CO2()\n");
|
|
state->serialPort[0].dataIn = "Z 432\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
float CO2 = co.CO2();
|
|
assertEqual("Z\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(432, CO2);
|
|
}
|
|
|
|
|
|
unittest(test_calibrate)
|
|
{
|
|
GodmodeState* state = GODMODE();
|
|
|
|
COZIR co(&Serial);
|
|
|
|
fprintf(stderr, "COZIR.init()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.init();
|
|
assertEqual("K 2\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.fineTuneZeroPoint(400, 382)\n");
|
|
state->serialPort[0].dataIn = "F 32950\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint16_t fineTuneZeroPoint = co.fineTuneZeroPoint(400, 382);
|
|
assertEqual("F 400 382\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(32950, fineTuneZeroPoint);
|
|
|
|
|
|
fprintf(stderr, "COZIR.calibrateFreshAir()\n");
|
|
state->serialPort[0].dataIn = "G 32950\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint16_t calibrateFreshAir = co.calibrateFreshAir();
|
|
assertEqual("G\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(32950, calibrateFreshAir);
|
|
|
|
fprintf(stderr, "COZIR.calibrateNitrogen()\n");
|
|
state->serialPort[0].dataIn = "U 32590\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint16_t calibrateNitrogen = co.calibrateNitrogen();
|
|
assertEqual("U\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(32590, calibrateNitrogen);
|
|
|
|
fprintf(stderr, "COZIR.calibrateKnownGas(100)\n");
|
|
state->serialPort[0].dataIn = "X 33012\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint16_t calibrateKnownGas = co.calibrateKnownGas(100);
|
|
assertEqual("X 100\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(33012, calibrateKnownGas);
|
|
|
|
}
|
|
|
|
|
|
unittest(test_digi_filter)
|
|
{
|
|
GodmodeState* state = GODMODE();
|
|
|
|
COZIR co(&Serial);
|
|
|
|
fprintf(stderr, "COZIR.init()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.init();
|
|
assertEqual("K 2\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.setDigiFilter(42)\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setDigiFilter(42);
|
|
assertEqual("A 42\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.getDigiFilter()\n");
|
|
state->serialPort[0].dataIn = "a 42\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint8_t digifilter = co.getDigiFilter();
|
|
assertEqual("a\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(42, digifilter);
|
|
}
|
|
|
|
|
|
unittest(test_streaming_mode)
|
|
{
|
|
GodmodeState* state = GODMODE();
|
|
|
|
COZIR co(&Serial);
|
|
|
|
fprintf(stderr, "COZIR.init()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.init();
|
|
assertEqual("K 2\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(co.getOutputFields(), CZR_NONE);
|
|
|
|
fprintf(stderr, "COZIR.setOperatingMode(CZR_STREAMING)\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setOperatingMode(CZR_STREAMING);
|
|
assertEqual("K 1\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.setOutputFields(CZR_HUMIDITY | CZR_RAWTEMP | CZR_RAWCO2)\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setOutputFields(CZR_HUMIDITY | CZR_RAWTEMP | CZR_RAWCO2);
|
|
assertEqual("M 4226\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(co.getOutputFields(), CZR_HTC);
|
|
|
|
fprintf(stderr, "COZIR.inOutputFields()\n");
|
|
assertTrue(co.inOutputFields(CZR_HUMIDITY));
|
|
assertTrue(co.inOutputFields(CZR_RAWTEMP));
|
|
assertTrue(co.inOutputFields(CZR_RAWCO2));
|
|
assertFalse(co.inOutputFields(CZR_LIGHT));
|
|
assertFalse(co.inOutputFields(~CZR_HTC));
|
|
|
|
fprintf(stderr, "COZIR.getRecentFields()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.getRecentFields();
|
|
assertEqual("Q\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.clearOutputFields()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.clearOutputFields();
|
|
assertEqual("M 1\r\n", state->serialPort[0].dataOut);
|
|
fprintf(stderr, "COZIR.inOutputFields()\n");
|
|
assertTrue(co.inOutputFields(CZR_NONE));
|
|
assertFalse(co.inOutputFields(~CZR_NONE));
|
|
|
|
fprintf(stderr, "COZIR.getRecentFields()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.getRecentFields();
|
|
assertEqual("Q\r\n", state->serialPort[0].dataOut);
|
|
// USER MUST READ RETURNED DATA AS IT CAN BE QUITE A LOT.
|
|
}
|
|
|
|
|
|
unittest(test_eeprom_I)
|
|
{
|
|
GodmodeState* state = GODMODE();
|
|
|
|
COZIR co(&Serial);
|
|
|
|
fprintf(stderr, "COZIR.init()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.init();
|
|
assertEqual("K 2\r\n", state->serialPort[0].dataOut);
|
|
|
|
// needs redo
|
|
fprintf(stderr, "COZIR._setEEPROM(10, 42)\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co._setEEPROM(10, 42);
|
|
assertEqual("P 10 42\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR._getEEPROM(100)\n");
|
|
state->serialPort[0].dataIn = "p 42\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint8_t getEEPROM = co._getEEPROM(100);
|
|
assertEqual("p 100\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(42, getEEPROM);
|
|
}
|
|
|
|
|
|
unittest(test_eeprom_II)
|
|
{
|
|
GodmodeState* state = GODMODE();
|
|
|
|
COZIR co(&Serial);
|
|
|
|
fprintf(stderr, "COZIR.init()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.init();
|
|
assertEqual("K 2\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.setAutoCalibrationPreload()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setAutoCalibrationPreload(123);
|
|
assertEqual("P 3 0\r\nP 4 123\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.getAutoCalibrationPreload()\n");
|
|
state->serialPort[0].dataIn = "p 01\r\np 42\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint16_t ACP = co.getAutoCalibrationPreload();
|
|
assertEqual("p 3\r\np 4\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(298, ACP);
|
|
|
|
|
|
fprintf(stderr, "COZIR.setAutoCalibrationInterval()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setAutoCalibrationInterval(123);
|
|
assertEqual("P 5 0\r\nP 6 123\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.getAutoCalibrationInterval()\n");
|
|
state->serialPort[0].dataIn = "p 04\r\np 01\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint16_t interval = co.getAutoCalibrationInterval();
|
|
assertEqual("p 5\r\np 6\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(1025, interval);
|
|
|
|
|
|
fprintf(stderr, "COZIR.setAutoCalibrationOn()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setAutoCalibrationOn();
|
|
assertEqual("P 7 1\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.setAutoCalibrationOff()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setAutoCalibrationOff();
|
|
assertEqual("P 7 0\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.getAutoCalibration()\n");
|
|
state->serialPort[0].dataIn = "p 01\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint8_t AC = co.getAutoCalibration();
|
|
assertEqual("p 7\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(1, AC);
|
|
|
|
|
|
fprintf(stderr, "COZIR.setAutoCalibrationBackgroundConcentration()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setAutoCalibrationBackgroundConcentration(524);
|
|
assertEqual("P 8 2\r\nP 9 12\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.getAutoCalibrationBackgroundConcentration()\n");
|
|
state->serialPort[0].dataIn = "p 03\r\np 10\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint16_t ACBC = co.getAutoCalibrationBackgroundConcentration();
|
|
assertEqual("p 8\r\np 9\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(778, ACBC);
|
|
|
|
|
|
fprintf(stderr, "COZIR.setAmbientConcentration()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setAmbientConcentration(1083);
|
|
assertEqual("P 10 4\r\nP 11 59\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.getAmbientConcentration()\n");
|
|
state->serialPort[0].dataIn = "p 05\r\np 00\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint16_t AMC = co.getAmbientConcentration();
|
|
assertEqual("p 10\r\np 11\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(1280, AMC);
|
|
|
|
|
|
fprintf(stderr, "COZIR.setBufferClearTime()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.setBufferClearTime(83);
|
|
assertEqual("P 12 0\r\nP 13 83\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.getBufferClearTime()\n");
|
|
state->serialPort[0].dataIn = "p 06\r\np 01\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint16_t BCT = co.getBufferClearTime();
|
|
assertEqual("p 12\r\np 13\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(1537, BCT);
|
|
|
|
}
|
|
|
|
|
|
unittest(test_PPM)
|
|
{
|
|
GodmodeState* state = GODMODE();
|
|
|
|
COZIR co(&Serial);
|
|
|
|
fprintf(stderr, "COZIR.init()\n");
|
|
state->serialPort[0].dataIn = "";
|
|
state->serialPort[0].dataOut = "";
|
|
co.init();
|
|
assertEqual("K 2\r\n", state->serialPort[0].dataOut);
|
|
|
|
fprintf(stderr, "COZIR.getPPMFactor()\n");
|
|
state->serialPort[0].dataIn = "p 01\r\n";
|
|
state->serialPort[0].dataOut = "";
|
|
uint16_t ppm = co.getPPMFactor();
|
|
assertEqual(".\r\n", state->serialPort[0].dataOut);
|
|
assertEqual(1, ppm);
|
|
|
|
fprintf(stderr, "\n===========================================\n\n");
|
|
}
|
|
|
|
|
|
unittest_main()
|
|
|
|
// --------
|