This class adds HTTP, FTP and CellLocate client support for u-blox modules for the C027 and C030 boards (excepting the C030 N2xx flavour) from mbed 5.5 onwards. The HTTP, FTP and CellLocate operations are all hosted on the module, minimizing RAM consumption in the mbed MCU. It also sub-classes ublox-cellular-driver-gen to bring in SMS, USSD and modem file system support if you need to use these functions at the same time as the cellular interface.

Dependencies:   ublox-at-cellular-interface

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

Committer:
Bilal Qamar
Date:
Mon Aug 26 16:55:43 2019 +0500
Revision:
28:4427f2e6bbab
Parent:
20:737d307fd4d6
Child:
30:da746bc48735
HTTP Test TLS issue resolved

Who changed what in which revision?

UserRevisionLine numberNew contents of line
RobMeades 0:0b75e22c9231 1 #include "mbed.h"
RobMeades 0:0b75e22c9231 2 #include "greentea-client/test_env.h"
RobMeades 0:0b75e22c9231 3 #include "unity.h"
RobMeades 0:0b75e22c9231 4 #include "utest.h"
RobMeades 0:0b75e22c9231 5 #include "UbloxATCellularInterfaceExt.h"
RobMeades 0:0b75e22c9231 6 #include "UDPSocket.h"
rob.meades@u-blox.com 5:9fd89567f769 7 #ifdef FEATURE_COMMON_PAL
RobMeades 0:0b75e22c9231 8 #include "mbed_trace.h"
RobMeades 0:0b75e22c9231 9 #define TRACE_GROUP "TEST"
rob.meades@u-blox.com 5:9fd89567f769 10 #else
rob.meades@u-blox.com 5:9fd89567f769 11 #define tr_debug(format, ...) debug(format "\n", ## __VA_ARGS__)
rob.meades@u-blox.com 5:9fd89567f769 12 #define tr_info(format, ...) debug(format "\n", ## __VA_ARGS__)
rob.meades@u-blox.com 5:9fd89567f769 13 #define tr_warn(format, ...) debug(format "\n", ## __VA_ARGS__)
rob.meades@u-blox.com 5:9fd89567f769 14 #define tr_error(format, ...) debug(format "\n", ## __VA_ARGS__)
rob.meades@u-blox.com 5:9fd89567f769 15 #endif
RobMeades 0:0b75e22c9231 16
RobMeades 0:0b75e22c9231 17 using namespace utest::v1;
RobMeades 0:0b75e22c9231 18
RobMeades 0:0b75e22c9231 19 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 20 // COMPILE-TIME MACROS
RobMeades 0:0b75e22c9231 21 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 22
RobMeades 0:0b75e22c9231 23 // These macros can be overridden with an mbed_app.json file and
RobMeades 0:0b75e22c9231 24 // contents of the following form:
RobMeades 0:0b75e22c9231 25 //
RobMeades 0:0b75e22c9231 26 //{
RobMeades 0:0b75e22c9231 27 // "config": {
RobMeades 0:0b75e22c9231 28 // "apn": {
RobMeades 0:0b75e22c9231 29 // "value": "\"my_apn\""
RobMeades 0:0b75e22c9231 30 // }
RobMeades 0:0b75e22c9231 31 //}
RobMeades 0:0b75e22c9231 32
rob.meades@u-blox.com 11:3631f62bb359 33 // Whether debug trace is on
rob.meades@u-blox.com 11:3631f62bb359 34 #ifndef MBED_CONF_APP_DEBUG_ON
rob.meades@u-blox.com 11:3631f62bb359 35 # define MBED_CONF_APP_DEBUG_ON false
rob.meades@u-blox.com 11:3631f62bb359 36 #endif
rob.meades@u-blox.com 11:3631f62bb359 37
RobMeades 0:0b75e22c9231 38 // The credentials of the SIM in the board.
RobMeades 0:0b75e22c9231 39 #ifndef MBED_CONF_APP_DEFAULT_PIN
rob.meades@u-blox.com 11:3631f62bb359 40 // Note: if PIN is enabled on your SIM, you must define the PIN
rob.meades@u-blox.com 11:3631f62bb359 41 // for your SIM jere (e.g. using mbed_app.json to do so).
rob.meades@u-blox.com 11:3631f62bb359 42 # define MBED_CONF_APP_DEFAULT_PIN "0000"
RobMeades 0:0b75e22c9231 43 #endif
RobMeades 0:0b75e22c9231 44
RobMeades 0:0b75e22c9231 45 // Network credentials.
RobMeades 0:0b75e22c9231 46 #ifndef MBED_CONF_APP_APN
RobMeades 0:0b75e22c9231 47 # define MBED_CONF_APP_APN NULL
RobMeades 0:0b75e22c9231 48 #endif
RobMeades 0:0b75e22c9231 49 #ifndef MBED_CONF_APP_USERNAME
RobMeades 0:0b75e22c9231 50 # define MBED_CONF_APP_USERNAME NULL
RobMeades 0:0b75e22c9231 51 #endif
RobMeades 0:0b75e22c9231 52 #ifndef MBED_CONF_APP_PASSWORD
RobMeades 0:0b75e22c9231 53 # define MBED_CONF_APP_PASSWORD NULL
RobMeades 0:0b75e22c9231 54 #endif
RobMeades 0:0b75e22c9231 55
RobMeades 0:0b75e22c9231 56 // The time to wait for a HTTP command to complete
fahim.alavi@u-blox.com 19:ee06f3b2b078 57 #ifndef MBED_CONF_APP_HTTP_TIMEOUT
fahim.alavi@u-blox.com 19:ee06f3b2b078 58 #define HTTP_TIMEOUT 10000
fahim.alavi@u-blox.com 19:ee06f3b2b078 59 #else
fahim.alavi@u-blox.com 19:ee06f3b2b078 60 #define HTTP_TIMEOUT MBED_CONF_APP_HTTP_TIMEOUT
fahim.alavi@u-blox.com 19:ee06f3b2b078 61 #endif
RobMeades 0:0b75e22c9231 62
RobMeades 0:0b75e22c9231 63 // The HTTP echo server, as described in the
RobMeades 0:0b75e22c9231 64 // first answer here:
RobMeades 0:0b75e22c9231 65 // http://stackoverflow.com/questions/5725430/http-test-server-that-accepts-get-post-calls
RobMeades 0:0b75e22c9231 66 // !!! IMPORTANT: this test relies on that server behaving in the same way forever !!!
RobMeades 0:0b75e22c9231 67 #define HTTP_ECHO_SERVER "httpbin.org"
RobMeades 0:0b75e22c9231 68
RobMeades 0:0b75e22c9231 69 // The size of the test file
RobMeades 0:0b75e22c9231 70 #define TEST_FILE_SIZE 100
RobMeades 0:0b75e22c9231 71
RobMeades 0:0b75e22c9231 72 // The maximum number of HTTP profiles
RobMeades 0:0b75e22c9231 73 #define MAX_PROFILES 4
RobMeades 0:0b75e22c9231 74
RobMeades 0:0b75e22c9231 75 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 76 // PRIVATE VARIABLES
RobMeades 0:0b75e22c9231 77 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 78
rob.meades@u-blox.com 5:9fd89567f769 79 #ifdef FEATURE_COMMON_PAL
RobMeades 0:0b75e22c9231 80 // Lock for debug prints
RobMeades 0:0b75e22c9231 81 static Mutex mtx;
rob.meades@u-blox.com 5:9fd89567f769 82 #endif
RobMeades 0:0b75e22c9231 83
RobMeades 0:0b75e22c9231 84 // An instance of the cellular interface
RobMeades 0:0b75e22c9231 85 static UbloxATCellularInterfaceExt *pDriver =
RobMeades 0:0b75e22c9231 86 new UbloxATCellularInterfaceExt(MDMTXD, MDMRXD,
RobMeades 0:0b75e22c9231 87 MBED_CONF_UBLOX_CELL_BAUD_RATE,
rob.meades@u-blox.com 11:3631f62bb359 88 MBED_CONF_APP_DEBUG_ON);
RobMeades 0:0b75e22c9231 89 // A few buffers for general use
fahim.alavi@u-blox.com 18:071ae6c6e581 90 static char buf[2048];
RobMeades 0:0b75e22c9231 91 static char buf1[sizeof(buf)];
RobMeades 0:0b75e22c9231 92
RobMeades 0:0b75e22c9231 93 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 94 // PRIVATE FUNCTIONS
RobMeades 0:0b75e22c9231 95 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 96
rob.meades@u-blox.com 5:9fd89567f769 97 #ifdef FEATURE_COMMON_PAL
RobMeades 0:0b75e22c9231 98 // Locks for debug prints
RobMeades 0:0b75e22c9231 99 static void lock()
RobMeades 0:0b75e22c9231 100 {
RobMeades 0:0b75e22c9231 101 mtx.lock();
RobMeades 0:0b75e22c9231 102 }
RobMeades 0:0b75e22c9231 103
RobMeades 0:0b75e22c9231 104 static void unlock()
RobMeades 0:0b75e22c9231 105 {
RobMeades 0:0b75e22c9231 106 mtx.unlock();
RobMeades 0:0b75e22c9231 107 }
rob.meades@u-blox.com 5:9fd89567f769 108 #endif
RobMeades 0:0b75e22c9231 109
RobMeades 0:0b75e22c9231 110 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 111 // TESTS
RobMeades 0:0b75e22c9231 112 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 113
RobMeades 0:0b75e22c9231 114 // Test HTTP commands
RobMeades 0:0b75e22c9231 115 void test_http_cmd() {
RobMeades 0:0b75e22c9231 116 int profile;
RobMeades 0:0b75e22c9231 117 char * pData;
RobMeades 0:0b75e22c9231 118
RobMeades 0:0b75e22c9231 119 TEST_ASSERT(pDriver->connect(MBED_CONF_APP_DEFAULT_PIN, MBED_CONF_APP_APN,
RobMeades 0:0b75e22c9231 120 MBED_CONF_APP_USERNAME, MBED_CONF_APP_PASSWORD) == 0);
RobMeades 0:0b75e22c9231 121
RobMeades 0:0b75e22c9231 122 profile = pDriver->httpAllocProfile();
RobMeades 0:0b75e22c9231 123 TEST_ASSERT(profile >= 0);
RobMeades 0:0b75e22c9231 124
RobMeades 0:0b75e22c9231 125 pDriver->httpSetTimeout(profile, HTTP_TIMEOUT);
RobMeades 0:0b75e22c9231 126
RobMeades 0:0b75e22c9231 127 // Set up the server to talk to
RobMeades 0:0b75e22c9231 128 TEST_ASSERT(pDriver->httpSetPar(profile, UbloxATCellularInterfaceExt::HTTP_SERVER_NAME, HTTP_ECHO_SERVER));
RobMeades 0:0b75e22c9231 129
RobMeades 0:0b75e22c9231 130 // Check HTTP head request
RobMeades 0:0b75e22c9231 131 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 132 TEST_ASSERT(pDriver->httpCommand(profile, UbloxATCellularInterfaceExt::HTTP_HEAD,
RobMeades 0:0b75e22c9231 133 "/headers",
RobMeades 0:0b75e22c9231 134 NULL, NULL, 0, NULL,
RobMeades 0:0b75e22c9231 135 buf, sizeof (buf)) == NULL);
RobMeades 0:0b75e22c9231 136 tr_debug("Received: %s", buf);
RobMeades 0:0b75e22c9231 137 TEST_ASSERT(strstr(buf, "Content-Length:") != NULL);
RobMeades 0:0b75e22c9231 138
RobMeades 0:0b75e22c9231 139 // Check HTTP get request
RobMeades 0:0b75e22c9231 140 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 141 TEST_ASSERT(pDriver->httpCommand(profile, UbloxATCellularInterfaceExt::HTTP_GET,
RobMeades 0:0b75e22c9231 142 "/get",
RobMeades 0:0b75e22c9231 143 NULL, NULL, 0, NULL,
RobMeades 0:0b75e22c9231 144 buf, sizeof (buf)) == NULL);
RobMeades 0:0b75e22c9231 145 tr_debug("Received: %s", buf);
SanaMasood 20:737d307fd4d6 146 TEST_ASSERT(strstr(buf, "HTTP/1.1 200 OK") != NULL);
RobMeades 0:0b75e22c9231 147
RobMeades 0:0b75e22c9231 148 // Check HTTP delete request
RobMeades 0:0b75e22c9231 149 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 150 TEST_ASSERT(pDriver->httpCommand(profile, UbloxATCellularInterfaceExt::HTTP_DELETE,
RobMeades 0:0b75e22c9231 151 "/delete",
RobMeades 0:0b75e22c9231 152 NULL, NULL, 0, NULL,
RobMeades 0:0b75e22c9231 153 buf, sizeof (buf)) == NULL);
RobMeades 0:0b75e22c9231 154 tr_debug("Received: %s", buf);
SanaMasood 20:737d307fd4d6 155 TEST_ASSERT(strstr(buf, "HTTP/1.1 200 OK") != NULL);
RobMeades 0:0b75e22c9231 156
RobMeades 0:0b75e22c9231 157 // Check HTTP put request (this will fail as the echo server doesn't support it)
RobMeades 0:0b75e22c9231 158 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 159 TEST_ASSERT(pDriver->httpCommand(profile, UbloxATCellularInterfaceExt::HTTP_PUT,
RobMeades 0:0b75e22c9231 160 "/put",
RobMeades 0:0b75e22c9231 161 NULL, NULL, 0, NULL,
RobMeades 0:0b75e22c9231 162 buf, sizeof (buf)) != NULL);
RobMeades 0:0b75e22c9231 163
RobMeades 0:0b75e22c9231 164 // Check HTTP post request with data
RobMeades 0:0b75e22c9231 165 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 166 TEST_ASSERT(pDriver->httpCommand(profile, UbloxATCellularInterfaceExt::HTTP_POST_DATA,
RobMeades 0:0b75e22c9231 167 "/post",
fahim.alavi@u-blox.com 18:071ae6c6e581 168 NULL, "formData=0123456789", 0, NULL,
RobMeades 0:0b75e22c9231 169 buf, sizeof (buf)) == NULL);
RobMeades 0:0b75e22c9231 170 tr_debug("Received: %s", buf);
SanaMasood 20:737d307fd4d6 171 TEST_ASSERT(strstr(buf, "HTTP/1.1 200 OK") != NULL);
RobMeades 0:0b75e22c9231 172
RobMeades 0:0b75e22c9231 173 // Check HTTP post request with a file, also checking that writing the response
RobMeades 0:0b75e22c9231 174 // to a named file works
RobMeades 0:0b75e22c9231 175 for (int x = 0; x < TEST_FILE_SIZE; x++) {
RobMeades 0:0b75e22c9231 176 buf[x] = (x % 10) + 0x30;
RobMeades 0:0b75e22c9231 177 }
RobMeades 0:0b75e22c9231 178 pDriver->delFile("post_test.txt");
RobMeades 0:0b75e22c9231 179 TEST_ASSERT(pDriver->writeFile("post_test.txt", buf, TEST_FILE_SIZE) == TEST_FILE_SIZE);
RobMeades 0:0b75e22c9231 180
RobMeades 0:0b75e22c9231 181 // This may fail if rsp.txt doesn't happen to be sitting around from a previous run
RobMeades 0:0b75e22c9231 182 // so don't check the return value
RobMeades 0:0b75e22c9231 183 pDriver->delFile("rsp.txt");
RobMeades 0:0b75e22c9231 184
RobMeades 0:0b75e22c9231 185 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 186 TEST_ASSERT(pDriver->httpCommand(profile, UbloxATCellularInterfaceExt::HTTP_POST_FILE,
RobMeades 0:0b75e22c9231 187 "/post",
RobMeades 0:0b75e22c9231 188 "rsp.txt", "post_test.txt",
RobMeades 0:0b75e22c9231 189 UbloxATCellularInterfaceExt::HTTP_CONTENT_TEXT, NULL,
RobMeades 0:0b75e22c9231 190 buf, sizeof (buf)) == NULL);
RobMeades 0:0b75e22c9231 191 tr_debug("Received: %s", buf);
RobMeades 0:0b75e22c9231 192 // Find the data in the response and check it
RobMeades 0:0b75e22c9231 193 pData = strstr(buf, "\"data\": \"");
RobMeades 0:0b75e22c9231 194 TEST_ASSERT(pData != NULL);
RobMeades 0:0b75e22c9231 195 pData += 9;
RobMeades 0:0b75e22c9231 196 for (int x = 0; x < TEST_FILE_SIZE; x++) {
RobMeades 0:0b75e22c9231 197 TEST_ASSERT(*(pData + x) == (x % 10) + 0x30);
RobMeades 0:0b75e22c9231 198 }
RobMeades 0:0b75e22c9231 199
RobMeades 0:0b75e22c9231 200 // Also check that rsp.txt exists and is the same as buf
RobMeades 0:0b75e22c9231 201 pDriver->readFile("rsp.txt", buf1, sizeof (buf1));
RobMeades 0:0b75e22c9231 202 memcmp(buf1, buf, sizeof (buf1));
RobMeades 0:0b75e22c9231 203 TEST_ASSERT(pDriver->delFile("rsp.txt"));
RobMeades 0:0b75e22c9231 204 TEST_ASSERT(!pDriver->delFile("rsp.txt")); // Should fail
RobMeades 0:0b75e22c9231 205
RobMeades 0:0b75e22c9231 206 TEST_ASSERT(pDriver->httpFreeProfile(profile));
RobMeades 0:0b75e22c9231 207 TEST_ASSERT(pDriver->disconnect() == 0);
RobMeades 0:0b75e22c9231 208 // Wait for printfs to leave the building or the test result string gets messed up
RobMeades 0:0b75e22c9231 209 wait_ms(500);
RobMeades 0:0b75e22c9231 210 }
RobMeades 0:0b75e22c9231 211
RobMeades 0:0b75e22c9231 212 // Test HTTP with TLS
RobMeades 0:0b75e22c9231 213 void test_http_tls() {
RobMeades 0:0b75e22c9231 214 int profile;
RobMeades 0:0b75e22c9231 215 SocketAddress address;
RobMeades 0:0b75e22c9231 216
RobMeades 0:0b75e22c9231 217 TEST_ASSERT(pDriver->connect(MBED_CONF_APP_DEFAULT_PIN, MBED_CONF_APP_APN,
RobMeades 0:0b75e22c9231 218 MBED_CONF_APP_USERNAME, MBED_CONF_APP_PASSWORD) == 0);
RobMeades 0:0b75e22c9231 219
RobMeades 0:0b75e22c9231 220 profile = pDriver->httpAllocProfile();
RobMeades 0:0b75e22c9231 221 TEST_ASSERT(profile >= 0);
RobMeades 0:0b75e22c9231 222
RobMeades 0:0b75e22c9231 223 pDriver->httpSetTimeout(profile, HTTP_TIMEOUT);
RobMeades 0:0b75e22c9231 224
RobMeades 0:0b75e22c9231 225 // Set up the server to talk to and TLS, using the IP address this time just for variety
Bilal Qamar 28:4427f2e6bbab 226 TEST_ASSERT(pDriver->gethostbyname("www.amazon.com", &address) == 0);
RobMeades 0:0b75e22c9231 227 TEST_ASSERT(pDriver->httpSetPar(profile, UbloxATCellularInterfaceExt::HTTP_IP_ADDRESS, address.get_ip_address()));
RobMeades 0:0b75e22c9231 228 TEST_ASSERT(pDriver->httpSetPar(profile, UbloxATCellularInterfaceExt::HTTP_SECURE, "1"));
Bilal Qamar 28:4427f2e6bbab 229 TEST_ASSERT(pDriver->httpSetPar(profile, UbloxATCellularInterfaceExt::HTTP_REQ_HEADER, "0:Host:www.amazon.com"));
RobMeades 0:0b75e22c9231 230
RobMeades 0:0b75e22c9231 231 // Check HTTP get request
RobMeades 0:0b75e22c9231 232 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 233 TEST_ASSERT(pDriver->httpCommand(profile, UbloxATCellularInterfaceExt::HTTP_GET,
RobMeades 0:0b75e22c9231 234 "/",
RobMeades 0:0b75e22c9231 235 NULL, NULL, 0, NULL,
RobMeades 0:0b75e22c9231 236 buf, sizeof (buf)) == NULL);
RobMeades 0:0b75e22c9231 237 tr_debug("Received: %s", buf);
RobMeades 0:0b75e22c9231 238 // This is what amazon.com returns if TLS is set
Bilal Qamar 28:4427f2e6bbab 239 TEST_ASSERT(strstr(buf, "HTTP/1.1 200 OK") != NULL);
RobMeades 0:0b75e22c9231 240
RobMeades 0:0b75e22c9231 241 // Reset the profile and check that this now fails
RobMeades 0:0b75e22c9231 242 TEST_ASSERT(pDriver->httpResetProfile(profile));
RobMeades 0:0b75e22c9231 243 TEST_ASSERT(pDriver->httpSetPar(profile, UbloxATCellularInterfaceExt::HTTP_IP_ADDRESS, address.get_ip_address()));
RobMeades 0:0b75e22c9231 244 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 245 TEST_ASSERT(pDriver->httpCommand(profile, UbloxATCellularInterfaceExt::HTTP_GET,
RobMeades 0:0b75e22c9231 246 "/",
RobMeades 0:0b75e22c9231 247 NULL, NULL, 0, NULL,
RobMeades 0:0b75e22c9231 248 buf, sizeof (buf)) == NULL);
RobMeades 0:0b75e22c9231 249 tr_debug("Received: %s", buf);
RobMeades 0:0b75e22c9231 250 // This is what amazon.com returns if TLS is NOT set
Bilal Qamar 28:4427f2e6bbab 251 TEST_ASSERT(strstr(buf, "HTTP/1.1 403 Forbidden") != NULL);
RobMeades 0:0b75e22c9231 252
RobMeades 0:0b75e22c9231 253 TEST_ASSERT(pDriver->httpFreeProfile(profile));
RobMeades 0:0b75e22c9231 254 TEST_ASSERT(pDriver->disconnect() == 0);
RobMeades 0:0b75e22c9231 255 // Wait for printfs to leave the building or the test result string gets messed up
RobMeades 0:0b75e22c9231 256 wait_ms(500);
RobMeades 0:0b75e22c9231 257 }
RobMeades 0:0b75e22c9231 258
RobMeades 0:0b75e22c9231 259 // Allocate max profiles
RobMeades 0:0b75e22c9231 260 void test_alloc_profiles() {
RobMeades 0:0b75e22c9231 261 int profiles[MAX_PROFILES];
RobMeades 0:0b75e22c9231 262
RobMeades 0:0b75e22c9231 263 TEST_ASSERT(pDriver->connect(MBED_CONF_APP_DEFAULT_PIN, MBED_CONF_APP_APN,
RobMeades 0:0b75e22c9231 264 MBED_CONF_APP_USERNAME, MBED_CONF_APP_PASSWORD) == 0);
RobMeades 0:0b75e22c9231 265
RobMeades 0:0b75e22c9231 266 // Allocate first profile and use it
RobMeades 0:0b75e22c9231 267 profiles[0] = pDriver->httpAllocProfile();
RobMeades 0:0b75e22c9231 268 TEST_ASSERT(profiles[0] >= 0);
fahim.alavi@u-blox.com 18:071ae6c6e581 269 TEST_ASSERT(pDriver->httpSetPar(profiles[0], UbloxATCellularInterfaceExt::HTTP_SERVER_NAME, "raw.githubusercontent.com"));
fahim.alavi@u-blox.com 18:071ae6c6e581 270 TEST_ASSERT(pDriver->httpSetPar(profiles[0], UbloxATCellularInterfaceExt::HTTP_SECURE, "1"));
RobMeades 0:0b75e22c9231 271
RobMeades 0:0b75e22c9231 272 // Check HTTP get request
RobMeades 0:0b75e22c9231 273 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 274 TEST_ASSERT(pDriver->httpCommand(profiles[0], UbloxATCellularInterfaceExt::HTTP_GET,
fahim.alavi@u-blox.com 18:071ae6c6e581 275 "/u-blox/mbed-os/master/features/cellular/mbed_lib.json",
RobMeades 0:0b75e22c9231 276 NULL, NULL, 0, NULL,
RobMeades 0:0b75e22c9231 277 buf, sizeof (buf)) == NULL);
RobMeades 0:0b75e22c9231 278 tr_debug("Received: %s", buf);
fahim.alavi@u-blox.com 18:071ae6c6e581 279 TEST_ASSERT(strstr(buf, "Radio access technology to use. Value in integer: GSM=0, GSM_COMPACT=1, UTRAN=2, EGPRS=3, HSDPA=4, HSUPA=5, HSDPA_HSUPA=6, E_UTRAN=7, CATM1=8 ,NB1=9") != NULL);
RobMeades 0:0b75e22c9231 280
RobMeades 0:0b75e22c9231 281 // Check that we stop being able to get profiles at the max number
RobMeades 0:0b75e22c9231 282 for (int x = 1; x < sizeof (profiles) / sizeof (profiles[0]); x++) {
RobMeades 0:0b75e22c9231 283 profiles[x] = pDriver->httpAllocProfile();
RobMeades 0:0b75e22c9231 284 TEST_ASSERT(profiles[0] >= 0);
RobMeades 0:0b75e22c9231 285 }
RobMeades 0:0b75e22c9231 286 TEST_ASSERT(pDriver->httpAllocProfile() < 0);
RobMeades 0:0b75e22c9231 287
RobMeades 0:0b75e22c9231 288 // Now use the last one and check that it doesn't affect the first one
RobMeades 0:0b75e22c9231 289 TEST_ASSERT(pDriver->httpSetPar(profiles[sizeof (profiles) / sizeof (profiles[0]) - 1],
RobMeades 0:0b75e22c9231 290 UbloxATCellularInterfaceExt::HTTP_SERVER_NAME, HTTP_ECHO_SERVER));
RobMeades 0:0b75e22c9231 291
RobMeades 0:0b75e22c9231 292 // Check HTTP head request on last profile
RobMeades 0:0b75e22c9231 293 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 294 TEST_ASSERT(pDriver->httpCommand(profiles[sizeof (profiles) / sizeof (profiles[0]) - 1],
RobMeades 0:0b75e22c9231 295 UbloxATCellularInterfaceExt::HTTP_HEAD,
RobMeades 0:0b75e22c9231 296 "/headers",
RobMeades 0:0b75e22c9231 297 NULL, NULL, 0, NULL,
RobMeades 0:0b75e22c9231 298 buf, sizeof (buf)) == NULL);
RobMeades 0:0b75e22c9231 299 tr_debug("Received: %s", buf);
RobMeades 0:0b75e22c9231 300 TEST_ASSERT(strstr(buf, "Content-Length:") != NULL);
RobMeades 0:0b75e22c9231 301
RobMeades 0:0b75e22c9231 302 // Check HTTP get request on first profile once more
RobMeades 0:0b75e22c9231 303 memset(buf, 0, sizeof (buf));
RobMeades 0:0b75e22c9231 304 TEST_ASSERT(pDriver->httpCommand(profiles[0], UbloxATCellularInterfaceExt::HTTP_GET,
fahim.alavi@u-blox.com 18:071ae6c6e581 305 "/u-blox/mbed-os/master/features/cellular/mbed_lib.json",
RobMeades 0:0b75e22c9231 306 NULL, NULL, 0, NULL,
RobMeades 0:0b75e22c9231 307 buf, sizeof (buf)) == NULL);
RobMeades 0:0b75e22c9231 308 tr_debug("Received: %s", buf);
fahim.alavi@u-blox.com 18:071ae6c6e581 309 TEST_ASSERT(strstr(buf, "Radio access technology to use. Value in integer: GSM=0, GSM_COMPACT=1, UTRAN=2, EGPRS=3, HSDPA=4, HSUPA=5, HSDPA_HSUPA=6, E_UTRAN=7, CATM1=8 ,NB1=9") != NULL);
RobMeades 0:0b75e22c9231 310
RobMeades 0:0b75e22c9231 311 // Free the profiles again
RobMeades 0:0b75e22c9231 312 for (int x = 0; x < sizeof (profiles) / sizeof (profiles[0]); x++) {
RobMeades 0:0b75e22c9231 313 TEST_ASSERT(pDriver->httpFreeProfile(profiles[x]));
RobMeades 0:0b75e22c9231 314 }
RobMeades 0:0b75e22c9231 315
RobMeades 0:0b75e22c9231 316 TEST_ASSERT(pDriver->disconnect() == 0);
RobMeades 0:0b75e22c9231 317 // Wait for printfs to leave the building or the test result string gets messed up
RobMeades 0:0b75e22c9231 318 wait_ms(500);
RobMeades 0:0b75e22c9231 319 }
RobMeades 0:0b75e22c9231 320
RobMeades 0:0b75e22c9231 321 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 322 // TEST ENVIRONMENT
RobMeades 0:0b75e22c9231 323 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 324
RobMeades 0:0b75e22c9231 325 // Setup the test environment
RobMeades 0:0b75e22c9231 326 utest::v1::status_t test_setup(const size_t number_of_cases) {
RobMeades 0:0b75e22c9231 327 // Setup Greentea with a timeout
RobMeades 0:0b75e22c9231 328 GREENTEA_SETUP(540, "default_auto");
RobMeades 0:0b75e22c9231 329 return verbose_test_setup_handler(number_of_cases);
RobMeades 0:0b75e22c9231 330 }
RobMeades 0:0b75e22c9231 331
RobMeades 0:0b75e22c9231 332 // Test cases
RobMeades 0:0b75e22c9231 333 Case cases[] = {
RobMeades 0:0b75e22c9231 334 Case("HTTP commands", test_http_cmd),
rob.meades@u-blox.com 11:3631f62bb359 335 #ifndef TARGET_UBLOX_C027
rob.meades@u-blox.com 11:3631f62bb359 336 // C027 doesn't support TLS
RobMeades 0:0b75e22c9231 337 Case("HTTP with TLS", test_http_tls),
rob.meades@u-blox.com 11:3631f62bb359 338 #endif
RobMeades 0:0b75e22c9231 339 Case("Alloc max profiles", test_alloc_profiles)
RobMeades 0:0b75e22c9231 340 };
RobMeades 0:0b75e22c9231 341
RobMeades 0:0b75e22c9231 342 Specification specification(test_setup, cases);
RobMeades 0:0b75e22c9231 343
RobMeades 0:0b75e22c9231 344 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 345 // MAIN
RobMeades 0:0b75e22c9231 346 // ----------------------------------------------------------------
RobMeades 0:0b75e22c9231 347
RobMeades 0:0b75e22c9231 348 int main() {
rob.meades@u-blox.com 5:9fd89567f769 349
rob.meades@u-blox.com 5:9fd89567f769 350 #ifdef FEATURE_COMMON_PAL
RobMeades 0:0b75e22c9231 351 mbed_trace_init();
RobMeades 0:0b75e22c9231 352
RobMeades 0:0b75e22c9231 353 mbed_trace_mutex_wait_function_set(lock);
RobMeades 0:0b75e22c9231 354 mbed_trace_mutex_release_function_set(unlock);
rob.meades@u-blox.com 5:9fd89567f769 355 #endif
RobMeades 0:0b75e22c9231 356
RobMeades 0:0b75e22c9231 357 // Run tests
RobMeades 0:0b75e22c9231 358 return !Harness::run(specification);
RobMeades 0:0b75e22c9231 359 }
RobMeades 0:0b75e22c9231 360
RobMeades 0:0b75e22c9231 361 // End Of File
RobMeades 0:0b75e22c9231 362