-
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathunit_test_001.cpp
123 lines (94 loc) · 3.23 KB
/
unit_test_001.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
//
// FILE: unit_test_001.cpp
// AUTHOR: Rob Tillaart
// DATE: 2021-01-01
// PURPOSE: unit tests for the MS5611 temperature and pressure library
// https://github.com/RobTillaart/MS5611
// https://github.com/Arduino-CI/arduino_ci/blob/master/REFERENCE.md
//
// supported assertions
// ----------------------------
// 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 "MS5611.h"
unittest_setup()
{
fprintf(stderr, "MS5611_LIB_VERSION: %s\n", (char *) MS5611_LIB_VERSION );
}
unittest_teardown()
{
}
/*
unittest(test_new_operator)
{
assertEqualINF(exp(800));
assertEqualINF(0.0/0.0);
assertEqualINF(42);
assertEqualNAN(INFINITY - INFINITY);
assertEqualNAN(0.0/0.0);
assertEqualNAN(42);
}
*/
unittest(test_constants)
{
assertEqual(MS5611_READ_OK , 0);
assertEqual(MS5611_ERROR_2 , 2);
assertEqual(MS5611_NOT_READ, -999);
}
unittest(test_constructor)
{
MS5611 sensor(0x77);
assertFalse(sensor.begin()); // as there is no sensor, and no ROM values.
assertEqualFloat(-9.99, sensor.getTemperature(), 0.01);
assertEqualFloat(-9.99, sensor.getPressure(), 0.01);
assertEqual(0, sensor.getLastResult());
assertEqual(0, sensor.lastRead());
}
unittest(test_read_sensor)
{
MS5611 sensor(0x77);
assertFalse(sensor.begin());
assureEqual(MS5611_READ_OK, sensor.read());
// as Wire not implemented in tests
// assertEqual(MS5611_NOT_READ, sensor.getTemperature());
// assertEqual(MS5611_NOT_READ, sensor.getPressure());
// assertEqual(MS5611_NOT_READ, sensor.getLastResult());
// assertEqual(0, sensor.lastRead());
}
unittest(test_overSampling)
{
MS5611 sensor(0x77);
assertFalse(sensor.begin());
// default
assureEqual(OSR_ULTRA_LOW, sensor.getOversampling());
sensor.setOversampling(OSR_ULTRA_LOW);
assureEqual(OSR_ULTRA_LOW, sensor.getOversampling());
sensor.setOversampling(OSR_LOW);
assureEqual(OSR_LOW, sensor.getOversampling());
sensor.setOversampling(OSR_STANDARD);
assureEqual(OSR_STANDARD, sensor.getOversampling());
sensor.setOversampling(OSR_HIGH);
assureEqual(OSR_HIGH, sensor.getOversampling());
sensor.setOversampling(OSR_ULTRA_HIGH);
assureEqual(OSR_ULTRA_HIGH, sensor.getOversampling());
}
unittest_main()
// --------