ACKme / Mbed 2 deprecated wiconnect-test-console

Dependencies:   WiConnect mbed

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?

UserRevisionLine numberNew 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 }