This class provides SMS, USSD and modem file system support for u-blox modules on the C027 and C030 boards (excepting the C030 N2xx flavour) from mbed 5.5 onwards.

Dependents:   example-ublox-at-cellular-interface-ext example-ublox-cellular-driver-gen HelloMQTT ublox_new_driver_test ... more

Committer:
rob.meades@u-blox.com
Date:
Tue Jun 13 00:29:44 2017 +0100
Revision:
3:027c9eaec52c
Parent:
0:bb5fabac67ab
Child:
5:b935404dcf7c
Update to work with external libraries, not yet fully working on C027 though, watch this space.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
RobMeades 0:bb5fabac67ab 1 #include "mbed.h"
RobMeades 0:bb5fabac67ab 2 #include "greentea-client/test_env.h"
RobMeades 0:bb5fabac67ab 3 #include "unity.h"
RobMeades 0:bb5fabac67ab 4 #include "utest.h"
RobMeades 0:bb5fabac67ab 5 #include "UbloxCellularDriverGen.h"
RobMeades 0:bb5fabac67ab 6 #include "UDPSocket.h"
rob.meades@u-blox.com 3:027c9eaec52c 7 #ifdef FEATURE_COMMON_PAL
RobMeades 0:bb5fabac67ab 8 #include "mbed_trace.h"
RobMeades 0:bb5fabac67ab 9 #define TRACE_GROUP "TEST"
rob.meades@u-blox.com 3:027c9eaec52c 10 #else
rob.meades@u-blox.com 3:027c9eaec52c 11 #define tr_debug(format, ...) debug(format "\n", ## __VA_ARGS__)
rob.meades@u-blox.com 3:027c9eaec52c 12 #define tr_info(format, ...) debug(format "\n", ## __VA_ARGS__)
rob.meades@u-blox.com 3:027c9eaec52c 13 #define tr_warn(format, ...) debug(format "\n", ## __VA_ARGS__)
rob.meades@u-blox.com 3:027c9eaec52c 14 #define tr_error(format, ...) debug(format "\n", ## __VA_ARGS__)
rob.meades@u-blox.com 3:027c9eaec52c 15 #endif
RobMeades 0:bb5fabac67ab 16
RobMeades 0:bb5fabac67ab 17 using namespace utest::v1;
RobMeades 0:bb5fabac67ab 18
RobMeades 0:bb5fabac67ab 19 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 20 // COMPILE-TIME MACROS
RobMeades 0:bb5fabac67ab 21 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 22
RobMeades 0:bb5fabac67ab 23 // These macros can be overridden with an mbed_app.json file and
RobMeades 0:bb5fabac67ab 24 // contents of the following form:
RobMeades 0:bb5fabac67ab 25 //
RobMeades 0:bb5fabac67ab 26 //{
RobMeades 0:bb5fabac67ab 27 // "config": {
RobMeades 0:bb5fabac67ab 28 // "default-pin": {
RobMeades 0:bb5fabac67ab 29 // "value": "\"my_pin\""
RobMeades 0:bb5fabac67ab 30 // }
RobMeades 0:bb5fabac67ab 31 //}
RobMeades 0:bb5fabac67ab 32
RobMeades 0:bb5fabac67ab 33 // The credentials of the SIM in the board.
RobMeades 0:bb5fabac67ab 34 #ifndef MBED_CONF_APP_DEFAULT_PIN
RobMeades 0:bb5fabac67ab 35 // Note: this is the PIN for the SIM with ICCID
RobMeades 0:bb5fabac67ab 36 // 8944501104169548380.
RobMeades 0:bb5fabac67ab 37 # define MBED_CONF_APP_DEFAULT_PIN "5134"
RobMeades 0:bb5fabac67ab 38 #endif
RobMeades 0:bb5fabac67ab 39
RobMeades 0:bb5fabac67ab 40 // http://www.geckobeach.com/cellular/secrets/gsmcodes.php
RobMeades 0:bb5fabac67ab 41 // https://en.wikipedia.org/wiki/Unstructured_Supplementary_Service_Data
RobMeades 0:bb5fabac67ab 42
RobMeades 0:bb5fabac67ab 43 // A few USSD commands to try, set to "" to skip
RobMeades 0:bb5fabac67ab 44 #ifndef MBED_CONF_APP_USSD_COMMAND_1
RobMeades 0:bb5fabac67ab 45 # define MBED_CONF_APP_USSD_COMMAND_1 "*100#"
RobMeades 0:bb5fabac67ab 46 #endif
RobMeades 0:bb5fabac67ab 47
RobMeades 0:bb5fabac67ab 48 #ifndef MBED_CONF_APP_USSD_COMMAND_2
RobMeades 0:bb5fabac67ab 49 # define MBED_CONF_APP_USSD_COMMAND_2 "*#21#"
RobMeades 0:bb5fabac67ab 50 #endif
RobMeades 0:bb5fabac67ab 51
RobMeades 0:bb5fabac67ab 52 #ifndef MBED_CONF_APP_USSD_COMMAND_3
RobMeades 0:bb5fabac67ab 53 # define MBED_CONF_APP_USSD_COMMAND_3 "*#30#"
RobMeades 0:bb5fabac67ab 54 #endif
RobMeades 0:bb5fabac67ab 55
RobMeades 0:bb5fabac67ab 56 #ifndef MBED_CONF_APP_USSD_COMMAND_4
RobMeades 0:bb5fabac67ab 57 # define MBED_CONF_APP_USSD_COMMAND_4 "*#31#"
RobMeades 0:bb5fabac67ab 58 #endif
RobMeades 0:bb5fabac67ab 59
RobMeades 0:bb5fabac67ab 60 #ifndef MBED_CONF_APP_USSD_COMMAND_5
RobMeades 0:bb5fabac67ab 61 # define MBED_CONF_APP_USSD_COMMAND_5 "*#43#"
RobMeades 0:bb5fabac67ab 62 #endif
RobMeades 0:bb5fabac67ab 63
RobMeades 0:bb5fabac67ab 64 #ifndef MBED_CONF_APP_USSD_COMMAND_6
RobMeades 0:bb5fabac67ab 65 # define MBED_CONF_APP_USSD_COMMAND_6 "*#61#"
RobMeades 0:bb5fabac67ab 66 #endif
RobMeades 0:bb5fabac67ab 67
RobMeades 0:bb5fabac67ab 68 #ifndef MBED_CONF_APP_USSD_COMMAND_7
RobMeades 0:bb5fabac67ab 69 # define MBED_CONF_APP_USSD_COMMAND_7 ""
RobMeades 0:bb5fabac67ab 70 #endif
RobMeades 0:bb5fabac67ab 71
RobMeades 0:bb5fabac67ab 72 #ifndef MBED_CONF_APP_USSD_COMMAND_8
RobMeades 0:bb5fabac67ab 73 # define MBED_CONF_APP_USSD_COMMAND_8 ""
RobMeades 0:bb5fabac67ab 74 #endif
RobMeades 0:bb5fabac67ab 75
RobMeades 0:bb5fabac67ab 76 #ifndef MBED_CONF_APP_USSD_COMMAND_9
RobMeades 0:bb5fabac67ab 77 # define MBED_CONF_APP_USSD_COMMAND_9 ""
RobMeades 0:bb5fabac67ab 78 #endif
RobMeades 0:bb5fabac67ab 79
RobMeades 0:bb5fabac67ab 80 #ifndef MBED_CONF_APP_USSD_COMMAND_10
RobMeades 0:bb5fabac67ab 81 # define MBED_CONF_APP_USSD_COMMAND_10 ""
RobMeades 0:bb5fabac67ab 82 #endif
RobMeades 0:bb5fabac67ab 83
RobMeades 0:bb5fabac67ab 84 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 85 // PRIVATE VARIABLES
RobMeades 0:bb5fabac67ab 86 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 87
rob.meades@u-blox.com 3:027c9eaec52c 88 #ifdef FEATURE_COMMON_PAL
RobMeades 0:bb5fabac67ab 89 // Lock for debug prints
RobMeades 0:bb5fabac67ab 90 static Mutex mtx;
rob.meades@u-blox.com 3:027c9eaec52c 91 #endif
RobMeades 0:bb5fabac67ab 92
RobMeades 0:bb5fabac67ab 93 // An instance of the generic cellular class
RobMeades 0:bb5fabac67ab 94 static UbloxCellularDriverGen *pDriver =
RobMeades 0:bb5fabac67ab 95 new UbloxCellularDriverGen(MDMTXD, MDMRXD,
RobMeades 0:bb5fabac67ab 96 MBED_CONF_UBLOX_CELL_BAUD_RATE,
RobMeades 0:bb5fabac67ab 97 true);
RobMeades 0:bb5fabac67ab 98 // A general purpose buffer
RobMeades 0:bb5fabac67ab 99 static char buf[USSD_STRING_LENGTH + 1];
RobMeades 0:bb5fabac67ab 100
RobMeades 0:bb5fabac67ab 101 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 102 // PRIVATE FUNCTIONS
RobMeades 0:bb5fabac67ab 103 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 104
rob.meades@u-blox.com 3:027c9eaec52c 105 #ifdef FEATURE_COMMON_PAL
RobMeades 0:bb5fabac67ab 106 // Locks for debug prints
RobMeades 0:bb5fabac67ab 107 static void lock()
RobMeades 0:bb5fabac67ab 108 {
RobMeades 0:bb5fabac67ab 109 mtx.lock();
RobMeades 0:bb5fabac67ab 110 }
RobMeades 0:bb5fabac67ab 111
RobMeades 0:bb5fabac67ab 112 static void unlock()
RobMeades 0:bb5fabac67ab 113 {
RobMeades 0:bb5fabac67ab 114 mtx.unlock();
RobMeades 0:bb5fabac67ab 115 }
rob.meades@u-blox.com 3:027c9eaec52c 116 #endif
RobMeades 0:bb5fabac67ab 117
RobMeades 0:bb5fabac67ab 118 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 119 // TESTS
RobMeades 0:bb5fabac67ab 120 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 121
RobMeades 0:bb5fabac67ab 122 // Test USSD
RobMeades 0:bb5fabac67ab 123 void test_ussd() {
RobMeades 0:bb5fabac67ab 124 TEST_ASSERT(pDriver->init(MBED_CONF_APP_DEFAULT_PIN));
RobMeades 0:bb5fabac67ab 125 TEST_ASSERT(pDriver->nwk_registration());
RobMeades 0:bb5fabac67ab 126
RobMeades 0:bb5fabac67ab 127 if (strlen(MBED_CONF_APP_USSD_COMMAND_1) > 0) {
RobMeades 0:bb5fabac67ab 128 tr_debug("Sending : \"%s\".", MBED_CONF_APP_USSD_COMMAND_1);
RobMeades 0:bb5fabac67ab 129 TEST_ASSERT(pDriver->ussdCommand(MBED_CONF_APP_USSD_COMMAND_1, buf, sizeof (buf)));
RobMeades 0:bb5fabac67ab 130 tr_debug("USSD answer: \"%s\".", buf);
RobMeades 0:bb5fabac67ab 131 }
RobMeades 0:bb5fabac67ab 132
RobMeades 0:bb5fabac67ab 133 if (strlen(MBED_CONF_APP_USSD_COMMAND_2) > 0) {
RobMeades 0:bb5fabac67ab 134 tr_debug("Sending : \"%s\".", MBED_CONF_APP_USSD_COMMAND_2);
RobMeades 0:bb5fabac67ab 135 TEST_ASSERT(pDriver->ussdCommand(MBED_CONF_APP_USSD_COMMAND_2, buf, sizeof (buf)));
RobMeades 0:bb5fabac67ab 136 tr_debug("USSD answer: \"%s\".", buf);
RobMeades 0:bb5fabac67ab 137 }
RobMeades 0:bb5fabac67ab 138
RobMeades 0:bb5fabac67ab 139 if (strlen(MBED_CONF_APP_USSD_COMMAND_3) > 0) {
RobMeades 0:bb5fabac67ab 140 tr_debug("Sending : \"%s\".", MBED_CONF_APP_USSD_COMMAND_3);
RobMeades 0:bb5fabac67ab 141 TEST_ASSERT(pDriver->ussdCommand(MBED_CONF_APP_USSD_COMMAND_3, buf, sizeof (buf)));
RobMeades 0:bb5fabac67ab 142 tr_debug("USSD answer: \"%s\".", buf);
RobMeades 0:bb5fabac67ab 143 }
RobMeades 0:bb5fabac67ab 144
RobMeades 0:bb5fabac67ab 145 if (strlen(MBED_CONF_APP_USSD_COMMAND_4) > 0) {
RobMeades 0:bb5fabac67ab 146 tr_debug("Sending : \"%s\".", MBED_CONF_APP_USSD_COMMAND_4);
RobMeades 0:bb5fabac67ab 147 TEST_ASSERT(pDriver->ussdCommand(MBED_CONF_APP_USSD_COMMAND_4, buf, sizeof (buf)));
RobMeades 0:bb5fabac67ab 148 tr_debug("USSD answer: \"%s\".", buf);
RobMeades 0:bb5fabac67ab 149 }
RobMeades 0:bb5fabac67ab 150
RobMeades 0:bb5fabac67ab 151 if (strlen(MBED_CONF_APP_USSD_COMMAND_5) > 0) {
RobMeades 0:bb5fabac67ab 152 tr_debug("Sending : \"%s\".", MBED_CONF_APP_USSD_COMMAND_5);
RobMeades 0:bb5fabac67ab 153 TEST_ASSERT(pDriver->ussdCommand(MBED_CONF_APP_USSD_COMMAND_5, buf, sizeof (buf)));
RobMeades 0:bb5fabac67ab 154 tr_debug("USSD answer: \"%s\".", buf);
RobMeades 0:bb5fabac67ab 155 }
RobMeades 0:bb5fabac67ab 156
RobMeades 0:bb5fabac67ab 157 if (strlen(MBED_CONF_APP_USSD_COMMAND_6) > 0) {
RobMeades 0:bb5fabac67ab 158 tr_debug("Sending : \"%s\".", MBED_CONF_APP_USSD_COMMAND_6);
RobMeades 0:bb5fabac67ab 159 TEST_ASSERT(pDriver->ussdCommand(MBED_CONF_APP_USSD_COMMAND_6, buf, sizeof (buf)));
RobMeades 0:bb5fabac67ab 160 tr_debug("USSD answer: \"%s\".", buf);
RobMeades 0:bb5fabac67ab 161 }
RobMeades 0:bb5fabac67ab 162
RobMeades 0:bb5fabac67ab 163 if (strlen(MBED_CONF_APP_USSD_COMMAND_7) > 0) {
RobMeades 0:bb5fabac67ab 164 tr_debug("Sending : \"%s\".", MBED_CONF_APP_USSD_COMMAND_7);
RobMeades 0:bb5fabac67ab 165 TEST_ASSERT(pDriver->ussdCommand(MBED_CONF_APP_USSD_COMMAND_7, buf, sizeof (buf)));
RobMeades 0:bb5fabac67ab 166 tr_debug("USSD answer: \"%s\".", buf);
RobMeades 0:bb5fabac67ab 167 }
RobMeades 0:bb5fabac67ab 168
RobMeades 0:bb5fabac67ab 169 if (strlen(MBED_CONF_APP_USSD_COMMAND_8) > 0) {
RobMeades 0:bb5fabac67ab 170 tr_debug("Sending : \"%s\".", MBED_CONF_APP_USSD_COMMAND_8);
RobMeades 0:bb5fabac67ab 171 TEST_ASSERT(pDriver->ussdCommand(MBED_CONF_APP_USSD_COMMAND_8, buf, sizeof (buf)));
RobMeades 0:bb5fabac67ab 172 tr_debug("USSD answer: \"%s\".", buf);
RobMeades 0:bb5fabac67ab 173 }
RobMeades 0:bb5fabac67ab 174
RobMeades 0:bb5fabac67ab 175 if (strlen(MBED_CONF_APP_USSD_COMMAND_9) > 0) {
RobMeades 0:bb5fabac67ab 176 tr_debug("Sending : \"%s\".", MBED_CONF_APP_USSD_COMMAND_9);
RobMeades 0:bb5fabac67ab 177 TEST_ASSERT(pDriver->ussdCommand(MBED_CONF_APP_USSD_COMMAND_9, buf, sizeof (buf)));
RobMeades 0:bb5fabac67ab 178 tr_debug("USSD answer: \"%s\".", buf);
RobMeades 0:bb5fabac67ab 179 }
RobMeades 0:bb5fabac67ab 180
RobMeades 0:bb5fabac67ab 181 if (strlen(MBED_CONF_APP_USSD_COMMAND_10) > 0) {
RobMeades 0:bb5fabac67ab 182 tr_debug("Sending : \"%s\".", MBED_CONF_APP_USSD_COMMAND_10);
RobMeades 0:bb5fabac67ab 183 TEST_ASSERT(pDriver->ussdCommand(MBED_CONF_APP_USSD_COMMAND_10, buf, sizeof (buf)));
RobMeades 0:bb5fabac67ab 184 tr_debug("USSD answer: \"%s\".", buf);
RobMeades 0:bb5fabac67ab 185 }
RobMeades 0:bb5fabac67ab 186
RobMeades 0:bb5fabac67ab 187 TEST_ASSERT(pDriver->nwk_deregistration());
RobMeades 0:bb5fabac67ab 188 }
RobMeades 0:bb5fabac67ab 189
RobMeades 0:bb5fabac67ab 190 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 191 // TEST ENVIRONMENT
RobMeades 0:bb5fabac67ab 192 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 193
RobMeades 0:bb5fabac67ab 194 // Setup the test environment
RobMeades 0:bb5fabac67ab 195 utest::v1::status_t test_setup(const size_t number_of_cases) {
RobMeades 0:bb5fabac67ab 196 // Setup Greentea with a timeout
RobMeades 0:bb5fabac67ab 197 GREENTEA_SETUP(180, "default_auto");
RobMeades 0:bb5fabac67ab 198 return verbose_test_setup_handler(number_of_cases);
RobMeades 0:bb5fabac67ab 199 }
RobMeades 0:bb5fabac67ab 200
RobMeades 0:bb5fabac67ab 201 // Test cases
RobMeades 0:bb5fabac67ab 202 Case cases[] = {
RobMeades 0:bb5fabac67ab 203 Case("USSD test", test_ussd)
RobMeades 0:bb5fabac67ab 204
RobMeades 0:bb5fabac67ab 205 };
RobMeades 0:bb5fabac67ab 206
RobMeades 0:bb5fabac67ab 207 Specification specification(test_setup, cases);
RobMeades 0:bb5fabac67ab 208
RobMeades 0:bb5fabac67ab 209 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 210 // MAIN
RobMeades 0:bb5fabac67ab 211 // ----------------------------------------------------------------
RobMeades 0:bb5fabac67ab 212
RobMeades 0:bb5fabac67ab 213 int main() {
RobMeades 0:bb5fabac67ab 214
rob.meades@u-blox.com 3:027c9eaec52c 215 #ifdef FEATURE_COMMON_PAL
RobMeades 0:bb5fabac67ab 216 mbed_trace_init();
RobMeades 0:bb5fabac67ab 217
RobMeades 0:bb5fabac67ab 218 mbed_trace_mutex_wait_function_set(lock);
RobMeades 0:bb5fabac67ab 219 mbed_trace_mutex_release_function_set(unlock);
rob.meades@u-blox.com 3:027c9eaec52c 220 #endif
RobMeades 0:bb5fabac67ab 221
RobMeades 0:bb5fabac67ab 222 // Run tests
RobMeades 0:bb5fabac67ab 223 return !Harness::run(specification);
RobMeades 0:bb5fabac67ab 224 }
RobMeades 0:bb5fabac67ab 225
RobMeades 0:bb5fabac67ab 226 // End Of File
RobMeades 0:bb5fabac67ab 227