ME910 support
Fork of MTS-Cellular by
Test/TestSMS.h@25:817e9d94bfd7, 2014-07-09 (annotated)
- Committer:
- mfiore
- Date:
- Wed Jul 09 14:44:48 2014 +0000
- Revision:
- 25:817e9d94bfd7
- Parent:
- 24:32d29cdfc1fa
- Child:
- 35:257eb41405e1
delete SMS messages at start of SMS unit test
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
mfiore | 17:dee902f7d00e | 1 | #ifndef TESTSMS_H |
mfiore | 17:dee902f7d00e | 2 | #define TESTSMS_H |
mfiore | 17:dee902f7d00e | 3 | |
mfiore | 17:dee902f7d00e | 4 | #include "mtsas.h" |
mfiore | 17:dee902f7d00e | 5 | #include <string> |
mfiore | 17:dee902f7d00e | 6 | #include <vector> |
mfiore | 17:dee902f7d00e | 7 | |
mfiore | 17:dee902f7d00e | 8 | using namespace mts; |
mfiore | 17:dee902f7d00e | 9 | |
mfiore | 17:dee902f7d00e | 10 | class TestSMS : public TestCollection |
mfiore | 17:dee902f7d00e | 11 | { |
mfiore | 17:dee902f7d00e | 12 | public: |
mfiore | 17:dee902f7d00e | 13 | TestSMS(); |
mfiore | 17:dee902f7d00e | 14 | virtual void run(); |
mfiore | 17:dee902f7d00e | 15 | |
mfiore | 17:dee902f7d00e | 16 | private: |
mfiore | 17:dee902f7d00e | 17 | MTSSerialFlowControl* io; |
mfiore | 17:dee902f7d00e | 18 | Cellular* radio; |
mfiore | 17:dee902f7d00e | 19 | }; |
mfiore | 17:dee902f7d00e | 20 | |
mfiore | 20:7cc2f55fb16b | 21 | |
mfiore | 17:dee902f7d00e | 22 | TestSMS::TestSMS() : TestCollection("TestSMS") {} |
mfiore | 17:dee902f7d00e | 23 | |
mfiore | 17:dee902f7d00e | 24 | void TestSMS::run() { |
mfiore | 21:916ef2da10f1 | 25 | const char APN[] = ""; |
mfiore | 21:916ef2da10f1 | 26 | |
mfiore | 17:dee902f7d00e | 27 | string number; |
mfiore | 17:dee902f7d00e | 28 | string response; |
mfiore | 17:dee902f7d00e | 29 | vector<string> parts; |
mfiore | 17:dee902f7d00e | 30 | vector<Cellular::Sms> rmessages; |
mfiore | 17:dee902f7d00e | 31 | vector<string> smessages; |
mfiore | 17:dee902f7d00e | 32 | smessages.push_back("testing SMS 1"); |
mfiore | 17:dee902f7d00e | 33 | smessages.push_back("testing SMS 2"); |
mfiore | 17:dee902f7d00e | 34 | smessages.push_back("This is a longer SMS message. It is the third and final message that will be sent."); |
mfiore | 17:dee902f7d00e | 35 | |
mfiore | 17:dee902f7d00e | 36 | MTSLog::setLogLevel(MTSLog::TRACE_LEVEL); |
mfiore | 17:dee902f7d00e | 37 | |
mfiore | 17:dee902f7d00e | 38 | Test::start("Setup"); |
mfiore | 18:fa0d8120f81f | 39 | io = new MTSSerialFlowControl(D8, D2, D3, D6); |
mfiore | 17:dee902f7d00e | 40 | io->baud(115200); |
mfiore | 17:dee902f7d00e | 41 | radio = CellularFactory::create(io); |
mfiore | 17:dee902f7d00e | 42 | if (! radio) { |
mfiore | 17:dee902f7d00e | 43 | logError("radio is NULL"); |
mfiore | 17:dee902f7d00e | 44 | Test::assertTrue(false); |
mfiore | 17:dee902f7d00e | 45 | } |
mfiore | 18:fa0d8120f81f | 46 | radio->configureSignals(D4, D7, RESET); |
mfiore | 17:dee902f7d00e | 47 | |
mfiore | 17:dee902f7d00e | 48 | for (int i = 0; i < 10; i++) { |
mfiore | 17:dee902f7d00e | 49 | if (i >= 10) { |
mfiore | 17:dee902f7d00e | 50 | Test::assertTrue(false); |
mfiore | 17:dee902f7d00e | 51 | } |
mfiore | 24:32d29cdfc1fa | 52 | if (radio->setApn(APN) == MTS_SUCCESS) { |
mfiore | 17:dee902f7d00e | 53 | break; |
mfiore | 17:dee902f7d00e | 54 | } else { |
mfiore | 17:dee902f7d00e | 55 | wait(1); |
mfiore | 17:dee902f7d00e | 56 | } |
mfiore | 17:dee902f7d00e | 57 | } |
mfiore | 25:817e9d94bfd7 | 58 | |
mfiore | 25:817e9d94bfd7 | 59 | Test::assertTrue(radio->deleteAllReceivedSms() == MTS_SUCCESS); |
mfiore | 25:817e9d94bfd7 | 60 | Test::assertTrue(radio->getReceivedSms().size() == 0); |
mfiore | 17:dee902f7d00e | 61 | Test::end(); |
mfiore | 17:dee902f7d00e | 62 | |
mfiore | 17:dee902f7d00e | 63 | Test::start("Send SMS"); |
mfiore | 17:dee902f7d00e | 64 | logInfo("finding my phone number"); |
mfiore | 17:dee902f7d00e | 65 | while (true) { |
mfiore | 17:dee902f7d00e | 66 | response = radio->sendCommand("AT+CNUM", 1000); |
mfiore | 17:dee902f7d00e | 67 | if (response.find("ERROR") == string::npos && response.find("error") == string::npos) { |
mfiore | 17:dee902f7d00e | 68 | break; |
mfiore | 17:dee902f7d00e | 69 | } |
mfiore | 17:dee902f7d00e | 70 | |
mfiore | 17:dee902f7d00e | 71 | wait(1); |
mfiore | 17:dee902f7d00e | 72 | } |
mfiore | 17:dee902f7d00e | 73 | if (response.find("My Number") != string::npos) { |
mfiore | 17:dee902f7d00e | 74 | parts = Text::split(response, ","); |
mfiore | 17:dee902f7d00e | 75 | number = parts[1]; |
mfiore | 17:dee902f7d00e | 76 | size_t fquote = number.find("\""); |
mfiore | 17:dee902f7d00e | 77 | size_t bquote = number.rfind("\""); |
mfiore | 17:dee902f7d00e | 78 | number = number.substr(fquote + 1, bquote - 1); |
mfiore | 17:dee902f7d00e | 79 | logInfo("my phone number: [%s]", number.c_str()); |
mfiore | 17:dee902f7d00e | 80 | } else { |
mfiore | 17:dee902f7d00e | 81 | Test::assertTrue(false); |
mfiore | 17:dee902f7d00e | 82 | } |
mfiore | 17:dee902f7d00e | 83 | |
mfiore | 24:32d29cdfc1fa | 84 | Test::assertTrue(radio->sendSMS(number, smessages[0]) == MTS_SUCCESS); |
mfiore | 24:32d29cdfc1fa | 85 | Test::assertTrue(radio->sendSMS(number, smessages[1]) == MTS_SUCCESS); |
mfiore | 17:dee902f7d00e | 86 | Test::end(); |
mfiore | 17:dee902f7d00e | 87 | |
mfiore | 17:dee902f7d00e | 88 | wait(30); |
mfiore | 17:dee902f7d00e | 89 | |
mfiore | 17:dee902f7d00e | 90 | Test::start("Receive SMS"); |
mfiore | 17:dee902f7d00e | 91 | rmessages = radio->getReceivedSms(); |
mfiore | 17:dee902f7d00e | 92 | Test::assertTrue(rmessages.size() == 2); |
mfiore | 17:dee902f7d00e | 93 | for (int i = 0; i < rmessages.size(); i++) { |
mfiore | 17:dee902f7d00e | 94 | Test::assertTrue(rmessages[i].message == smessages[i]); |
mfiore | 17:dee902f7d00e | 95 | } |
mfiore | 17:dee902f7d00e | 96 | Test::end(); |
mfiore | 17:dee902f7d00e | 97 | |
mfiore | 17:dee902f7d00e | 98 | Test::start("Send another SMS"); |
mfiore | 24:32d29cdfc1fa | 99 | Test::assertTrue(radio->sendSMS(number, smessages[2]) == MTS_SUCCESS); |
mfiore | 17:dee902f7d00e | 100 | Test::end(); |
mfiore | 17:dee902f7d00e | 101 | |
mfiore | 17:dee902f7d00e | 102 | wait(30); |
mfiore | 17:dee902f7d00e | 103 | |
mfiore | 17:dee902f7d00e | 104 | /* the SMS that we haven't "read" yet should not get deleted */ |
mfiore | 17:dee902f7d00e | 105 | Test::start("Delete Read SMS Messages"); |
mfiore | 24:32d29cdfc1fa | 106 | Test::assertTrue(radio->deleteOnlyReceivedReadSms() == MTS_SUCCESS); |
mfiore | 17:dee902f7d00e | 107 | Test::assertTrue(radio->getReceivedSms().size() == 1); |
mfiore | 17:dee902f7d00e | 108 | Test::end(); |
mfiore | 17:dee902f7d00e | 109 | |
mfiore | 17:dee902f7d00e | 110 | Test::start("Receive another SMS"); |
mfiore | 17:dee902f7d00e | 111 | rmessages = radio->getReceivedSms(); |
mfiore | 17:dee902f7d00e | 112 | Test::assertTrue(rmessages.size() == 1); |
mfiore | 17:dee902f7d00e | 113 | Test::assertTrue(rmessages[0].message == smessages[2]); |
mfiore | 17:dee902f7d00e | 114 | Test::end(); |
mfiore | 17:dee902f7d00e | 115 | |
mfiore | 17:dee902f7d00e | 116 | Test::start("Delete All SMS Messages"); |
mfiore | 24:32d29cdfc1fa | 117 | Test::assertTrue(radio->deleteAllReceivedSms() == MTS_SUCCESS); |
mfiore | 17:dee902f7d00e | 118 | Test::assertTrue(radio->getReceivedSms().size() == 0); |
mfiore | 17:dee902f7d00e | 119 | Test::end(); |
mfiore | 17:dee902f7d00e | 120 | } |
mfiore | 17:dee902f7d00e | 121 | |
mfiore | 17:dee902f7d00e | 122 | #endif |