Vodafone Test Suite

Dependencies:   mbed-rtos mbed HTTPClient VodafoneUSBModem

Tests/Test12.h

Committer:
ashleymills
Date:
2012-09-13
Revision:
33:16126e029d58
Parent:
31:9231acdde9ff
Child:
34:d9e45aad85f2

File content as of revision 33:16126e029d58:

#pragma once
#include "VodafoneTestCase.h"



// this test case will wait to receive an SMS from the modem.
// if the method that reports a message waiting returns an error it will fail.
// if the method that returns the message from the mailbox returns an error it will fai.
// it will report the test as failed if any of the above happens.
// it waits forever for an SMS.
// TODO: this should wait for a set time before failing.

static const char *gTest12Description = "Waiting for an SMS message with basic characters and numbers...";


class Test12 : public VodafoneTestCase {
   public: 

      char num[17];
      char msg[160];
      size_t count;

      Test12(VodafoneUSBModem *m) : VodafoneTestCase(m) {
         _description = gTest12Description;
         _testCaseNumber = 12;
      }
   
      virtual bool runTest() {
         LOG("Test: %d",_testCaseNumber);
         LOG(gTest12Description);
         LOG("Receiving SMS from test phone, waiting for response.");
      
         while(true)
            {
             LOG("Waiting for an SMS message...");
             int ret = _modem->getSMCount(&count);
             if(ret)
                {
                    LOG("getSMCount returned %d", ret);
                    Thread::wait(3000);
                    continue;
                }
    
             if( count > 0)
                {
                    LOG("%d SMS to read", count);
                    ret = _modem->getSM(num, msg, 64);
                    if(ret)
                        {
                            LOG("Error receiving sms. The method getSMS  returned %d", ret);
                            return false;
                        }
                    LOG("The message is from number: %s and the message is: \"%s\"", num, msg);
                    if (strcmp (msg, alphabetNumbersMessage) ==0)
                        {
                            LOG("Success receiving alphabet message matches the sent message");
                            return true;
                        }
                    
                    return false;
                }
                Thread::wait(500);
            }
                  
      }
};