Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: mbed DRV88255 TextLCD Ping mbed-rtos
Diff: testing.cpp
- Revision:
- 28:f4a4ee58d57e
- Parent:
- 23:46cc7d776988
- Child:
- 30:cf12566013a5
diff -r 4f73f754fdc9 -r f4a4ee58d57e testing.cpp
--- a/testing.cpp Tue Jun 14 09:23:29 2016 +0000
+++ b/testing.cpp Tue Jun 14 09:46:31 2016 +0000
@@ -5,7 +5,7 @@
#include "testing.h"
#define NUMBER_OF_SEC_BEFORE_CRITICAL_ALARM 30
-#define NUMBER_OF_SEC_BEFORE_DANGEROUS_ALARM 300
+#define NUMBER_OF_SEC_BEFORE_UNDESIRED_ALARM 300
void TestCase::assertTrue(bool b, const char *error) {
if(!b) {
@@ -14,7 +14,7 @@
}
}
-
+MOCK(temp_mock_steady, 35.0);
MOCK(salt_mock_steady, 6.1);
MOCK(prox_mock_steady, 10.0);
@@ -53,7 +53,7 @@
DEF_MOCKS(temp_mock3, salt_mock_steady, prox_mock_steady);
AlarmController alarm(false,0,&temp,&salt,&prox);
- for(int i = 0; i < NUMBER_OF_SEC_BEFORE_DANGEROUS_ALARM+1; i++) {
+ for(int i = 0; i < NUMBER_OF_SEC_BEFORE_UNDESIRED_ALARM+1; i++) {
alarm.run();
Thread::wait(1000);
}
@@ -68,7 +68,7 @@
DEF_MOCKS(temp_mock4, salt_mock_steady, prox_mock_steady);
AlarmController alarm(false,0,&temp,&salt,&prox);
- for(int i = 0; i < NUMBER_OF_SEC_BEFORE_DANGEROUS_ALARM+1; i++) {
+ for(int i = 0; i < NUMBER_OF_SEC_BEFORE_UNDESIRED_ALARM+1; i++) {
alarm.run();
Thread::wait(1000);
}
@@ -82,22 +82,40 @@
return true;
}
-bool testAlarmWaterOverflow(TestCase *tc) {
- // TODO
- return true;
+MOCK(overflow_undesired_mock, 900+(t/4000.0));
+bool testAlarmWaterOverflowUndesired(TestCase *tc) {
+ DEF_MOCKS(temp_mock_steady, salt_mock_steady, overflow_undesired_mock);
+
+ AlarmController alarm(false,0,&temp,&salt,&prox);
+ for(int i = 0; i < NUMBER_OF_SEC_BEFORE_UNDESIRED_ALARM+1; i++) {
+ alarm.run();
+ Thread::wait(1000);
+ }
+
+ return alarm.is_error();
}
-bool testAlarmWaterLeak(TestCase *tc) {
- // TODO
+bool testAlarmWaterOverflowCritical(TestCase *tc) {
+ // TODO 1001 should raise alarm in 30 sec
return true;
}
+bool testAlarmWaterLeakUndesired(TestCase *tc) {
+ // TODO 0-100 ml for 5 minutes
+ return true;
+}
+
+bool testAlarmWaterLeakCritical(TestCase *tc) {
+ // TODO 0 ml should produce alarm in 30 sec
+ return true;
+}
+
int test_main() {
- TestCase t1("Test if alarm is raised when temp > 40 for 30 seconds", testTempDangerousHighAlarm);
- TestCase t2("Test if alarm is raised when temp < 30 for 30 seconds", testTempDangerousLowAlarm);
- TestCase t3("Test if alarm is raised when temp > 30 and < 32 for 300 seconds", testTempLowRangeAlarm);
- TestCase t4("Test if alarm is raised when temp > 38 and < 40 for 300 seconds", testTempHighRangeAlarm);
- TestCase t5("Test if heater gets enabled at < 32 and disabled at 32+", testTemperatureHeater);
+ TestCase("Test if alarm is raised when temp > 40 for 30 seconds", testTempDangerousHighAlarm);
+ TestCase("Test if alarm is raised when temp < 30 for 30 seconds", testTempDangerousLowAlarm);
+ TestCase("Test if alarm is raised when temp > 30 and < 32 for 300 seconds", testTempLowRangeAlarm);
+ TestCase("Test if alarm is raised when temp > 38 and < 40 for 300 seconds", testTempHighRangeAlarm);
+ //TestCase("Test if heater gets enabled at < 32 and disabled at 32+", testTemperatureHeater);
return 0;
}
\ No newline at end of file