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)
208 lines
9.3 KiB
C++
208 lines
9.3 KiB
C++
// Copyright 2017 Jonny Graham
|
|
|
|
#include "IRsend.h"
|
|
#include "IRsend_test.h"
|
|
#include "ir_Fujitsu.h"
|
|
#include "gtest/gtest.h"
|
|
|
|
template<typename T, size_t size>
|
|
::testing::AssertionResult ArraysMatch(const T (&expected)[size],
|
|
const T* actual) {
|
|
for (size_t i(0); i < size; ++i) {
|
|
if (expected[i] != actual[i]) {
|
|
int e = expected[i];
|
|
int a = actual[i];
|
|
return ::testing::AssertionFailure() << "array[" << i
|
|
<< "] (" << std::hex << a << std::dec << ") != expected[" << i
|
|
<< "] (" << std::hex << e << std::dec << ")";
|
|
}
|
|
}
|
|
|
|
return ::testing::AssertionSuccess();
|
|
}
|
|
// Tests for Mitsubishi A/C methods.
|
|
|
|
// Test sending typical data only.
|
|
TEST(TestSendFujitsuAC, GetRawDefault) {
|
|
IRFujitsuAC fujitsuACSender = IRFujitsuAC(4);
|
|
fujitsuACSender.setCmd(FUJITSU_AC_CMD_TURN_ON);
|
|
fujitsuACSender.setSwing(FUJITSU_AC_SWING_BOTH);
|
|
fujitsuACSender.setMode(FUJITSU_AC_MODE_COOL);
|
|
fujitsuACSender.setFanSpeed(FUJITSU_AC_FAN_HIGH);
|
|
fujitsuACSender.setTemp(24);
|
|
uint8_t expected[16] = {0x14, 0x63, 0x0, 0x10, 0x10, 0xFE, 0x9, 0x30,
|
|
0x81, 0x1, 0x31, 0x0, 0x0, 0x0, 0x20, 0xFD};
|
|
EXPECT_TRUE(ArraysMatch(expected, fujitsuACSender.getRaw()));
|
|
}
|
|
|
|
TEST(TestSendFujitsuAC, GetRawTurnOff) {
|
|
IRFujitsuAC fujitsuACSender = IRFujitsuAC(4);
|
|
fujitsuACSender.off();
|
|
uint8_t expected[7] = {0x14, 0x63, 0x0, 0x10, 0x10, 0x02, 0xFD};
|
|
EXPECT_TRUE(ArraysMatch(expected, fujitsuACSender.getRaw()));
|
|
}
|
|
TEST(TestSendFujitsuAC, GetRawStepHoriz) {
|
|
IRFujitsuAC fujitsuACSender = IRFujitsuAC(4);
|
|
fujitsuACSender.stepHoriz();
|
|
uint8_t expected[7] = {0x14, 0x63, 0x0, 0x10, 0x10, 0x79, 0x86};
|
|
EXPECT_TRUE(ArraysMatch(expected, fujitsuACSender.getRaw()));
|
|
}
|
|
TEST(TestSendFujitsuAC, GetRawStepVert) {
|
|
IRFujitsuAC fujitsuACSender = IRFujitsuAC(4);
|
|
fujitsuACSender.stepVert();
|
|
uint8_t expected[7] = {0x14, 0x63, 0x0, 0x10, 0x10, 0x6C, 0x93};
|
|
EXPECT_TRUE(ArraysMatch(expected, fujitsuACSender.getRaw()));
|
|
}
|
|
|
|
TEST(TestSendFujitsuAC, GetRawWithSwingHoriz) {
|
|
IRFujitsuAC fujitsuACSender = IRFujitsuAC(4);
|
|
fujitsuACSender.setCmd(FUJITSU_AC_CMD_STAY_ON);
|
|
fujitsuACSender.setSwing(FUJITSU_AC_SWING_HORIZ);
|
|
fujitsuACSender.setMode(FUJITSU_AC_MODE_COOL);
|
|
fujitsuACSender.setFanSpeed(FUJITSU_AC_FAN_QUIET);
|
|
fujitsuACSender.setTemp(25);
|
|
uint8_t expected[16] = {0x14, 0x63, 0x0, 0x10, 0x10, 0xFE, 0x9, 0x30,
|
|
0x90, 0x1, 0x24, 0x0, 0x0, 0x0, 0x20, 0xFB};
|
|
EXPECT_TRUE(ArraysMatch(expected, fujitsuACSender.getRaw()));
|
|
}
|
|
|
|
TEST(TestSendFujitsuAC, GetRawWithFan) {
|
|
IRFujitsuAC fujitsuACSender = IRFujitsuAC(4);
|
|
fujitsuACSender.setCmd(FUJITSU_AC_CMD_STAY_ON);
|
|
fujitsuACSender.setSwing(FUJITSU_AC_SWING_HORIZ);
|
|
fujitsuACSender.setMode(FUJITSU_AC_MODE_FAN);
|
|
fujitsuACSender.setFanSpeed(FUJITSU_AC_FAN_MED);
|
|
fujitsuACSender.setTemp(20); // temp doesn't matter for fan
|
|
// but it is sent by the RC anyway
|
|
uint8_t expected[16] = {0x14, 0x63, 0x0, 0x10, 0x10, 0xFE, 0x9, 0x30,
|
|
0x40, 0x3, 0x22, 0x0, 0x0, 0x0, 0x20, 0x4B};
|
|
EXPECT_TRUE(ArraysMatch(expected, fujitsuACSender.getRaw()));
|
|
}
|
|
|
|
TEST(TestSendFujitsuAC, GenerateMessage) {
|
|
IRFujitsuAC fujitsuACSender = IRFujitsuAC(4);
|
|
IRsendTest irsend(4);
|
|
fujitsuACSender.begin();
|
|
irsend.begin();
|
|
|
|
fujitsuACSender.setCmd(FUJITSU_AC_CMD_STAY_ON);
|
|
fujitsuACSender.setSwing(FUJITSU_AC_SWING_BOTH);
|
|
fujitsuACSender.setMode(FUJITSU_AC_MODE_COOL);
|
|
fujitsuACSender.setFanSpeed(FUJITSU_AC_FAN_HIGH);
|
|
fujitsuACSender.setTemp(24);
|
|
|
|
EXPECT_EQ(FUJITSU_AC_FAN_HIGH, fujitsuACSender.getFanSpeed());
|
|
EXPECT_EQ(FUJITSU_AC_MODE_COOL, fujitsuACSender.getMode());
|
|
EXPECT_EQ(24, fujitsuACSender.getTemp());
|
|
EXPECT_EQ(FUJITSU_AC_SWING_BOTH, fujitsuACSender.getSwing());
|
|
EXPECT_EQ(FUJITSU_AC_CMD_STAY_ON, fujitsuACSender.getCmd());
|
|
|
|
irsend.reset();
|
|
irsend.sendFujitsuAC(fujitsuACSender.getRaw(), FUJITSU_AC_STATE_LENGTH);
|
|
EXPECT_EQ(
|
|
"m3224s1574m448s367m448s367m448s1182m448s367m448s1182m448s367m448s367m448"
|
|
"s367m448s1182m448s1182m448s367m448s367m448s367m448s1182m448s1182m448s367"
|
|
"m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448"
|
|
"s367m448s367m448s367m448s367m448s1182m448s367m448s367m448s367m448s367m448"
|
|
"s367m448s367m448s367m448s1182m448s367m448s367m448s367m448s367m448s1182"
|
|
"m448s1182m448s1182m448s1182m448s1182m448s1182m448s1182m448s1182m448s367"
|
|
"m448s367m448s1182m448s367m448s367m448s367m448s367m448s367m448s367m448s367"
|
|
"m448s367m448s1182m448s1182m448s367m448s367m448s367m448s367m448s367m448s367"
|
|
"m448s367m448s367m448s367m448s1182m448s1182m448s367m448s367m448s367m448"
|
|
"s367m448s367m448s367m448s367m448s1182m448s367m448s367m448s367m448s1182m448"
|
|
"s1182m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448"
|
|
"s367m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448"
|
|
"s367m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448"
|
|
"s367m448s367m448s367m448s367m448s367m448s1182m448s367m448s367m448s367m448"
|
|
"s1182m448s1182m448s1182m448s1182m448s1182m448s1182m448s1182m448s8100",
|
|
irsend.outputStr());
|
|
}
|
|
TEST(TestSendFujitsuAC, GenerateShortMessage) {
|
|
IRFujitsuAC fujitsuACSender = IRFujitsuAC(4);
|
|
IRsendTest irsend(4);
|
|
fujitsuACSender.begin();
|
|
irsend.begin();
|
|
|
|
fujitsuACSender.off();
|
|
|
|
EXPECT_EQ(FUJITSU_AC_CMD_TURN_OFF, fujitsuACSender.getCmd());
|
|
|
|
irsend.reset();
|
|
irsend.sendFujitsuAC(fujitsuACSender.getRaw(), FUJITSU_AC_STATE_LENGTH_SHORT);
|
|
EXPECT_EQ(
|
|
"m3224s1574m448s367m448s367m448s1182m448s367m448s1182m448s367m448s367m448"
|
|
"s367m448s1182m448s1182m448s367m448s367m448s367m448s1182m448s1182m448s367"
|
|
"m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448s367"
|
|
"m448s367m448s367m448s367m448s1182m448s367m448s367m448s367m448s367m448s367"
|
|
"m448s367m448s367m448s1182m448s367m448s367m448s367m448s367m448s1182m448s367"
|
|
"m448s367m448s367m448s367m448s367m448s367m448s1182m448s367m448s1182m448"
|
|
"s1182m448s1182m448s1182m448s1182m448s1182m448s8100",
|
|
irsend.outputStr());
|
|
}
|
|
|
|
// Issue #275
|
|
TEST(TestSendFujitsuAC, Issue275) {
|
|
IRFujitsuAC fujitsuACSender = IRFujitsuAC(4);
|
|
IRsendTest irsend(4);
|
|
fujitsuACSender.begin();
|
|
irsend.begin();
|
|
irsend.reset();
|
|
|
|
fujitsuACSender.setCmd(FUJITSU_AC_CMD_TURN_OFF);
|
|
irsend.sendFujitsuAC(fujitsuACSender.getRaw(), FUJITSU_AC_STATE_LENGTH_SHORT);
|
|
EXPECT_EQ(
|
|
// Header
|
|
"m3224s1574"
|
|
// 0 0 1 0 1 0 0 0 (0x28)
|
|
"m448s367m448s367m448s1182m448s367m448s1182m448s367m448s367m448s367"
|
|
// 1 1 0 0 0 1 1 0 (0xC6)
|
|
"m448s1182m448s1182m448s367m448s367m448s367m448s1182m448s1182m448s367"
|
|
// 0 0 0 0 0 0 0 0 (0x00)
|
|
"m448s367m448s367m448s367m448s367m448s367m448s367m448s367m448s367"
|
|
// 0 0 0 0 1 0 0 0 (0x08)
|
|
"m448s367m448s367m448s367m448s367m448s1182m448s367m448s367m448s367"
|
|
// 0 0 0 0 1 0 0 0 (0x08)
|
|
"m448s367m448s367m448s367m448s367m448s1182m448s367m448s367m448s367"
|
|
// 0 1 0 0 0 0 0 0 (0x40)
|
|
"m448s367m448s1182m448s367m448s367m448s367m448s367m448s367m448s367"
|
|
// 1 0 1 1 1 1 1 1 (0xBF)
|
|
"m448s1182m448s367m448s1182m448s1182m448s1182m448s1182m448s1182m448s1182"
|
|
// Footer
|
|
"m448s8100", irsend.outputStr());
|
|
|
|
irsend.reset();
|
|
// Per report in Issue #275
|
|
uint16_t off[115] = {
|
|
3350, 1650,
|
|
450, 400, 450, 450, 450, 1250, 450, 400, 450, 1250, 450, 400, 450, 400,
|
|
450, 400, 450, 1250, 450, 1250, 450, 400, 450, 400, 450, 400, 450, 1250,
|
|
450, 1250, 450, 400, 450, 400, 450, 400, 450, 400, 450, 400, 450, 400,
|
|
450, 400, 450, 400, 450, 400, 450, 400, 450, 400, 450, 400, 450, 400,
|
|
450, 1250, 450, 400, 450, 400, 450, 400, 450, 400, 450, 400, 450, 400,
|
|
450, 400, 450, 1250, 450, 400, 450, 400, 450, 400, 450, 400, 450, 1250,
|
|
450, 400, 450, 400, 450, 400, 450, 400, 450, 400, 450, 400, 450, 1250,
|
|
450, 400, 450, 1250, 450, 1250, 450, 1250, 450, 1250, 450, 1250,
|
|
450, 1250, 450};
|
|
irsend.sendRaw(off, 115, 38);
|
|
EXPECT_EQ(
|
|
// Header
|
|
"m3350s1650"
|
|
// 0 0 1 0 1 0 0 0 (0x28)
|
|
"m450s400m450s450m450s1250m450s400m450s1250m450s400m450s400m450s400"
|
|
// 1 1 0 0 0 1 1 0 (0xC6)
|
|
"m450s1250m450s1250m450s400m450s400m450s400m450s1250m450s1250m450s400"
|
|
// 0 0 0 0 0 0 0 0 (0x00)
|
|
"m450s400m450s400m450s400m450s400m450s400m450s400m450s400m450s400"
|
|
// 0 0 0 0 1 0 0 0 (0x08)
|
|
"m450s400m450s400m450s400m450s400m450s1250m450s400m450s400m450s400"
|
|
// 0 0 0 0 1 0 0 0 (0x08)
|
|
"m450s400m450s400m450s400m450s400m450s1250m450s400m450s400m450s400"
|
|
// 0 1 0 0 0 0 0 0 (0x40)
|
|
"m450s400m450s1250m450s400m450s400m450s400m450s400m450s400m450s400"
|
|
// 1 0 1 1 1 1 1 1 (0xBF)
|
|
"m450s1250m450s400m450s1250m450s1250m450s1250m450s1250m450s1250m450s1250"
|
|
// Footer
|
|
"m450",
|
|
irsend.outputStr());
|
|
}
|