5.10.0 20171201 * Upgrade library ArduinoJson to 5.11.2 * Upgrade library IRRemoteEsp8266 to 2.2.1 + 2 commits but disabled some protocols (code size reduction) * Upgrade library NeoPixelBus to 2.2.9 * Upgrade library OneWire to 2.3.3 + 6 commits and disabled CRC lookup-table (#define ONEWIRE_CRC8_TABLE 0) (code size reduction) * Update library PubSubClient to 2.6 + 9 commits and additional delay (#790) * Update core_esp8266_wiring_digital.c to latest (staged) level * Patch library I2Cdevlib-Core for esp8266-core 2.4.0-rc2 compatibility * Remove command EnergyReset 1..3 now replaced by ENergyReset1 to EnergyReset3 * Remove spaces in JSON messages (code size reduction) * Renamed xsns_05_ds18x20.ino to xsns_05_ds18x20_legacy.ino still using library OneWire and providing dynamic sensor scan * Fix possible iram1_0_seg compile error by shrinking ICACHE_RAM_ATTR code usage * Fix PWM watchdog timeout if Dimmer is set to 100 or Color set to 0xFF (#1146) * Fix Sonoff Bridge Learn Mode hang caused by unrecognised RF code (#1181) * Fix blank console log window by using XML character encoding (#1187) * Fix wrong response name for command HlwISet (#1214) * Fix DHT type sensor timeout recognition by distinguish "signal already there" from "timeout" (#1233) * Add fixed color options 1..12 to command Color * Add + (plus) and - (minus) to commands Dimmer (+10/-10), Speed and Scheme * Add + (plus) and - (minus) to command Color to select 1 out of 12 preset colors * Add + (plus) and - (minus) to command Ct to control ColdWarm led ColorTemperature (+34/-34) * Add commands EnergyReset1 0..42500, EnergyReset2 0..42500 and EnergyReset3 0..42500000 * to (Re)set Energy Today, Yesterday or Total respectively in Wh (#406, #685, #1202) * Add optional ADS1115 driver as alternative for unsupported I2Cdevlib in esp8266-core 2.4.0-rc2 * Add support for INA219 Voltage and Current sensor to be enabled in user_config.h with define USE_INA219 * Add support for Arilux LC11 (Clearing RF home code when selecting no Arilux module) * Add support for WS2812 RGBW ledstrips to be enabled in user_config.h with define USE_WS2812_CTYPE (#1156) * Add SettingsSaveAll routine to command SaveData to be used before controlled power down (#1202) * Add option PUSHBUTTON_TOGGLE (SwitchMode 7) to allow toggling on any switch change (#1221) * Add new xdrv_05_ds18x20.ino free from library OneWire and add the following features: * Add support for DS1822 * Add forced setting of 12-bit resolution for selected device types (#1222) * Add read temperature retry counter (#1215) * Fix lost sensors by performing sensor probe at restart only thereby removing dynamic sensor probe (#1215) * Fix sensor address sorting using ascending sort on sensor type followed by sensor address * Rewrite JSON resulting in shorter message allowing more sensors in default firmware image: * "DS18B20-1":{"Id":"00000483C23A","Temperature":19.5},"DS18B20-2":{"Id":"0000048EC44C","Temperature":19.6} * Add additional define in user_config.h to select either single sensor (defines disabled), new multi sensor (USE_DS18X20) or legacy multi sensor (USE_DS18X20_LEGACY) * Add clock support for more different pixel counts (#1226) * Add support for Sonoff Dual R2 (#1249) * Add FriendlyName to web page tab and add program information to web page footer (#1275)
191 lines
4.7 KiB
C++
191 lines
4.7 KiB
C++
#include "PubSubClient.h"
|
|
#include "ShimClient.h"
|
|
#include "Buffer.h"
|
|
#include "BDDTest.h"
|
|
#include "trace.h"
|
|
|
|
|
|
byte server[] = { 172, 16, 0, 2 };
|
|
|
|
void callback(char* topic, byte* payload, unsigned int length) {
|
|
// handle message arrived
|
|
}
|
|
|
|
int test_publish() {
|
|
IT("publishes a null-terminated string");
|
|
ShimClient shimClient;
|
|
shimClient.setAllowConnect(true);
|
|
|
|
byte connack[] = { 0x20, 0x02, 0x00, 0x00 };
|
|
shimClient.respond(connack,4);
|
|
|
|
PubSubClient client(server, 1883, callback, shimClient);
|
|
int rc = client.connect((char*)"client_test1");
|
|
IS_TRUE(rc);
|
|
|
|
byte publish[] = {0x30,0xe,0x0,0x5,0x74,0x6f,0x70,0x69,0x63,0x70,0x61,0x79,0x6c,0x6f,0x61,0x64};
|
|
shimClient.expect(publish,16);
|
|
|
|
rc = client.publish((char*)"topic",(char*)"payload");
|
|
IS_TRUE(rc);
|
|
|
|
IS_FALSE(shimClient.error());
|
|
|
|
END_IT
|
|
}
|
|
|
|
|
|
int test_publish_bytes() {
|
|
IT("publishes a byte array");
|
|
ShimClient shimClient;
|
|
shimClient.setAllowConnect(true);
|
|
|
|
byte payload[] = { 0x01,0x02,0x03,0x0,0x05 };
|
|
int length = 5;
|
|
|
|
byte connack[] = { 0x20, 0x02, 0x00, 0x00 };
|
|
shimClient.respond(connack,4);
|
|
|
|
PubSubClient client(server, 1883, callback, shimClient);
|
|
int rc = client.connect((char*)"client_test1");
|
|
IS_TRUE(rc);
|
|
|
|
byte publish[] = {0x30,0xc,0x0,0x5,0x74,0x6f,0x70,0x69,0x63,0x1,0x2,0x3,0x0,0x5};
|
|
shimClient.expect(publish,14);
|
|
|
|
rc = client.publish((char*)"topic",payload,length);
|
|
IS_TRUE(rc);
|
|
|
|
IS_FALSE(shimClient.error());
|
|
|
|
END_IT
|
|
}
|
|
|
|
|
|
int test_publish_retained() {
|
|
IT("publishes retained - 1");
|
|
ShimClient shimClient;
|
|
shimClient.setAllowConnect(true);
|
|
|
|
byte payload[] = { 0x01,0x02,0x03,0x0,0x05 };
|
|
int length = 5;
|
|
|
|
byte connack[] = { 0x20, 0x02, 0x00, 0x00 };
|
|
shimClient.respond(connack,4);
|
|
|
|
PubSubClient client(server, 1883, callback, shimClient);
|
|
int rc = client.connect((char*)"client_test1");
|
|
IS_TRUE(rc);
|
|
|
|
byte publish[] = {0x31,0xc,0x0,0x5,0x74,0x6f,0x70,0x69,0x63,0x1,0x2,0x3,0x0,0x5};
|
|
shimClient.expect(publish,14);
|
|
|
|
rc = client.publish((char*)"topic",payload,length,true);
|
|
IS_TRUE(rc);
|
|
|
|
IS_FALSE(shimClient.error());
|
|
|
|
END_IT
|
|
}
|
|
|
|
int test_publish_retained_2() {
|
|
IT("publishes retained - 2");
|
|
ShimClient shimClient;
|
|
shimClient.setAllowConnect(true);
|
|
|
|
byte connack[] = { 0x20, 0x02, 0x00, 0x00 };
|
|
shimClient.respond(connack,4);
|
|
|
|
PubSubClient client(server, 1883, callback, shimClient);
|
|
int rc = client.connect((char*)"client_test1");
|
|
IS_TRUE(rc);
|
|
|
|
byte publish[] = {0x31,0xc,0x0,0x5,0x74,0x6f,0x70,0x69,0x63,'A','B','C','D','E'};
|
|
shimClient.expect(publish,14);
|
|
|
|
rc = client.publish((char*)"topic",(char*)"ABCDE",true);
|
|
IS_TRUE(rc);
|
|
|
|
IS_FALSE(shimClient.error());
|
|
|
|
END_IT
|
|
}
|
|
|
|
int test_publish_not_connected() {
|
|
IT("publish fails when not connected");
|
|
ShimClient shimClient;
|
|
|
|
PubSubClient client(server, 1883, callback, shimClient);
|
|
|
|
int rc = client.publish((char*)"topic",(char*)"payload");
|
|
IS_FALSE(rc);
|
|
|
|
IS_FALSE(shimClient.error());
|
|
|
|
END_IT
|
|
}
|
|
|
|
int test_publish_too_long() {
|
|
IT("publish fails when topic/payload are too long");
|
|
ShimClient shimClient;
|
|
shimClient.setAllowConnect(true);
|
|
|
|
byte connack[] = { 0x20, 0x02, 0x00, 0x00 };
|
|
shimClient.respond(connack,4);
|
|
|
|
PubSubClient client(server, 1883, callback, shimClient);
|
|
int rc = client.connect((char*)"client_test1");
|
|
IS_TRUE(rc);
|
|
|
|
// 0 1 2 3 4 5 6 7 8 9 0 1 2
|
|
rc = client.publish((char*)"topic",(char*)"123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890");
|
|
IS_FALSE(rc);
|
|
|
|
IS_FALSE(shimClient.error());
|
|
|
|
END_IT
|
|
}
|
|
|
|
int test_publish_P() {
|
|
IT("publishes using PROGMEM");
|
|
ShimClient shimClient;
|
|
shimClient.setAllowConnect(true);
|
|
|
|
byte payload[] = { 0x01,0x02,0x03,0x0,0x05 };
|
|
int length = 5;
|
|
|
|
byte connack[] = { 0x20, 0x02, 0x00, 0x00 };
|
|
shimClient.respond(connack,4);
|
|
|
|
PubSubClient client(server, 1883, callback, shimClient);
|
|
int rc = client.connect((char*)"client_test1");
|
|
IS_TRUE(rc);
|
|
|
|
byte publish[] = {0x31,0xc,0x0,0x5,0x74,0x6f,0x70,0x69,0x63,0x1,0x2,0x3,0x0,0x5};
|
|
shimClient.expect(publish,14);
|
|
|
|
rc = client.publish_P((char*)"topic",payload,length,true);
|
|
IS_TRUE(rc);
|
|
|
|
IS_FALSE(shimClient.error());
|
|
|
|
END_IT
|
|
}
|
|
|
|
|
|
|
|
|
|
int main()
|
|
{
|
|
SUITE("Publish");
|
|
test_publish();
|
|
test_publish_bytes();
|
|
test_publish_retained();
|
|
test_publish_retained_2();
|
|
test_publish_not_connected();
|
|
test_publish_too_long();
|
|
test_publish_P();
|
|
|
|
FINISH
|
|
}
|