5.2.1 - Updated I2C files
Dependents: mbed-TFT-example-NCS36510 mbed-Accelerometer-example-NCS36510 mbed-Accelerometer-example-NCS36510
TESTS/network/wifi/main.cpp
- Committer:
- jacobjohnson
- Date:
- 2017-02-27
- Revision:
- 1:f30bdcd2b33b
- Parent:
- 0:098463de4c5d
File content as of revision 1:f30bdcd2b33b:
/* mbed Microcontroller Library * Copyright (c) 2016 ARM Limited * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "utest/utest.h" #include "unity/unity.h" #include "greentea-client/test_env.h" #include "mbed.h" #if TARGET_UBLOX_EVK_ODIN_W2 #include "OdinWiFiInterface.h" #else #error [NOT_SUPPORTED] Only built in WiFi modules are supported at this time. #endif using namespace utest::v1; /** * WiFi tests require following macros to be defined: * - MBED_CONF_APP_WIFI_SSID - SSID of a network the test will try connecting to * - MBED_CONF_APP_WIFI_PASSWORD - Passphrase that will be used to connecting to the network * - WIFI_TEST_NETWORKS - List of network that presence will be asserted e.g. "net1", "net2", "net3" */ #if !defined(MBED_CONF_APP_WIFI_SSID) || !defined(MBED_CONF_APP_WIFI_PASSWORD) || !defined(MBED_CONF_APP_WIFI_NETWORKS) #error [NOT_SUPPORTED] MBED_CONF_APP_WIFI_SSID, MBED_CONF_APP_WIFI_PASSWORD and MBED_CONF_APP_WIFI_NETWORKS have to be defined for this test. #endif const char *networks[] = {MBED_CONF_APP_WIFI_NETWORKS, NULL}; WiFiInterface *wifi; /* In normal circumstances the WiFi object could be global, but the delay introduced by WiFi initialization is an issue for the tests. It causes Greentea to timeout on syncing with the board. To solve it we defer the actual object creation till we actually need it. */ WiFiInterface *get_wifi() { if (wifi == NULL) { /* We don't really care about freeing this, as its lifetime is through the full test suit run. */ #if TARGET_UBLOX_EVK_ODIN_W2 wifi = new OdinWiFiInterface; #endif } return wifi; } void check_wifi(const char *ssid, bool *net_stat) { int i = 0; while(networks[i]) { if (strcmp(networks[i], ssid) == 0) { net_stat[i] = true; break; } i++; } } void wifi_scan() { int count; WiFiAccessPoint *aps; const int net_len = sizeof(networks)/sizeof(networks[0]); bool net_stat[net_len - 1]; memset(net_stat, 0, sizeof(net_stat)); count = get_wifi()->scan(NULL, 0); TEST_ASSERT_MESSAGE(count >= 0, "WiFi interface returned error"); TEST_ASSERT_MESSAGE(count > 0, "Scan result empty"); aps = new WiFiAccessPoint[count]; count = get_wifi()->scan(aps, count); for(int i = 0; i < count; i++) { check_wifi(aps[i].get_ssid(), net_stat); } delete[] aps; for (unsigned i = 0; i < sizeof(net_stat); i++) { TEST_ASSERT_MESSAGE(net_stat[i] == true, "Not all required WiFi network detected"); } } void wifi_connect() { int ret; ret = get_wifi()->connect(MBED_CONF_APP_WIFI_SSID, MBED_CONF_APP_WIFI_PASSWORD, NSAPI_SECURITY_WPA_WPA2); TEST_ASSERT_MESSAGE(ret == 0, "Connect failed"); ret = get_wifi()->disconnect(); TEST_ASSERT_MESSAGE(ret == 0, "Disconnect failed"); } void wifi_connect_scan() { int ret; int count; WiFiAccessPoint *aps; const int net_len = sizeof(networks)/sizeof(networks[0]); bool net_stat[net_len - 1]; memset(net_stat, 0, sizeof(net_stat)); ret = get_wifi()->connect(MBED_CONF_APP_WIFI_SSID, MBED_CONF_APP_WIFI_PASSWORD, NSAPI_SECURITY_WPA_WPA2); TEST_ASSERT_MESSAGE(ret == 0, "Connect failed"); count = get_wifi()->scan(NULL, 0); TEST_ASSERT_MESSAGE(count >= 0, "WiFi interface returned error"); TEST_ASSERT_MESSAGE(count > 0, "Scan result empty"); aps = new WiFiAccessPoint[count]; count = get_wifi()->scan(aps, count); for(int i = 0; i < count; i++) { check_wifi(aps[i].get_ssid(), net_stat); } delete[] aps; ret = get_wifi()->disconnect(); TEST_ASSERT_MESSAGE(ret == 0, "Disconnect failed"); for (unsigned i = 0; i < sizeof(net_stat); i++) { TEST_ASSERT_MESSAGE(net_stat[i] == true, "Not all required WiFi network detected"); } } void wifi_http() { TCPSocket socket; int ret; ret = get_wifi()->connect(MBED_CONF_APP_WIFI_SSID, MBED_CONF_APP_WIFI_PASSWORD, NSAPI_SECURITY_WPA_WPA2); TEST_ASSERT_MESSAGE(ret == 0, "Connect failed"); // Open a socket on the network interface, and create a TCP connection to www.arm.com ret = socket.open(get_wifi()); TEST_ASSERT_MESSAGE(ret == 0, "Socket open failed"); ret = socket.connect("www.arm.com", 80); TEST_ASSERT_MESSAGE(ret == 0, "Socket connect failed"); // Send a simple http request char sbuffer[] = "GET / HTTP/1.1\r\nHost: www.arm.com\r\n\r\n"; int scount = socket.send(sbuffer, sizeof sbuffer); TEST_ASSERT_MESSAGE(scount >= 0, "Socket send failed"); // Recieve a simple http response and check if it's not empty char rbuffer[64]; int rcount = socket.recv(rbuffer, sizeof rbuffer); TEST_ASSERT_MESSAGE(rcount >= 0, "Socket recv error"); TEST_ASSERT_MESSAGE(rcount > 0, "No data received"); ret = socket.close(); TEST_ASSERT_MESSAGE(ret == 0, "Socket close failed"); ret = get_wifi()->disconnect(); TEST_ASSERT_MESSAGE(ret == 0, "Disconnect failed"); } status_t greentea_failure_handler(const Case *const source, const failure_t reason) { greentea_case_failure_abort_handler(source, reason); return STATUS_CONTINUE; } Case cases[] = { Case("Scan test", wifi_scan, greentea_failure_handler), Case("Connect test", wifi_connect, greentea_failure_handler), Case("Scan while connected test", wifi_connect_scan, greentea_failure_handler), Case("HTTP test", wifi_http, greentea_failure_handler), }; status_t greentea_test_setup(const size_t number_of_cases) { GREENTEA_SETUP(90, "default_auto"); return greentea_test_setup_handler(number_of_cases); } int main() { Specification specification(greentea_test_setup, cases, greentea_test_teardown_handler); Harness::run(specification); }