Vodafone Test Suite

Dependencies:   mbed-rtos mbed HTTPClient VodafoneUSBModem

Committer:
nherriot
Date:
Wed Sep 12 10:18:28 2012 +0000
Revision:
30:dd2beda340c6
Parent:
27:0297dbc3252b
Parent:
29:c0e6f198db84
Child:
31:9231acdde9ff
Child:
32:8ff0b67bb58c
merging working set with Ashley's new stuff

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ashleymills 2:ea883307d02f 1 #include "TestManager.h"
ashleymills 3:28336c2e94e4 2 #include "Tests.h"
ashleymills 19:26fbed33d4e7 3 TestManager::TestManager(VodafoneUSBModem *m) : _modem(m) {
ashleymills 19:26fbed33d4e7 4 // using direct array indexing instead of searching each time, so need to put in dummy tests
ashleymills 23:408199b5d2cb 5 for(int i=0; i<10; i++) { _tests.push_back(NULL); }
ashleymills 23:408199b5d2cb 6
ashleymills 23:408199b5d2cb 7 _tests.push_back((VodafoneTestCase*)new Test10(_modem,10));
ashleymills 23:408199b5d2cb 8
ashleymills 23:408199b5d2cb 9 for(int i=11; i<12; i++) { _tests.push_back(NULL); }
ashleymills 20:18373fb68ad7 10 _tests.push_back((VodafoneTestCase*)new Test12(_modem,12));
ashleymills 20:18373fb68ad7 11 _tests.push_back((VodafoneTestCase*)new Test13(_modem,13));
ashleymills 23:408199b5d2cb 12
nherriot 28:c630a04a7198 13 for(int i=14; i<16; i++) { _tests.push_back(NULL); }
nherriot 28:c630a04a7198 14 _tests.push_back((VodafoneTestCase*)new Test16(_modem,16));
nherriot 28:c630a04a7198 15
nherriot 28:c630a04a7198 16 for(int i=17; i<21; i++) { _tests.push_back(NULL); }
ashleymills 23:408199b5d2cb 17
ashleymills 20:18373fb68ad7 18 _tests.push_back((VodafoneTestCase*)new Test21(_modem,21));
ashleymills 20:18373fb68ad7 19 _tests.push_back((VodafoneTestCase*)new Test22(_modem,22));
ashleymills 20:18373fb68ad7 20 _tests.push_back((VodafoneTestCase*)new Test23(_modem,23));
ashleymills 23:408199b5d2cb 21
ashleymills 23:408199b5d2cb 22 for(int i=24; i<25; i++) { _tests.push_back(NULL); }
ashleymills 23:408199b5d2cb 23
ashleymills 22:5b1feecf2aeb 24 _tests.push_back((VodafoneTestCase*)new Test25(_modem,25));
ashleymills 22:5b1feecf2aeb 25 _tests.push_back((VodafoneTestCase*)new Test26(_modem,26));
ashleymills 23:408199b5d2cb 26
ashleymills 23:408199b5d2cb 27 for(int i=27; i<50; i++) { _tests.push_back(NULL); }
ashleymills 23:408199b5d2cb 28
ashleymills 20:18373fb68ad7 29 _tests.push_back((VodafoneTestCase*)new Test50(_modem,50));
nherriot 29:c0e6f198db84 30 _tests.push_back((VodafoneTestCase*)new Test56(_modem,45));
ashleymills 2:ea883307d02f 31 }
ashleymills 2:ea883307d02f 32
ashleymills 22:5b1feecf2aeb 33 int TestManager::getTestProfileLength(TestProfile profile) {
ashleymills 26:9eefab9e28df 34 if(profile < TESTS_END) { // no test for >= 0 since TestProfile is unsigned
ashleymills 22:5b1feecf2aeb 35 return gTestProfileLengths[profile];
ashleymills 22:5b1feecf2aeb 36 } else {
ashleymills 22:5b1feecf2aeb 37 LOG("Test profile out of bounds. Must be between 0 and %d",TESTS_END-1);
ashleymills 22:5b1feecf2aeb 38 return 0;
ashleymills 22:5b1feecf2aeb 39 }
ashleymills 22:5b1feecf2aeb 40 }
ashleymills 22:5b1feecf2aeb 41
ashleymills 22:5b1feecf2aeb 42 int TestManager::executeTestProfile(TestProfile profile) {
nherriot 30:dd2beda340c6 43
ashleymills 24:8f0f9551122a 44 int numPassed = 0;
ashleymills 26:9eefab9e28df 45 if(profile <TESTS_END) { // no test for >= 0 since TestProfile is unsigned
ashleymills 24:8f0f9551122a 46 numPassed = executeTestList(gTestProfiles[profile], gTestProfileLengths[profile]);
nherriot 30:dd2beda340c6 47
ashleymills 22:5b1feecf2aeb 48 } else {
ashleymills 22:5b1feecf2aeb 49 LOG("Test profile out of bounds. Must be between 0 and %d",TESTS_END-1);
ashleymills 22:5b1feecf2aeb 50 return 0;
ashleymills 22:5b1feecf2aeb 51 }
ashleymills 24:8f0f9551122a 52 int numTests = getTestProfileLength(profile);
ashleymills 24:8f0f9551122a 53 LOG("%d tests complete: %d passes and %d failures.",numTests,numPassed,numTests-numPassed);
ashleymills 27:0297dbc3252b 54 LOG("Listing failures:");
ashleymills 27:0297dbc3252b 55 listFailures(gTestProfiles[profile], gTestProfileLengths[profile]);
ashleymills 24:8f0f9551122a 56 return numPassed;
ashleymills 22:5b1feecf2aeb 57 }
ashleymills 22:5b1feecf2aeb 58
ashleymills 27:0297dbc3252b 59 void TestManager::listFailures(const int *list, const int listLen) {
ashleymills 27:0297dbc3252b 60 int successfullTests = 0;
ashleymills 27:0297dbc3252b 61 for(int i=0; i<listLen; i++) {
ashleymills 27:0297dbc3252b 62 int testIndex = list[i];
ashleymills 27:0297dbc3252b 63 if(testIndex>=_tests.size()) {
ashleymills 27:0297dbc3252b 64 LOG("Test out of bounds. Test index must be betweeen 0 and %d!",_tests.size());
ashleymills 27:0297dbc3252b 65 continue;
ashleymills 27:0297dbc3252b 66 }
ashleymills 27:0297dbc3252b 67
ashleymills 27:0297dbc3252b 68 VodafoneTestCase* test = _tests[list[i]];
ashleymills 27:0297dbc3252b 69 if(test->_lastRunOutcome==false) {
ashleymills 27:0297dbc3252b 70 LOG("Test %d:",list[i]);
ashleymills 27:0297dbc3252b 71 LOG(gTestDescriptions[list[i]]);
ashleymills 27:0297dbc3252b 72 }
ashleymills 27:0297dbc3252b 73 }
ashleymills 22:5b1feecf2aeb 74 }
ashleymills 22:5b1feecf2aeb 75
ashleymills 19:26fbed33d4e7 76 int TestManager::executeTestList(const int *list, const int listLen) {
nherriot 29:c0e6f198db84 77 LOG("The executeTestList is: %d", list);
nherriot 29:c0e6f198db84 78 LOG("The executeTestListLength is: %d", listLen);
ashleymills 2:ea883307d02f 79 int successfullTests = 0;
ashleymills 19:26fbed33d4e7 80 LOG("Running %d tests...",listLen);
ashleymills 19:26fbed33d4e7 81 for(int i=0; i<listLen; i++) {
ashleymills 19:26fbed33d4e7 82 int testIndex = list[i];
ashleymills 19:26fbed33d4e7 83 LOG("Running test %d...",testIndex);
ashleymills 19:26fbed33d4e7 84 if(testIndex>=_tests.size()) {
ashleymills 19:26fbed33d4e7 85 LOG("Test out of bounds. Test index must be betweeen 0 and %d!",_tests.size());
ashleymills 19:26fbed33d4e7 86 continue;
ashleymills 19:26fbed33d4e7 87 }
ashleymills 19:26fbed33d4e7 88
ashleymills 19:26fbed33d4e7 89 VodafoneTestCase* test = _tests[list[i]];
ashleymills 19:26fbed33d4e7 90 if(test==NULL) {
ashleymills 19:26fbed33d4e7 91 LOG("NULL test! This will be counted as a failure.");
ashleymills 19:26fbed33d4e7 92 continue;
ashleymills 19:26fbed33d4e7 93 }
ashleymills 19:26fbed33d4e7 94
ashleymills 19:26fbed33d4e7 95 if(test->run()) {
ashleymills 2:ea883307d02f 96 LOG("...OK");
ashleymills 2:ea883307d02f 97 successfullTests++;
ashleymills 2:ea883307d02f 98 } else {
ashleymills 2:ea883307d02f 99 LOG("...FAIL");
ashleymills 2:ea883307d02f 100 }
ashleymills 2:ea883307d02f 101 }
ashleymills 2:ea883307d02f 102 return successfullTests;
ashleymills 2:ea883307d02f 103 }
ashleymills 2:ea883307d02f 104
ashleymills 4:1f8e079924ba 105 bool TestManager::runTest(int id) {
ashleymills 4:1f8e079924ba 106 if(id<0||id>=_tests.size()) {
ashleymills 4:1f8e079924ba 107 LOG("Test ID must be between 0 and %d",_tests.size());
ashleymills 19:26fbed33d4e7 108 return false;
ashleymills 4:1f8e079924ba 109 }
ashleymills 19:26fbed33d4e7 110 if(_tests[id]==NULL) {
ashleymills 19:26fbed33d4e7 111 LOG("NULL test! This will be counted as a failure.");
ashleymills 19:26fbed33d4e7 112 return false;
ashleymills 19:26fbed33d4e7 113 }
ashleymills 19:26fbed33d4e7 114
ashleymills 4:1f8e079924ba 115 return _tests[id]->run();
ashleymills 4:1f8e079924ba 116 }
ashleymills 4:1f8e079924ba 117
ashleymills 4:1f8e079924ba 118
ashleymills 4:1f8e079924ba 119 bool TestManager::runTest(int id, int numTimes) {
ashleymills 4:1f8e079924ba 120 for(int i=0; i<numTimes; i++) {
ashleymills 4:1f8e079924ba 121 if(!runTest(id))
ashleymills 4:1f8e079924ba 122 return false;
ashleymills 4:1f8e079924ba 123 }
ashleymills 4:1f8e079924ba 124 return true;
ashleymills 2:ea883307d02f 125 }