Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
tests/blocking/wiconnect/WiconnectTests.cpp@12:3dd3a1be40c1, 2014-08-13 (annotated)
- Committer:
- dan_ackme
- Date:
- Wed Aug 13 04:42:11 2014 -0700
- Revision:
- 12:3dd3a1be40c1
- Parent:
- 2:2f222449973a
- Child:
- 22:26420b641605
updated copyright
Who changed what in which revision?
| User | Revision | Line number | New contents of line |
|---|---|---|---|
| dan_ackme | 12:3dd3a1be40c1 | 1 | /** |
| dan_ackme | 12:3dd3a1be40c1 | 2 | * ACKme WiConnect Host Library is licensed under the BSD licence: |
| dan_ackme | 12:3dd3a1be40c1 | 3 | * |
| dan_ackme | 12:3dd3a1be40c1 | 4 | * Copyright (c)2014 ACKme Networks. |
| dan_ackme | 12:3dd3a1be40c1 | 5 | * All rights reserved. |
| dan_ackme | 12:3dd3a1be40c1 | 6 | * |
| dan_ackme | 12:3dd3a1be40c1 | 7 | * Redistribution and use in source and binary forms, with or without modification, |
| dan_ackme | 12:3dd3a1be40c1 | 8 | * are permitted provided that the following conditions are met: |
| dan_ackme | 12:3dd3a1be40c1 | 9 | * |
| dan_ackme | 12:3dd3a1be40c1 | 10 | * 1. Redistributions of source code must retain the above copyright notice, |
| dan_ackme | 12:3dd3a1be40c1 | 11 | * this list of conditions and the following disclaimer. |
| dan_ackme | 12:3dd3a1be40c1 | 12 | * 2. Redistributions in binary form must reproduce the above copyright notice, |
| dan_ackme | 12:3dd3a1be40c1 | 13 | * this list of conditions and the following disclaimer in the documentation |
| dan_ackme | 12:3dd3a1be40c1 | 14 | * and/or other materials provided with the distribution. |
| dan_ackme | 12:3dd3a1be40c1 | 15 | * 3. The name of the author may not be used to endorse or promote products |
| dan_ackme | 12:3dd3a1be40c1 | 16 | * derived from this software without specific prior written permission. |
| dan_ackme | 12:3dd3a1be40c1 | 17 | * |
| dan_ackme | 12:3dd3a1be40c1 | 18 | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS AND ANY EXPRESS OR IMPLIED |
| dan_ackme | 12:3dd3a1be40c1 | 19 | * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
| dan_ackme | 12:3dd3a1be40c1 | 20 | * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT |
| dan_ackme | 12:3dd3a1be40c1 | 21 | * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
| dan_ackme | 12:3dd3a1be40c1 | 22 | * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT |
| dan_ackme | 12:3dd3a1be40c1 | 23 | * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| dan_ackme | 12:3dd3a1be40c1 | 24 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
| dan_ackme | 12:3dd3a1be40c1 | 25 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING |
| dan_ackme | 12:3dd3a1be40c1 | 26 | * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY |
| dan_ackme | 12:3dd3a1be40c1 | 27 | * OF SUCH DAMAGE. |
| dan_ackme | 0:836c9a6383e0 | 28 | */ |
| dan_ackme | 0:836c9a6383e0 | 29 | |
| dan_ackme | 0:836c9a6383e0 | 30 | #include "tests/Tests.h" |
| dan_ackme | 0:836c9a6383e0 | 31 | #include "Wiconnect.h" |
| dan_ackme | 0:836c9a6383e0 | 32 | |
| dan_ackme | 0:836c9a6383e0 | 33 | |
| dan_ackme | 0:836c9a6383e0 | 34 | #define TIMEOUT 10000 // ms |
| dan_ackme | 0:836c9a6383e0 | 35 | |
| dan_ackme | 0:836c9a6383e0 | 36 | |
| dan_ackme | 0:836c9a6383e0 | 37 | static volatile bool wiconnectNonBlockingCommandFinished = false; |
| dan_ackme | 0:836c9a6383e0 | 38 | |
| dan_ackme | 0:836c9a6383e0 | 39 | |
| dan_ackme | 0:836c9a6383e0 | 40 | |
| dan_ackme | 0:836c9a6383e0 | 41 | /*************************************************************************************************/ |
| dan_ackme | 0:836c9a6383e0 | 42 | WiconnectResult wiconnectSendRawBlockingCommand(int argc, char **argv) |
| dan_ackme | 0:836c9a6383e0 | 43 | { |
| dan_ackme | 0:836c9a6383e0 | 44 | WiconnectResult result; |
| dan_ackme | 0:836c9a6383e0 | 45 | Wiconnect *wiconnect = Wiconnect::getInstance(); |
| dan_ackme | 0:836c9a6383e0 | 46 | |
| dan_ackme | 0:836c9a6383e0 | 47 | strcpy(testBuffer, argv[0]); |
| dan_ackme | 0:836c9a6383e0 | 48 | --argc; |
| dan_ackme | 0:836c9a6383e0 | 49 | ++argv; |
| dan_ackme | 0:836c9a6383e0 | 50 | |
| dan_ackme | 0:836c9a6383e0 | 51 | while(argc--) |
| dan_ackme | 0:836c9a6383e0 | 52 | { |
| dan_ackme | 0:836c9a6383e0 | 53 | strcat(testBuffer, " "); |
| dan_ackme | 0:836c9a6383e0 | 54 | strcat(testBuffer, argv[0]); |
| dan_ackme | 0:836c9a6383e0 | 55 | ++argv; |
| dan_ackme | 0:836c9a6383e0 | 56 | } |
| dan_ackme | 0:836c9a6383e0 | 57 | |
| dan_ackme | 0:836c9a6383e0 | 58 | if(!WICONNECT_FAILED(result, wiconnect->sendCommand(TIMEOUT, testBuffer, TEST_BUFFER_LENGTH, testBuffer))) |
| dan_ackme | 0:836c9a6383e0 | 59 | { |
| dan_ackme | 0:836c9a6383e0 | 60 | LOG_INFO_WRITE_STR("Response:\r\n", wiconnect->getResponseBuffer()); |
| dan_ackme | 0:836c9a6383e0 | 61 | } |
| dan_ackme | 0:836c9a6383e0 | 62 | |
| dan_ackme | 0:836c9a6383e0 | 63 | return result; |
| dan_ackme | 0:836c9a6383e0 | 64 | } |
| dan_ackme | 0:836c9a6383e0 | 65 | |
| dan_ackme | 0:836c9a6383e0 | 66 | |
| dan_ackme | 0:836c9a6383e0 | 67 | |
| dan_ackme | 0:836c9a6383e0 | 68 | /*************************************************************************************************/ |
| dan_ackme | 0:836c9a6383e0 | 69 | static void responseHandler(WiconnectResult result, void *response, void *responseLen) |
| dan_ackme | 0:836c9a6383e0 | 70 | { |
| dan_ackme | 0:836c9a6383e0 | 71 | Wiconnect *wiconnect = Wiconnect::getInstance(); |
| dan_ackme | 0:836c9a6383e0 | 72 | |
| dan_ackme | 0:836c9a6383e0 | 73 | wiconnectNonBlockingCommandFinished = true; |
| dan_ackme | 0:836c9a6383e0 | 74 | |
| dan_ackme | 0:836c9a6383e0 | 75 | if(result == WICONNECT_SUCCESS) |
| dan_ackme | 0:836c9a6383e0 | 76 | { |
| dan_ackme | 0:836c9a6383e0 | 77 | LOG_INFO_WRITE_STR("Non-blocking Response:\r\n", (const char*)response); |
| dan_ackme | 0:836c9a6383e0 | 78 | } |
| dan_ackme | 0:836c9a6383e0 | 79 | else |
| dan_ackme | 0:836c9a6383e0 | 80 | { |
| dan_ackme | 0:836c9a6383e0 | 81 | LOG_WICONNECT_ERROR(result, "Non-blocking command failed"); |
| dan_ackme | 0:836c9a6383e0 | 82 | } |
| dan_ackme | 0:836c9a6383e0 | 83 | } |
| dan_ackme | 0:836c9a6383e0 | 84 | |
| dan_ackme | 0:836c9a6383e0 | 85 | /*************************************************************************************************/ |
| dan_ackme | 0:836c9a6383e0 | 86 | WiconnectResult wiconnectSendRawNonBlockingCommand(int argc, char **argv) |
| dan_ackme | 0:836c9a6383e0 | 87 | { |
| dan_ackme | 0:836c9a6383e0 | 88 | WiconnectResult result; |
| dan_ackme | 0:836c9a6383e0 | 89 | Wiconnect *wiconnect = Wiconnect::getInstance(); |
| dan_ackme | 0:836c9a6383e0 | 90 | |
| dan_ackme | 0:836c9a6383e0 | 91 | strcpy(testBuffer, argv[0]); |
| dan_ackme | 0:836c9a6383e0 | 92 | --argc; |
| dan_ackme | 0:836c9a6383e0 | 93 | ++argv; |
| dan_ackme | 0:836c9a6383e0 | 94 | |
| dan_ackme | 0:836c9a6383e0 | 95 | while(argc--) |
| dan_ackme | 0:836c9a6383e0 | 96 | { |
| dan_ackme | 0:836c9a6383e0 | 97 | strcat(testBuffer, " "); |
| dan_ackme | 0:836c9a6383e0 | 98 | strcat(testBuffer, argv[0]); |
| dan_ackme | 0:836c9a6383e0 | 99 | ++argv; |
| dan_ackme | 0:836c9a6383e0 | 100 | } |
| dan_ackme | 0:836c9a6383e0 | 101 | |
| dan_ackme | 0:836c9a6383e0 | 102 | wiconnectNonBlockingCommandFinished = false; |
| dan_ackme | 0:836c9a6383e0 | 103 | if(WICONNECT_FAILED(result, wiconnect->sendCommand(Callback(responseHandler), testBuffer, TEST_BUFFER_LENGTH, TIMEOUT, testBuffer))) |
| dan_ackme | 0:836c9a6383e0 | 104 | { |
| dan_ackme | 0:836c9a6383e0 | 105 | } |
| dan_ackme | 0:836c9a6383e0 | 106 | else if(!wiconnectNonBlockingCommandFinished) |
| dan_ackme | 0:836c9a6383e0 | 107 | { |
| dan_ackme | 0:836c9a6383e0 | 108 | LOG_INFO("Non-blocking command processing..."); |
| dan_ackme | 0:836c9a6383e0 | 109 | } |
| dan_ackme | 0:836c9a6383e0 | 110 | |
| dan_ackme | 0:836c9a6383e0 | 111 | return result; |
| dan_ackme | 0:836c9a6383e0 | 112 | } |
| dan_ackme | 0:836c9a6383e0 | 113 | |
| dan_ackme | 0:836c9a6383e0 | 114 | /*************************************************************************************************/ |
| dan_ackme | 0:836c9a6383e0 | 115 | WiconnectResult wiconnectGetVersionCommand(int argc, char **argv) |
| dan_ackme | 0:836c9a6383e0 | 116 | { |
| dan_ackme | 0:836c9a6383e0 | 117 | WiconnectResult result; |
| dan_ackme | 0:836c9a6383e0 | 118 | Wiconnect *wiconnect = Wiconnect::getInstance(); |
| dan_ackme | 0:836c9a6383e0 | 119 | |
| dan_ackme | 0:836c9a6383e0 | 120 | if(!WICONNECT_FAILED(result, wiconnect->getVersion(testBuffer, sizeof(testBuffer)))) |
| dan_ackme | 0:836c9a6383e0 | 121 | { |
| dan_ackme | 0:836c9a6383e0 | 122 | LOG_INFO("Version: %s", testBuffer); |
| dan_ackme | 0:836c9a6383e0 | 123 | } |
| dan_ackme | 0:836c9a6383e0 | 124 | return result; |
| dan_ackme | 0:836c9a6383e0 | 125 | } |
| dan_ackme | 0:836c9a6383e0 | 126 | |
| dan_ackme | 0:836c9a6383e0 | 127 | /*************************************************************************************************/ |
| dan_ackme | 0:836c9a6383e0 | 128 | WiconnectResult wiconnectDebugEnableCommand(int argc, char **argv) |
| dan_ackme | 0:836c9a6383e0 | 129 | { |
| dan_ackme | 0:836c9a6383e0 | 130 | extern int wiconnectLogDebug(const char *str); |
| dan_ackme | 0:836c9a6383e0 | 131 | Wiconnect *wiconnect = Wiconnect::getInstance(); |
| dan_ackme | 0:836c9a6383e0 | 132 | bool enabled; |
| dan_ackme | 0:836c9a6383e0 | 133 | |
| dan_ackme | 0:836c9a6383e0 | 134 | if(!StringUtil::parseBool(argv[0], &enabled)) |
| dan_ackme | 0:836c9a6383e0 | 135 | { |
| dan_ackme | 0:836c9a6383e0 | 136 | return WICONNECT_BAD_ARG; |
| dan_ackme | 0:836c9a6383e0 | 137 | } |
| dan_ackme | 0:836c9a6383e0 | 138 | |
| dan_ackme | 0:836c9a6383e0 | 139 | if(enabled) |
| dan_ackme | 0:836c9a6383e0 | 140 | { |
| dan_ackme | 0:836c9a6383e0 | 141 | wiconnect->setDebugLogger(LogFunc(wiconnectLogDebug)); |
| dan_ackme | 0:836c9a6383e0 | 142 | LOG_INFO("WiConnet debugging enabled"); |
| dan_ackme | 0:836c9a6383e0 | 143 | } |
| dan_ackme | 0:836c9a6383e0 | 144 | else |
| dan_ackme | 0:836c9a6383e0 | 145 | { |
| dan_ackme | 0:836c9a6383e0 | 146 | wiconnect->setDebugLogger(LogFunc()); |
| dan_ackme | 0:836c9a6383e0 | 147 | LOG_INFO("WiConnet debugging disabled"); |
| dan_ackme | 0:836c9a6383e0 | 148 | } |
| dan_ackme | 0:836c9a6383e0 | 149 | |
| dan_ackme | 0:836c9a6383e0 | 150 | return WICONNECT_SUCCESS; |
| dan_ackme | 0:836c9a6383e0 | 151 | } |