Cellular library for MTS Socket Modem Arduino Shield devices from Multi-Tech Systems

Dependents:   mtsas mtsas mtsas mtsas

Committer:
Vanger
Date:
Wed Aug 13 21:50:43 2014 +0000
Revision:
62:c171606f7318
Parent:
61:2acb8c25aecf
Child:
67:7c705fe2acec
Removed APN from TestSMS.h

Who changed what in which revision?

UserRevisionLine numberNew 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 62:c171606f7318 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 56:43205bd2752a 60 while (radio->sendBasicCommand("AT+CMGD=1,4", 3000) != 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