Vodafone Test Suite

Dependencies:   mbed-rtos mbed HTTPClient VodafoneUSBModem

Committer:
ashleymills
Date:
Tue Aug 28 15:40:07 2012 +0000
Revision:
12:b50d37429dff
Parent:
11:a286d8112b45
Child:
13:8b69853966f8
Added timeout for receiving sent SMS

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ashleymills 3:28336c2e94e4 1 #pragma once
ashleymills 4:1f8e079924ba 2 #include "VodafoneTestCase.h"
ashleymills 3:28336c2e94e4 3 class Test50 : public VodafoneTestCase {
ashleymills 3:28336c2e94e4 4 public:
ashleymills 3:28336c2e94e4 5 Test50(VodafoneUSBModem *m) : VodafoneTestCase(m) {
ashleymills 4:1f8e079924ba 6 _smsLen = 32;
ashleymills 4:1f8e079924ba 7 _numberLen = 16;
ashleymills 4:1f8e079924ba 8 }
ashleymills 4:1f8e079924ba 9
ashleymills 4:1f8e079924ba 10 virtual void setupTest() {
ashleymills 4:1f8e079924ba 11 allocStorage();
ashleymills 4:1f8e079924ba 12 }
ashleymills 4:1f8e079924ba 13
ashleymills 11:a286d8112b45 14 virtual void endTest() {
ashleymills 4:1f8e079924ba 15 freeStorage();
ashleymills 3:28336c2e94e4 16 }
ashleymills 3:28336c2e94e4 17
ashleymills 3:28336c2e94e4 18 virtual bool runTest() {
ashleymills 9:3ff68422f4d7 19 int numIterations = 10;
ashleymills 4:1f8e079924ba 20 size_t smCount;
ashleymills 4:1f8e079924ba 21 LOG("Getting MSISDN");
ashleymills 4:1f8e079924ba 22 _modem->sendUSSD("*#100#",_ownNumber,_numberLen);
ashleymills 4:1f8e079924ba 23 LOG("Got MSISDN %s",_ownNumber);
ashleymills 9:3ff68422f4d7 24 for(int i=0; i<numIterations; i++) {
ashleymills 4:1f8e079924ba 25 createRandomString(_smsOut,_smsLen);
ashleymills 9:3ff68422f4d7 26 if(_modem->sendSM(_ownNumber,_smsOut)!=0) {
ashleymills 9:3ff68422f4d7 27 LOG("Error sending short message");
ashleymills 4:1f8e079924ba 28 }
ashleymills 12:b50d37429dff 29 LOG("Created: %s",_smsOut);
ashleymills 4:1f8e079924ba 30 bool gotMessage = false;
ashleymills 12:b50d37429dff 31 Timer t;
ashleymills 12:b50d37429dff 32 t.start();
ashleymills 12:b50d37429dff 33 while(!gotMessage && t.read_ms()<25000) {
ashleymills 4:1f8e079924ba 34 if(_modem->getSMCount(&smCount)!=0) {
ashleymills 4:1f8e079924ba 35 LOG("Faiure getting SM count");
ashleymills 4:1f8e079924ba 36 return false;
ashleymills 4:1f8e079924ba 37 }
ashleymills 4:1f8e079924ba 38
ashleymills 4:1f8e079924ba 39 if(smCount>0) {
ashleymills 4:1f8e079924ba 40 if(_modem->getSM(_senderNumber,_smsIn,_smsLen)!=0) {
ashleymills 4:1f8e079924ba 41 LOG("Failure getting SM");
ashleymills 4:1f8e079924ba 42 return false;
ashleymills 4:1f8e079924ba 43 }
ashleymills 4:1f8e079924ba 44 LOG("Got SMS: %s",_smsIn);
ashleymills 9:3ff68422f4d7 45 if(strcmp(_smsIn,_smsOut)!=0) {
ashleymills 9:3ff68422f4d7 46 LOG("FAIL: strings did not match");
ashleymills 9:3ff68422f4d7 47 return false;
ashleymills 9:3ff68422f4d7 48 }
ashleymills 4:1f8e079924ba 49 gotMessage = true;
ashleymills 4:1f8e079924ba 50 }
ashleymills 4:1f8e079924ba 51 Thread::wait(50);
ashleymills 4:1f8e079924ba 52 }
ashleymills 12:b50d37429dff 53 if(!gotMessage) {
ashleymills 12:b50d37429dff 54 LOG("FAIL: timeout on waiting for SMS");
ashleymills 12:b50d37429dff 55 return false;
ashleymills 12:b50d37429dff 56 }
ashleymills 4:1f8e079924ba 57 }
ashleymills 3:28336c2e94e4 58
ashleymills 4:1f8e079924ba 59 return true;
ashleymills 3:28336c2e94e4 60 }
ashleymills 3:28336c2e94e4 61
ashleymills 4:1f8e079924ba 62 private:
ashleymills 4:1f8e079924ba 63 void createRandomString(char *target, int len) {
ashleymills 4:1f8e079924ba 64 for(int i=0; i<len; i++) {
ashleymills 9:3ff68422f4d7 65 target[i] = 65+rand()%16;
ashleymills 4:1f8e079924ba 66 }
ashleymills 4:1f8e079924ba 67 target[len-1] = 0x00;
ashleymills 4:1f8e079924ba 68 }
ashleymills 4:1f8e079924ba 69
ashleymills 4:1f8e079924ba 70 void allocStorage() {
ashleymills 4:1f8e079924ba 71 _ownNumber = (char*)malloc(_numberLen*sizeof(char));
ashleymills 4:1f8e079924ba 72 _senderNumber = (char*)malloc(_numberLen*sizeof(char));
ashleymills 4:1f8e079924ba 73 _smsOut = (char*)malloc(_smsLen*sizeof(char));
ashleymills 4:1f8e079924ba 74 _smsIn = (char*)malloc(_smsLen*sizeof(char));
ashleymills 4:1f8e079924ba 75 }
ashleymills 3:28336c2e94e4 76
ashleymills 4:1f8e079924ba 77 void freeStorage() {
ashleymills 4:1f8e079924ba 78 free(_ownNumber);
ashleymills 4:1f8e079924ba 79 free(_senderNumber);
ashleymills 4:1f8e079924ba 80 free(_smsOut);
ashleymills 4:1f8e079924ba 81 free(_smsIn);
ashleymills 4:1f8e079924ba 82 }
ashleymills 4:1f8e079924ba 83
ashleymills 4:1f8e079924ba 84 char* _ownNumber;
ashleymills 4:1f8e079924ba 85 char* _senderNumber;
ashleymills 4:1f8e079924ba 86 char* _smsOut;
ashleymills 4:1f8e079924ba 87 char* _smsIn;
ashleymills 4:1f8e079924ba 88 int _smsLen;
ashleymills 4:1f8e079924ba 89 int _numberLen;
ashleymills 3:28336c2e94e4 90 };