1
0
mirror of https://github.com/esp8266/Arduino.git synced 2025-04-22 21:23:07 +03:00
esp8266/tests/device/test_ClientContext/test_ClientContext.ino
david gauchard d5cbd91775 device test for #4516 (WiFiClient leaking) (#4549)
* device test for #4516 (WiFiClient leaking)

* simply count the number of connections that do not change heap

* remove unused heapLost

* + python server (to not depend on gateway's opened tcp port)

* remove old&bad define

* fix another old address
2018-03-23 11:30:59 -03:00

95 lines
2.0 KiB
C++

#include <Arduino.h>
#include <BSTest.h>
#include <test_config.h>
#include <ESP8266WiFi.h>
extern "C" {
#include "user_interface.h"
}
BS_ENV_DECLARE();
// no need for #include
struct tcp_pcb;
extern struct tcp_pcb* tcp_tw_pcbs;
extern "C" void tcp_abort (struct tcp_pcb* pcb);
void tcpCleanup (void)
{
while (tcp_tw_pcbs)
tcp_abort(tcp_tw_pcbs);
}
void setup()
{
Serial.begin(115200);
Serial.setDebugOutput(true);
WiFi.persistent(false);
WiFi.mode(WIFI_STA);
WiFi.begin(STA_SSID, STA_PASS);
while (WiFi.status() != WL_CONNECTED) {
delay(500);
}
BS_RUN(Serial);
}
TEST_CASE("WiFi release ClientContext", "[clientcontext]")
{
#define MAXLOOPS 50
#define SUCCESS_GOAL 10
#define srv SERVER_IP
WiFiClient client;
Serial.print(srv);
// look for reachable port on gateway
int port;
for (port = 8266; port <= 8285; port++)
if (client.connect(srv, port))
{
client.stop();
break;
}
if (port > 8285)
port = 0;
Serial.printf(":%d\r\n", port);
int loops = 0;
int success = 0;
if (port)
{
tcpCleanup();
int heapStart = ESP.getFreeHeap();
int minHeap = heapStart / 2;
int heap = heapStart;
Serial.printf("heap: %d\r\n", heap);
while (success < SUCCESS_GOAL && ++loops <= MAXLOOPS && (int)ESP.getFreeHeap() > minHeap)
if (client.connect(srv, port))
{
client.stop();
tcpCleanup();
int newHeap = (int)ESP.getFreeHeap();
Serial.printf("%03d %5d %d\r\n", loops, newHeap, newHeap - heap);
if (newHeap - heap == 0)
success++;
heap = newHeap;
}
Serial.printf("heap: %d\r\n"
"loops: %d\r\nstable-loops: %d\r\n",
ESP.getFreeHeap(),
loops,
success);
}
REQUIRE(success >= SUCCESS_GOAL);
}
void loop()
{
}