ACKme / Mbed 2 deprecated wiconnect-test-console

Dependencies:   WiConnect mbed

Committer:
dan_ackme
Date:
Mon Aug 11 04:53:00 2014 -0700
Revision:
2:2f222449973a
Parent:
1:5137ec8f4c45
Child:
3:dddd476d5967
warning fixes

Who changed what in which revision?

UserRevisionLine numberNew contents of line
dan_ackme 0:836c9a6383e0 1 /*
dan_ackme 0:836c9a6383e0 2 * Copyright 2014, ACKme Networks
dan_ackme 0:836c9a6383e0 3 * All Rights Reserved.
dan_ackme 0:836c9a6383e0 4 *
dan_ackme 0:836c9a6383e0 5 * This is UNPUBLISHED PROPRIETARY SOURCE CODE of ACKme Networks;
dan_ackme 0:836c9a6383e0 6 * the contents of this file may not be disclosed to third parties, copied
dan_ackme 0:836c9a6383e0 7 * or duplicated in any form, in whole or in part, without the prior
dan_ackme 0:836c9a6383e0 8 * written permission of ACKme Networks.
dan_ackme 0:836c9a6383e0 9 */
dan_ackme 0:836c9a6383e0 10
dan_ackme 0:836c9a6383e0 11
dan_ackme 0:836c9a6383e0 12 #include "tests/Tests.h"
dan_ackme 0:836c9a6383e0 13 #include "Wiconnect.h"
dan_ackme 0:836c9a6383e0 14
dan_ackme 0:836c9a6383e0 15
dan_ackme 0:836c9a6383e0 16
dan_ackme 0:836c9a6383e0 17 static WiconnectResult processData(Socket &socket, uint32_t count, uint32_t delay, uint32_t size);
dan_ackme 0:836c9a6383e0 18
dan_ackme 0:836c9a6383e0 19
dan_ackme 0:836c9a6383e0 20
dan_ackme 0:836c9a6383e0 21 /*************************************************************************************************/
dan_ackme 0:836c9a6383e0 22 WiconnectResult socketTcpClientEchoCommand(int argc, char **argv)
dan_ackme 0:836c9a6383e0 23 {
dan_ackme 0:836c9a6383e0 24 WiconnectResult result;
dan_ackme 0:836c9a6383e0 25 Wiconnect *wiconnect = Wiconnect::getInstance();
dan_ackme 0:836c9a6383e0 26 Socket socket(sizeof(testBuffer)/2, testBuffer, sizeof(testBuffer)/2, testBuffer + sizeof(testBuffer)/2);
dan_ackme 0:836c9a6383e0 27 const char *host;
dan_ackme 0:836c9a6383e0 28 uint32_t port;
dan_ackme 0:836c9a6383e0 29 uint32_t delay = 5;
dan_ackme 0:836c9a6383e0 30 uint32_t count = 1000;
dan_ackme 0:836c9a6383e0 31 uint32_t size = 256;
dan_ackme 0:836c9a6383e0 32
dan_ackme 0:836c9a6383e0 33 if(argc < 2)
dan_ackme 0:836c9a6383e0 34 {
dan_ackme 0:836c9a6383e0 35 LOG_ERROR("Must specify host and port");
dan_ackme 0:836c9a6383e0 36 return WICONNECT_BAD_ARG;
dan_ackme 0:836c9a6383e0 37 }
dan_ackme 0:836c9a6383e0 38 host = argv[0];
dan_ackme 0:836c9a6383e0 39
dan_ackme 0:836c9a6383e0 40 if(!StringUtil::strToUint32((const char*)argv[1], &port))
dan_ackme 0:836c9a6383e0 41 {
dan_ackme 0:836c9a6383e0 42 LOG_ERROR("Invalid port");
dan_ackme 0:836c9a6383e0 43 return WICONNECT_BAD_ARG;
dan_ackme 0:836c9a6383e0 44 }
dan_ackme 0:836c9a6383e0 45 if(argc > 2 && !StringUtil::strToUint32((const char*)argv[2], &count))
dan_ackme 0:836c9a6383e0 46 {
dan_ackme 0:836c9a6383e0 47 LOG_ERROR("Invalid packet count");
dan_ackme 0:836c9a6383e0 48 return WICONNECT_BAD_ARG;
dan_ackme 0:836c9a6383e0 49 }
dan_ackme 0:836c9a6383e0 50 if(argc > 3 && !StringUtil::strToUint32((const char*)argv[3], &delay))
dan_ackme 0:836c9a6383e0 51 {
dan_ackme 0:836c9a6383e0 52 LOG_ERROR("Invalid packet delay");
dan_ackme 0:836c9a6383e0 53 return WICONNECT_BAD_ARG;
dan_ackme 0:836c9a6383e0 54 }
dan_ackme 0:836c9a6383e0 55 if(argc > 4 && (!StringUtil::strToUint32((const char*)argv[4], &size) || size > sizeof(testBuffer)/2))
dan_ackme 0:836c9a6383e0 56 {
dan_ackme 0:836c9a6383e0 57 LOG_ERROR("Invalid packet size");
dan_ackme 0:836c9a6383e0 58 return WICONNECT_BAD_ARG;
dan_ackme 0:836c9a6383e0 59 }
dan_ackme 0:836c9a6383e0 60
dan_ackme 0:836c9a6383e0 61 if(WICONNECT_FAILED(result, wiconnect->tcpConnect(socket, host, port)))
dan_ackme 0:836c9a6383e0 62 {
dan_ackme 0:836c9a6383e0 63 LOG_ERROR("Failed to connect to server");
dan_ackme 0:836c9a6383e0 64 }
dan_ackme 0:836c9a6383e0 65 else
dan_ackme 0:836c9a6383e0 66 {
dan_ackme 0:836c9a6383e0 67 result = processData(socket, count, delay, size);
dan_ackme 0:836c9a6383e0 68 }
dan_ackme 0:836c9a6383e0 69
dan_ackme 0:836c9a6383e0 70 return result;
dan_ackme 0:836c9a6383e0 71 }
dan_ackme 0:836c9a6383e0 72
dan_ackme 0:836c9a6383e0 73
dan_ackme 0:836c9a6383e0 74 /*************************************************************************************************/
dan_ackme 0:836c9a6383e0 75 static WiconnectResult processData(Socket &socket, uint32_t count, uint32_t delay, uint32_t size)
dan_ackme 0:836c9a6383e0 76 {
dan_ackme 2:2f222449973a 77 WiconnectResult result = WICONNECT_ERROR;
dan_ackme 0:836c9a6383e0 78 uint8_t *txBuffer = socket.getTxBuffer();
dan_ackme 0:836c9a6383e0 79 const int txBufferLen = socket.getTxBufferSize();
dan_ackme 0:836c9a6383e0 80 uint8_t writeCounter = 32;
dan_ackme 0:836c9a6383e0 81 uint8_t readCounter = 32;
dan_ackme 0:836c9a6383e0 82 uint32_t bytesSent = 0;
dan_ackme 0:836c9a6383e0 83 uint32_t bytesReceived = 0;
dan_ackme 0:836c9a6383e0 84
dan_ackme 0:836c9a6383e0 85 LOG_INFO("\r\n------------------\r\n"
dan_ackme 0:836c9a6383e0 86 "Starting TCP Echo Test:\r\n"
dan_ackme 0:836c9a6383e0 87 "Packet count: %d\r\n"
dan_ackme 0:836c9a6383e0 88 "Packet size: %d\r\n"
dan_ackme 0:836c9a6383e0 89 "Packet delay: %d\r\n"
dan_ackme 0:836c9a6383e0 90 "(Press any key to terminate)",
dan_ackme 0:836c9a6383e0 91 count, size, delay);
dan_ackme 0:836c9a6383e0 92
dan_ackme 0:836c9a6383e0 93 for(int i = 0; i < count || bytesReceived < bytesSent; ++i)
dan_ackme 0:836c9a6383e0 94 {
dan_ackme 0:836c9a6383e0 95 if(i < count)
dan_ackme 0:836c9a6383e0 96 {
dan_ackme 0:836c9a6383e0 97 uint8_t *ptr = txBuffer;
dan_ackme 0:836c9a6383e0 98 int l = size;
dan_ackme 0:836c9a6383e0 99 while(l--)
dan_ackme 0:836c9a6383e0 100 {
dan_ackme 0:836c9a6383e0 101 *ptr++ = writeCounter++;
dan_ackme 0:836c9a6383e0 102 if(writeCounter == 128)
dan_ackme 0:836c9a6383e0 103 writeCounter = 32;
dan_ackme 0:836c9a6383e0 104 }
dan_ackme 0:836c9a6383e0 105
dan_ackme 0:836c9a6383e0 106 if(WICONNECT_FAILED(result, socket.write(size)))
dan_ackme 0:836c9a6383e0 107 {
dan_ackme 0:836c9a6383e0 108 break;
dan_ackme 0:836c9a6383e0 109 }
dan_ackme 0:836c9a6383e0 110 bytesSent += size;
dan_ackme 0:836c9a6383e0 111 consoleSerial.putc('.');
dan_ackme 0:836c9a6383e0 112 }
dan_ackme 0:836c9a6383e0 113
dan_ackme 0:836c9a6383e0 114 if(consoleSerial.readable())
dan_ackme 0:836c9a6383e0 115 {
dan_ackme 0:836c9a6383e0 116 int c = consoleSerial.getc();
dan_ackme 0:836c9a6383e0 117 break;
dan_ackme 0:836c9a6383e0 118 }
dan_ackme 0:836c9a6383e0 119
dan_ackme 0:836c9a6383e0 120 delayMs(delay);
dan_ackme 0:836c9a6383e0 121
dan_ackme 0:836c9a6383e0 122 uint8_t *readPtr;
dan_ackme 0:836c9a6383e0 123 uint16_t readLen;
dan_ackme 0:836c9a6383e0 124 if(WICONNECT_FAILED(result, socket.read(&readPtr, &readLen)))
dan_ackme 0:836c9a6383e0 125 {
dan_ackme 0:836c9a6383e0 126 break;
dan_ackme 0:836c9a6383e0 127 }
dan_ackme 0:836c9a6383e0 128 bytesReceived += readLen;
dan_ackme 0:836c9a6383e0 129
dan_ackme 0:836c9a6383e0 130 while(readLen--)
dan_ackme 0:836c9a6383e0 131 {
dan_ackme 0:836c9a6383e0 132 if(*readPtr != readCounter)
dan_ackme 0:836c9a6383e0 133 {
dan_ackme 0:836c9a6383e0 134 LOG_ERROR("Invalid: %02X != %02X", *readPtr, readCounter);
dan_ackme 0:836c9a6383e0 135 }
dan_ackme 0:836c9a6383e0 136 ++readPtr;
dan_ackme 0:836c9a6383e0 137 ++readCounter;
dan_ackme 0:836c9a6383e0 138 if(readCounter == 128)
dan_ackme 0:836c9a6383e0 139 readCounter = 32;
dan_ackme 0:836c9a6383e0 140 }
dan_ackme 0:836c9a6383e0 141 }
dan_ackme 0:836c9a6383e0 142
dan_ackme 0:836c9a6383e0 143 consoleSerial.write("\r\n");
dan_ackme 0:836c9a6383e0 144 LOG_INFO("------------------\r\n"
dan_ackme 0:836c9a6383e0 145 "TCP Echo Test Complete:\r\n"
dan_ackme 0:836c9a6383e0 146 "Bytes sent: %d\r\n"
dan_ackme 0:836c9a6383e0 147 "Bytes received: %d\r\n",
dan_ackme 0:836c9a6383e0 148 bytesSent, bytesReceived);
dan_ackme 0:836c9a6383e0 149
dan_ackme 0:836c9a6383e0 150 return result;
dan_ackme 0:836c9a6383e0 151 }