Program for the water play project for the course Software Testing Practical 2016 given at the VU University

Dependencies:   mbed DRV88255 TextLCD Ping mbed-rtos

Committer:
sbouber1
Date:
Sun Jun 19 23:07:21 2016 +0000
Revision:
61:6b5c2ddcea0c
Parent:
60:17e0a8e2be4a
Child:
68:b769c0f23406
sure hope this still works :D

Who changed what in which revision?

UserRevisionLine numberNew contents of line
sbouber1 21:17dd0d778bda 1 #include "mbed.h"
sbouber1 21:17dd0d778bda 2
sbouber1 19:ee89eabe1fa2 3 #include "MockSensorController.h"
sbouber1 61:6b5c2ddcea0c 4 #include "SensorAlarmController.h"
sbouber1 36:8aeb014bd651 5 #include "PIDController.h"
sbouber1 19:ee89eabe1fa2 6 #include "testing.h"
sbouber1 19:ee89eabe1fa2 7
sbouber1 19:ee89eabe1fa2 8
sbouber1 31:1c50d2d8c155 9 void TestCase::assert(bool b, const char *error) {
sbouber1 19:ee89eabe1fa2 10 if(!b) {
sbouber1 19:ee89eabe1fa2 11 printf("[%s] ASSERTION FAILED: %s\r\n", this->name, error);
sbouber1 19:ee89eabe1fa2 12 this->failed = true;
sbouber1 19:ee89eabe1fa2 13 }
sbouber1 19:ee89eabe1fa2 14 }
sbouber1 19:ee89eabe1fa2 15
sbouber1 28:f4a4ee58d57e 16 MOCK(temp_mock_steady, 35.0);
sbouber1 23:46cc7d776988 17 MOCK(salt_mock_steady, 6.1);
sbouber1 50:c1f682eb4c4e 18 MOCK(prox_mock_steady, 500.0);
sbouber1 23:46cc7d776988 19
sbouber1 30:cf12566013a5 20
sbouber1 22:4b5bf1c2e1ff 21 MOCK(temp_mock1, 40.1+(t/1000.0));
sbouber1 30:cf12566013a5 22 ALARM_TEST(testTempDangerousHighAlarm, temp_mock1, salt_mock_steady, prox_mock_steady, NUMBER_OF_SEC_BEFORE_CRITICAL_ALARM+1);
sbouber1 19:ee89eabe1fa2 23
sbouber1 22:4b5bf1c2e1ff 24 MOCK(temp_mock2, 29.9-(t/1000.0));
sbouber1 30:cf12566013a5 25 ALARM_TEST(testTempDangerousLowAlarm, temp_mock2, salt_mock_steady, prox_mock_steady, NUMBER_OF_SEC_BEFORE_CRITICAL_ALARM+1);
sbouber1 22:4b5bf1c2e1ff 26
sbouber1 50:c1f682eb4c4e 27 MOCK(temp_mock3, 30+(t*0.000001));
sbouber1 30:cf12566013a5 28 ALARM_TEST(testTempLowRangeAlarm, temp_mock3, salt_mock_steady, prox_mock_steady, NUMBER_OF_SEC_BEFORE_UNDESIRED_ALARM+1);
sbouber1 22:4b5bf1c2e1ff 29
sbouber1 50:c1f682eb4c4e 30 MOCK(temp_mock4, 38+(t*0.000001));
sbouber1 30:cf12566013a5 31 ALARM_TEST(testTempHighRangeAlarm, temp_mock4, salt_mock_steady, prox_mock_steady, NUMBER_OF_SEC_BEFORE_UNDESIRED_ALARM+1);
sbouber1 30:cf12566013a5 32
sbouber1 30:cf12566013a5 33 MOCK(overflow_undesired_mock, 900+(t/4000.0));
sbouber1 30:cf12566013a5 34 ALARM_TEST(testAlarmWaterOverflowUndesired, temp_mock_steady, salt_mock_steady, overflow_undesired_mock, NUMBER_OF_SEC_BEFORE_UNDESIRED_ALARM+1);
sbouber1 30:cf12566013a5 35
sbouber1 30:cf12566013a5 36 MOCK(overflow_critical_mock, 1001+(t/4000.0));
sbouber1 30:cf12566013a5 37 ALARM_TEST(testAlarmWaterOverflowCritical, temp_mock_steady, salt_mock_steady, overflow_critical_mock, NUMBER_OF_SEC_BEFORE_CRITICAL_ALARM+1);
sbouber1 30:cf12566013a5 38
sbouber1 30:cf12566013a5 39 MOCK(leak_undesired_mock, 1+(t/4000.0));
sbouber1 30:cf12566013a5 40 ALARM_TEST(testAlarmWaterLeakUndesired, temp_mock_steady, salt_mock_steady, leak_undesired_mock, NUMBER_OF_SEC_BEFORE_UNDESIRED_ALARM+1);
sbouber1 30:cf12566013a5 41
sbouber1 30:cf12566013a5 42 MOCK(leak_critical_mock, -1-(t/4000.0));
sbouber1 51:4a70184ff7dc 43 ALARM_TEST(testAlarmWaterLeakCritical, temp_mock_steady, salt_mock_steady, leak_critical_mock, NUMBER_OF_SEC_BEFORE_CRITICAL_ALARM+1);
sbouber1 22:4b5bf1c2e1ff 44
sbouber1 50:c1f682eb4c4e 45 MOCK(salinity_mock1, 3.1+(t*0.000005));
sbouber1 31:1c50d2d8c155 46 ALARM_TEST(testSalinityLowRangeAlarm, temp_mock_steady, salinity_mock1, prox_mock_steady, NUMBER_OF_SEC_BEFORE_UNDESIRED_ALARM+1);
sbouber1 31:1c50d2d8c155 47
sbouber1 50:c1f682eb4c4e 48 MOCK(salinity_mock2, 9.1+(t*0.000005));
sbouber1 31:1c50d2d8c155 49 ALARM_TEST(testSalinityHighRangeAlarm, temp_mock_steady, salinity_mock2, prox_mock_steady, NUMBER_OF_SEC_BEFORE_UNDESIRED_ALARM+1);
sbouber1 31:1c50d2d8c155 50
sbouber1 50:c1f682eb4c4e 51 MOCK(salinity_mock3, 2.9-(t*0.000005));
sbouber1 31:1c50d2d8c155 52 ALARM_TEST(testSalinityDangerousLowAlarm, temp_mock_steady, salinity_mock3, prox_mock_steady, NUMBER_OF_SEC_BEFORE_CRITICAL_ALARM+1);
sbouber1 31:1c50d2d8c155 53
sbouber1 50:c1f682eb4c4e 54 MOCK(salinity_mock4, 12.1+(t*0.000005));
sbouber1 31:1c50d2d8c155 55 ALARM_TEST(testSalinityDangerousHighAlarm, temp_mock_steady, salinity_mock4, prox_mock_steady, NUMBER_OF_SEC_BEFORE_CRITICAL_ALARM+1);
sbouber1 19:ee89eabe1fa2 56
sbouber1 50:c1f682eb4c4e 57 MOCK(temp_heating_mock, 29+(0.001*t));
sbouber1 23:46cc7d776988 58 bool testTemperatureHeater(TestCase *tc) {
sbouber1 36:8aeb014bd651 59 DEF_MOCKS(temp_heating_mock, salt_mock_steady, prox_mock_steady);
sbouber1 36:8aeb014bd651 60 PIDController pidc(false,0,&temp,&salt,&prox);
sbouber1 36:8aeb014bd651 61
sbouber1 37:2d9480c498c9 62 pidc.run();
sbouber1 61:6b5c2ddcea0c 63 tc->assert(pidc.isHeating(), "PIDController should be heating at temp=29!");
sbouber1 36:8aeb014bd651 64 Thread::wait(1000);
sbouber1 37:2d9480c498c9 65
sbouber1 37:2d9480c498c9 66 pidc.run();
sbouber1 61:6b5c2ddcea0c 67 tc->assert(pidc.isHeating(), "PIDController should be heating at temp=30!");
sbouber1 36:8aeb014bd651 68 Thread::wait(1000);
sbouber1 37:2d9480c498c9 69
sbouber1 37:2d9480c498c9 70 pidc.run();
sbouber1 61:6b5c2ddcea0c 71 tc->assert(pidc.isHeating(), "PIDController should be heating at temp=31!");
sbouber1 51:4a70184ff7dc 72 Thread::wait(2500);
sbouber1 37:2d9480c498c9 73
sbouber1 37:2d9480c498c9 74 pidc.run();
sbouber1 61:6b5c2ddcea0c 75 tc->assert(!pidc.isHeating(), "PIDController shouldn't be heating at temp=33.5!");
sbouber1 36:8aeb014bd651 76
sbouber1 23:46cc7d776988 77 return true;
sbouber1 23:46cc7d776988 78 }
sbouber1 23:46cc7d776988 79
sbouber1 30:cf12566013a5 80
sbouber1 61:6b5c2ddcea0c 81 int testMain() {
sbouber1 31:1c50d2d8c155 82
sbouber1 31:1c50d2d8c155 83 START_TESTS();
sbouber1 31:1c50d2d8c155 84
sbouber1 57:8dc3192ff150 85 TESTCASE("Test if alarm is raised when temp > 40 for 30 seconds", testTempDangerousHighAlarm);
sbouber1 57:8dc3192ff150 86 TESTCASE("Test if alarm is raised when temp < 30 for 30 seconds", testTempDangerousLowAlarm);
sbouber1 57:8dc3192ff150 87 TESTCASE("Test if alarm is raised when temp > 30 and < 32 for 5 minutes", testTempLowRangeAlarm);
sbouber1 57:8dc3192ff150 88 TESTCASE("Test if alarm is raised when temp > 38 and < 40 for 5 minutes", testTempHighRangeAlarm);
sbouber1 19:ee89eabe1fa2 89
sbouber1 57:8dc3192ff150 90 TESTCASE("Test if alarm is raised when salinity > 3 and < 6 for 5 minutes", testSalinityLowRangeAlarm);
sbouber1 57:8dc3192ff150 91 TESTCASE("Test if alarm is raised when salinity > 9 and < 12 for 5 minutes", testSalinityHighRangeAlarm);
sbouber1 57:8dc3192ff150 92 TESTCASE("Test if alarm is raised when salinity < 3 for 30 seconds", testSalinityDangerousLowAlarm);
sbouber1 57:8dc3192ff150 93 TESTCASE("Test if alarm is raised when salinity > 12 for 30 seconds", testSalinityDangerousHighAlarm);
sbouber1 31:1c50d2d8c155 94
sbouber1 57:8dc3192ff150 95 TESTCASE("Test if heater gets enabled at < 32 and disabled at 33+", testTemperatureHeater);
sbouber1 31:1c50d2d8c155 96
sbouber1 57:8dc3192ff150 97 TESTCASE("Test if alarm is raised when water tank level in range 900-1000 ml for 5 minutes", testAlarmWaterOverflowUndesired);
sbouber1 57:8dc3192ff150 98 TESTCASE("Test if alarm is raised when water tank level is 1001 for 30 seconds", testAlarmWaterOverflowCritical);
sbouber1 57:8dc3192ff150 99 TESTCASE("Test if alarm is raised when water tank level is in range 0-100 ml for 5 minutes", testAlarmWaterLeakUndesired);
sbouber1 57:8dc3192ff150 100 TESTCASE("Test if alarm is raised when water tank level is < 0 for 30 seconds", testAlarmWaterLeakCritical);
sbouber1 31:1c50d2d8c155 101
sbouber1 31:1c50d2d8c155 102 END_TESTS();
sbouber1 30:cf12566013a5 103
sbouber1 19:ee89eabe1fa2 104 return 0;
sbouber1 19:ee89eabe1fa2 105 }