Cellular library for MTS Socket Modem Arduino Shield devices from Multi-Tech Systems
Dependents: mtsas mtsas mtsas mtsas
Test/TestSMS.h@52:2cb58398a4f9, 2014-08-11 (annotated)
- Committer:
- Vanger
- Date:
- Mon Aug 11 16:03:19 2014 +0000
- Revision:
- 52:2cb58398a4f9
- Parent:
- 48:3f9d82915e83
- Child:
- 56:43205bd2752a
Removed parse response '>' from sendCommand() under Cellular.cpp, changed sendSMS() to verify sending SMS message under Cellular.cpp, changed disconnect() to have better flow under EasyIP.cpp, changed isConnected() to be simpler under EasyIP.cpp
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() { |
Vanger | 47:16a9297b59ba | 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 | |
Vanger | 52:2cb58398a4f9 | 59 | //Wait until the SIM card is ready |
Vanger | 52:2cb58398a4f9 | 60 | while (radio->sendBasicCommand("AT+CMGD=1,4", 1000) != MTS_SUCCESS); |
Vanger | 35:257eb41405e1 | 61 | |
mfiore | 25:817e9d94bfd7 | 62 | Test::assertTrue(radio->deleteAllReceivedSms() == MTS_SUCCESS); |
mfiore | 25:817e9d94bfd7 | 63 | Test::assertTrue(radio->getReceivedSms().size() == 0); |
mfiore | 17:dee902f7d00e | 64 | Test::end(); |
mfiore | 17:dee902f7d00e | 65 | |
Vanger | 48:3f9d82915e83 | 66 | Test::start("Send SMS 1"); |
mfiore | 17:dee902f7d00e | 67 | logInfo("finding my phone number"); |
mfiore | 17:dee902f7d00e | 68 | while (true) { |
mfiore | 17:dee902f7d00e | 69 | response = radio->sendCommand("AT+CNUM", 1000); |
mfiore | 17:dee902f7d00e | 70 | if (response.find("ERROR") == string::npos && response.find("error") == string::npos) { |
mfiore | 17:dee902f7d00e | 71 | break; |
mfiore | 17:dee902f7d00e | 72 | } |
mfiore | 17:dee902f7d00e | 73 | wait(1); |
mfiore | 17:dee902f7d00e | 74 | } |
Vanger | 52:2cb58398a4f9 | 75 | |
Vanger | 52:2cb58398a4f9 | 76 | //Read phone number from radio |
Vanger | 35:257eb41405e1 | 77 | if (response.find("+CNUM:") != string::npos) { |
mfiore | 17:dee902f7d00e | 78 | parts = Text::split(response, ","); |
mfiore | 17:dee902f7d00e | 79 | number = parts[1]; |
mfiore | 17:dee902f7d00e | 80 | size_t fquote = number.find("\""); |
mfiore | 17:dee902f7d00e | 81 | size_t bquote = number.rfind("\""); |
mfiore | 17:dee902f7d00e | 82 | number = number.substr(fquote + 1, bquote - 1); |
Vanger | 35:257eb41405e1 | 83 | logInfo("My phone number: [%s]", number.c_str()); |
mfiore | 17:dee902f7d00e | 84 | } else { |
mfiore | 17:dee902f7d00e | 85 | Test::assertTrue(false); |
mfiore | 17:dee902f7d00e | 86 | } |
mfiore | 17:dee902f7d00e | 87 | |
mfiore | 24:32d29cdfc1fa | 88 | Test::assertTrue(radio->sendSMS(number, smessages[0]) == MTS_SUCCESS); |
Vanger | 48:3f9d82915e83 | 89 | Test::end(); |
Vanger | 48:3f9d82915e83 | 90 | Test::start("Send SMS 2"); |
mfiore | 24:32d29cdfc1fa | 91 | Test::assertTrue(radio->sendSMS(number, smessages[1]) == MTS_SUCCESS); |
mfiore | 17:dee902f7d00e | 92 | Test::end(); |
mfiore | 17:dee902f7d00e | 93 | |
mfiore | 17:dee902f7d00e | 94 | wait(30); |
mfiore | 17:dee902f7d00e | 95 | |
mfiore | 17:dee902f7d00e | 96 | Test::start("Receive SMS"); |
mfiore | 17:dee902f7d00e | 97 | rmessages = radio->getReceivedSms(); |
mfiore | 17:dee902f7d00e | 98 | Test::assertTrue(rmessages.size() == 2); |
mfiore | 17:dee902f7d00e | 99 | for (int i = 0; i < rmessages.size(); i++) { |
mfiore | 17:dee902f7d00e | 100 | Test::assertTrue(rmessages[i].message == smessages[i]); |
mfiore | 17:dee902f7d00e | 101 | } |
mfiore | 17:dee902f7d00e | 102 | Test::end(); |
mfiore | 17:dee902f7d00e | 103 | |
mfiore | 17:dee902f7d00e | 104 | Test::start("Send another SMS"); |
mfiore | 24:32d29cdfc1fa | 105 | Test::assertTrue(radio->sendSMS(number, smessages[2]) == MTS_SUCCESS); |
mfiore | 17:dee902f7d00e | 106 | Test::end(); |
mfiore | 17:dee902f7d00e | 107 | |
mfiore | 17:dee902f7d00e | 108 | wait(30); |
mfiore | 17:dee902f7d00e | 109 | |
mfiore | 17:dee902f7d00e | 110 | /* the SMS that we haven't "read" yet should not get deleted */ |
mfiore | 17:dee902f7d00e | 111 | Test::start("Delete Read SMS Messages"); |
mfiore | 24:32d29cdfc1fa | 112 | Test::assertTrue(radio->deleteOnlyReceivedReadSms() == MTS_SUCCESS); |
mfiore | 17:dee902f7d00e | 113 | Test::assertTrue(radio->getReceivedSms().size() == 1); |
mfiore | 17:dee902f7d00e | 114 | Test::end(); |
mfiore | 17:dee902f7d00e | 115 | |
mfiore | 17:dee902f7d00e | 116 | Test::start("Receive another SMS"); |
mfiore | 17:dee902f7d00e | 117 | rmessages = radio->getReceivedSms(); |
mfiore | 17:dee902f7d00e | 118 | Test::assertTrue(rmessages.size() == 1); |
mfiore | 17:dee902f7d00e | 119 | Test::assertTrue(rmessages[0].message == smessages[2]); |
mfiore | 17:dee902f7d00e | 120 | Test::end(); |
mfiore | 17:dee902f7d00e | 121 | |
mfiore | 17:dee902f7d00e | 122 | Test::start("Delete All SMS Messages"); |
mfiore | 24:32d29cdfc1fa | 123 | Test::assertTrue(radio->deleteAllReceivedSms() == MTS_SUCCESS); |
mfiore | 17:dee902f7d00e | 124 | Test::assertTrue(radio->getReceivedSms().size() == 0); |
mfiore | 17:dee902f7d00e | 125 | Test::end(); |
mfiore | 17:dee902f7d00e | 126 | } |
mfiore | 17:dee902f7d00e | 127 | |
mfiore | 17:dee902f7d00e | 128 | #endif |