From 43c6d54af1655e9911319820b1b6fea2b9fc78f5 Mon Sep 17 00:00:00 2001 From: Vivien Nicolas Date: Fri, 15 Oct 2021 19:37:38 +0200 Subject: [PATCH 1/2] Move the list of YAML tests runned with chip-tool under examples/chip-tool/templates/helper.js --- examples/chip-tool/templates/templates.json | 3 +- .../chip-tool/templates/tests-commands.zapt | 2 +- examples/chip-tool/templates/tests.js | 163 ++++++++++++++++++ .../common/ClusterTestGeneration.js | 5 +- 4 files changed, 169 insertions(+), 4 deletions(-) create mode 100644 examples/chip-tool/templates/tests.js diff --git a/examples/chip-tool/templates/templates.json b/examples/chip-tool/templates/templates.json index a295e5df7fd170..9fa7f7f4d4c38e 100644 --- a/examples/chip-tool/templates/templates.json +++ b/examples/chip-tool/templates/templates.json @@ -7,7 +7,8 @@ "../../../src/app/zap-templates/templates/app/helper.js", "../../../src/app/zap-templates/templates/chip/helper.js", "../../../src/app/zap-templates/common/ClusterTestGeneration.js", - "helper.js" + "helper.js", + "tests.js" ], "override": "../../../src/app/zap-templates/common/override.js", "partials": [ diff --git a/examples/chip-tool/templates/tests-commands.zapt b/examples/chip-tool/templates/tests-commands.zapt index 88383618ca505e..4a7dee80b7d947 100644 --- a/examples/chip-tool/templates/tests-commands.zapt +++ b/examples/chip-tool/templates/tests-commands.zapt @@ -4,4 +4,4 @@ #include -{{>test_cluster tests="TV_TargetNavigatorCluster, TV_AudioOutputCluster, TV_ApplicationLauncherCluster, TV_KeypadInputCluster, TV_AccountLoginCluster, TV_WakeOnLanCluster, TV_ApplicationBasicCluster, TV_MediaPlaybackCluster, TV_TvChannelCluster, TV_LowPowerCluster, TV_MediaInputCluster, TestCluster, TestClusterComplexTypes, TestConstraints, TestDelayCommands, TestDescriptorCluster, TestSubscribe_OnOff, Test_TC_OO_1_1, Test_TC_OO_2_1, Test_TC_OO_2_2, Test_TC_DM_1_1, Test_TC_DM_3_1, Test_TC_WNCV_1_1, Test_TC_WNCV_2_1, Test_TC_WNCV_3_1, Test_TC_WNCV_3_2, Test_TC_WNCV_3_3, Test_TC_BI_1_1, Test_TC_FLW_1_1, Test_TC_TM_1_1, Test_TC_OCC_1_1, TestOperationalCredentialsCluster, Test_TC_LVL_1_1, Test_TC_LVL_2_1, Test_TC_LVL_3_1, Test_TC_CC_1_1, Test_TC_RH_1_1, Test_TC_MC_1_1, Test_TC_TSTAT_1_1, Test_TC_PCC_1_1, Test_TC_TSUIC_1_1, Test_TC_DIAGTH_1_1, Test_TC_TM_2_1, Test_TC_TSUIC_2_1, Test_TC_PCC_2_1, Test_TC_CC_3_1, Test_TC_CC_3_2, Test_TC_CC_3_3, Test_TC_CC_4_1, Test_TC_CC_4_2, Test_TC_CC_4_3, Test_TC_CC_4_4, Test_TC_CC_5_1, Test_TC_CC_5_2, Test_TC_CC_5_3, Test_TC_CC_6_1, Test_TC_CC_6_2, Test_TC_CC_6_3, Test_TC_CC_7_1, Test_TC_CC_7_2, Test_TC_CC_7_3, Test_TC_CC_7_4, Test_TC_CC_8_1"}} +{{>test_cluster tests=(getTests)}} diff --git a/examples/chip-tool/templates/tests.js b/examples/chip-tool/templates/tests.js new file mode 100644 index 00000000000000..83c7b0bc2b7d14 --- /dev/null +++ b/examples/chip-tool/templates/tests.js @@ -0,0 +1,163 @@ +/* + * + * Copyright (c) 2021 Project CHIP Authors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +function getTests() +{ + const BinaryInput = [ + 'Test_TC_BI_1_1', + ]; + + const ColorControl = [ + 'Test_TC_CC_1_1', + 'Test_TC_CC_3_1', + 'Test_TC_CC_3_2', + 'Test_TC_CC_3_3', + 'Test_TC_CC_4_1', + 'Test_TC_CC_4_2', + 'Test_TC_CC_4_3', + 'Test_TC_CC_4_4', + 'Test_TC_CC_5_1', + 'Test_TC_CC_5_2', + 'Test_TC_CC_5_3', + 'Test_TC_CC_6_1', + 'Test_TC_CC_6_2', + 'Test_TC_CC_6_3', + 'Test_TC_CC_7_1', + 'Test_TC_CC_7_2', + 'Test_TC_CC_7_3', + 'Test_TC_CC_7_4', + 'Test_TC_CC_8_1', + ]; + + const DeviceManagement = [ + 'Test_TC_DM_1_1', + 'Test_TC_DM_3_1', + ]; + + const FlowMeasurement = [ + 'Test_TC_FLW_1_1', + ]; + + const OccupancySensing = [ + 'Test_TC_OCC_1_1', + ]; + + const LevelControl = [ + 'Test_TC_LVL_1_1', + 'Test_TC_LVL_2_1', + 'Test_TC_LVL_3_1', + ]; + + const MediaControl = [ + 'Test_TC_MC_1_1', + ]; + + const OnOff = [ + 'Test_TC_OO_1_1', + 'Test_TC_OO_2_1', + 'Test_TC_OO_2_2', + ]; + + const PumpConfigurationControl = [ + 'Test_TC_PCC_1_1', + 'Test_TC_PCC_2_1', + ]; + + const RelativeHumidityMeasurement = [ + 'Test_TC_RH_1_1', + ]; + + const TemperatureMeasurement = [ + 'Test_TC_TM_1_1', + 'Test_TC_TM_2_1', + ]; + + const Thermostat = [ + 'Test_TC_TSTAT_1_1', + ]; + + const ThermostatUserConfiguration = [ + 'Test_TC_TSUIC_1_1', + 'Test_TC_TSUIC_2_1', + ]; + + const ThreadNetworkDiagnostics = [ + 'Test_TC_DIAGTH_1_1', + ]; + + const WindowCovering = [ + 'Test_TC_WNCV_1_1', + 'Test_TC_WNCV_2_1', + 'Test_TC_WNCV_3_1', + 'Test_TC_WNCV_3_2', + 'Test_TC_WNCV_3_3', + ]; + + const TV = [ + 'TV_TargetNavigatorCluster', + 'TV_AudioOutputCluster', + 'TV_ApplicationLauncherCluster', + 'TV_KeypadInputCluster', + 'TV_AccountLoginCluster', + 'TV_WakeOnLanCluster', + 'TV_ApplicationBasicCluster', + 'TV_MediaPlaybackCluster', + 'TV_TvChannelCluster', + 'TV_LowPowerCluster', + 'TV_MediaInputCluster', + ]; + + const Others = [ + 'TestCluster', + 'TestClusterComplexTypes', + 'TestConstraints', + 'TestDelayCommands', + 'TestDescriptorCluster', + 'TestOperationalCredentialsCluster', + ]; + + const Subscriptions = [ + 'TestSubscribe_OnOff', + ]; + + const tests = [ + BinaryInput, // + ColorControl, // + DeviceManagement, // + FlowMeasurement, // + LevelControl, // + MediaControl, // + OccupancySensing, // + OnOff, // + PumpConfigurationControl, // + RelativeHumidityMeasurement, // + TemperatureMeasurement, // + Thermostat, // + ThermostatUserConfiguration, // + ThreadNetworkDiagnostics, // + WindowCovering, // + TV, // + Others, // + Subscriptions, // + ]; + return tests.flat(1); +} + +// +// Module exports +// +exports.getTests = getTests; diff --git a/src/app/zap-templates/common/ClusterTestGeneration.js b/src/app/zap-templates/common/ClusterTestGeneration.js index db455d590929d4..01de1efd606c31 100644 --- a/src/app/zap-templates/common/ClusterTestGeneration.js +++ b/src/app/zap-templates/common/ClusterTestGeneration.js @@ -326,9 +326,10 @@ function assertCommandOrAttribute(context) // // Templates // -function chip_tests(items, options) +function chip_tests(list, options) { - const names = items.split(',').map(name => name.trim()); + const items = Array.isArray(list) ? list : list.split(','); + const names = items.map(name => name.trim()); const tests = names.map(item => parse(item)); return templateUtil.collectBlocks(tests, options, this); } From 4f8a68fbf9b1ad0d77cb783e6c0215cfd844c2b0 Mon Sep 17 00:00:00 2001 From: Vivien Nicolas Date: Fri, 15 Oct 2021 19:37:57 +0200 Subject: [PATCH 2/2] Update generated chip-tool tests (just reordered) --- .../chip-tool/zap-generated/test/Commands.h | 21558 ++++++++-------- 1 file changed, 10779 insertions(+), 10779 deletions(-) diff --git a/zzz_generated/chip-tool/zap-generated/test/Commands.h b/zzz_generated/chip-tool/zap-generated/test/Commands.h index c9086eeb058f17..5c444eda2ce8f5 100644 --- a/zzz_generated/chip-tool/zap-generated/test/Commands.h +++ b/zzz_generated/chip-tool/zap-generated/test/Commands.h @@ -21,10 +21,10 @@ #include -class TV_TargetNavigatorCluster : public TestCommand +class Test_TC_BI_1_1 : public TestCommand { public: - TV_TargetNavigatorCluster() : TestCommand("TV_TargetNavigatorCluster"), mTestIndex(0) {} + Test_TC_BI_1_1() : TestCommand("Test_TC_BI_1_1"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -33,12 +33,12 @@ class TV_TargetNavigatorCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TV_TargetNavigatorCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_BI_1_1\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TV_TargetNavigatorCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_BI_1_1\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -52,12 +52,17 @@ class TV_TargetNavigatorCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute Target Navigator list\n"); - err = TestReadAttributeTargetNavigatorList_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); + err = TestReadTheGlobalAttributeClusterRevision_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Navigate Target Command\n"); - err = TestNavigateTargetCommand_1(); + ChipLogProgress(chipTool, + " ***** Test Step 1 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : reads back global attribute: ClusterRevision\n"); + err = TestReadsBackGlobalAttributeClusterRevision_2(); break; } @@ -70,75 +75,101 @@ class TV_TargetNavigatorCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 2; + const uint16_t mTestCount = 3; chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback - mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_0(void * context, uint16_t count, _NavigateTargetTargetInfo * targetNavigatorList) + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - (static_cast(context))->OnSuccessResponse_0(count, targetNavigatorList); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); + } + + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); + } + + static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) + { + (static_cast(context))->OnSuccessResponse_1(clusterRevision); + } + + static void OnFailureCallback_2(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_2(status); + } + + static void OnSuccessCallback_2(void * context, uint16_t clusterRevision) + { + (static_cast(context))->OnSuccessResponse_2(clusterRevision); } // // Tests methods // - CHIP_ERROR TestReadAttributeTargetNavigatorList_0() + CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() { - chip::Controller::TargetNavigatorClusterTest cluster; + chip::Controller::BinaryInputBasicClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeTargetNavigatorList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint16_t count, _NavigateTargetTargetInfo * targetNavigatorList) + void OnSuccessResponse_0(uint16_t clusterRevision) { - VerifyOrReturn(CheckValueAsList("targetNavigatorList", count, 2)); + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 1U)); NextTest(); } - CHIP_ERROR TestNavigateTargetCommand_1() + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1() { - chip::Controller::TargetNavigatorClusterTest cluster; + chip::Controller::BinaryInputBasicClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::TargetNavigator::Commands::NavigateTarget::Type; - using responseType = chip::app::Clusters::TargetNavigator::Commands::NavigateTargetResponse::DecodableType; + uint16_t clusterRevisionArgument = 1U; - chip::app::Clusters::TargetNavigator::Commands::NavigateTarget::Type request; - request.target = 1; - request.data = chip::Span("1", strlen("1")); + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), + clusterRevisionArgument); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context)) - ->OnSuccessResponse_1(data.status, - chip::ByteSpan(reinterpret_cast(data.data.data()), data.data.size())); - }; + void OnFailureResponse_1(uint8_t status) { NextTest(); } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } + + CHIP_ERROR TestReadsBackGlobalAttributeClusterRevision_2() + { + chip::Controller::BinaryInputBasicClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint8_t status, chip::ByteSpan data) { NextTest(); } + void OnSuccessResponse_2(uint16_t clusterRevision) + { + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 1U)); + NextTest(); + } }; -class TV_AudioOutputCluster : public TestCommand +class Test_TC_CC_1_1 : public TestCommand { public: - TV_AudioOutputCluster() : TestCommand("TV_AudioOutputCluster"), mTestIndex(0) {} + Test_TC_CC_1_1() : TestCommand("Test_TC_CC_1_1"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -147,12 +178,12 @@ class TV_AudioOutputCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TV_AudioOutputCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_1_1\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TV_AudioOutputCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_1_1\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -166,16 +197,9 @@ class TV_AudioOutputCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute Audio Output list\n"); - err = TestReadAttributeAudioOutputList_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Select Output Command\n"); - err = TestSelectOutputCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Rename Output Command\n"); - err = TestRenameOutputCommand_2(); + ChipLogProgress(chipTool, + " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); break; } @@ -188,99 +212,45 @@ class TV_AudioOutputCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 3; + const uint16_t mTestCount = 1; chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ - OnSuccessCallback_0, this - }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_0(void * context, uint16_t count, _AudioOutputInfo * audioOutputList) + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - (static_cast(context))->OnSuccessResponse_0(count, audioOutputList); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } // // Tests methods // - CHIP_ERROR TestReadAttributeAudioOutputList_0() - { - chip::Controller::AudioOutputClusterTest cluster; - cluster.Associate(mDevice, 2); - - return cluster.ReadAttributeAudioOutputList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); - } - - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0(uint16_t count, _AudioOutputInfo * audioOutputList) - { - VerifyOrReturn(CheckValueAsList("audioOutputList", count, 3)); - NextTest(); - } - - CHIP_ERROR TestSelectOutputCommand_1() - { - chip::Controller::AudioOutputClusterTest cluster; - cluster.Associate(mDevice, 2); - - using requestType = chip::app::Clusters::AudioOutput::Commands::SelectOutput::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::AudioOutput::Commands::SelectOutput::Type request; - request.index = 1; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); - }; - return cluster.InvokeCommand(request, this, success, failure); - } - - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_1() { NextTest(); } - - CHIP_ERROR TestRenameOutputCommand_2() + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() { - chip::Controller::AudioOutputClusterTest cluster; - cluster.Associate(mDevice, 2); - - using requestType = chip::app::Clusters::AudioOutput::Commands::RenameOutput::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::AudioOutput::Commands::RenameOutput::Type request; - request.index = 1; - request.name = chip::Span("exampleName", strlen("exampleName")); + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + uint16_t clusterRevisionArgument = 4U; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), + clusterRevisionArgument); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { NextTest(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } }; -class TV_ApplicationLauncherCluster : public TestCommand +class Test_TC_CC_3_1 : public TestCommand { public: - TV_ApplicationLauncherCluster() : TestCommand("TV_ApplicationLauncherCluster"), mTestIndex(0) {} + Test_TC_CC_3_1() : TestCommand("Test_TC_CC_3_1"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -289,12 +259,12 @@ class TV_ApplicationLauncherCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TV_ApplicationLauncherCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_3_1\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TV_ApplicationLauncherCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_3_1\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -308,20 +278,36 @@ class TV_ApplicationLauncherCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute Application Launcher list\n"); - err = TestReadAttributeApplicationLauncherList_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Launch App Command\n"); - err = TestLaunchAppCommand_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Read attribute catalog vendor id\n"); - err = TestReadAttributeCatalogVendorId_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Move to hue shortest distance command\n"); + err = TestMoveToHueShortestDistanceCommand_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Read attribute application id\n"); - err = TestReadAttributeApplicationId_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Move to hue longest distance command\n"); + err = TestMoveToHueLongestDistanceCommand_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Move to hue up command\n"); + err = TestMoveToHueUpCommand_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Move to hue down command\n"); + err = TestMoveToHueDownCommand_5(); + break; + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_6(); + break; + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7(); break; } @@ -334,133 +320,238 @@ class TV_ApplicationLauncherCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 4; + const uint16_t mTestCount = 8; - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ - OnSuccessCallback_0, this - }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; - static void OnFailureCallback_0(void * context, uint8_t status) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_0(void * context, uint16_t count, uint16_t * applicationLauncherList) + static void OnSuccessCallback_1(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_0(count, applicationLauncherList); + (static_cast(context))->OnSuccessResponse_1(onOff); } - static void OnFailureCallback_2(void * context, uint8_t status) + static void OnFailureCallback_7(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_7(status); } - static void OnSuccessCallback_2(void * context, uint8_t catalogVendorId) + static void OnSuccessCallback_7(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_2(catalogVendorId); + (static_cast(context))->OnSuccessResponse_7(onOff); } - static void OnFailureCallback_3(void * context, uint8_t status) + // + // Tests methods + // + + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - (static_cast(context))->OnFailureResponse_3(status); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_3(void * context, uint8_t applicationId) + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - (static_cast(context))->OnSuccessResponse_3(applicationId); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - // - // Tests methods - // + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestReadAttributeApplicationLauncherList_0() + void OnSuccessResponse_1(bool onOff) { - chip::Controller::ApplicationLauncherClusterTest cluster; + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } + + CHIP_ERROR TestMoveToHueShortestDistanceCommand_2() + { + chip::Controller::ColorControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeApplicationLauncherList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + using requestType = chip::app::Clusters::ColorControl::Commands::MoveToHue::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::MoveToHue::Type request; + request.hue = 150; + request.direction = static_cast(0); + request.transitionTime = 100U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint16_t count, uint16_t * applicationLauncherList) + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestMoveToHueLongestDistanceCommand_3() { - VerifyOrReturn(CheckValueAsList("applicationLauncherList", count, 2)); - NextTest(); + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::MoveToHue::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::MoveToHue::Type request; + request.hue = 200; + request.direction = static_cast(1); + request.transitionTime = 100U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - CHIP_ERROR TestLaunchAppCommand_1() + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3() { NextTest(); } + + CHIP_ERROR TestMoveToHueUpCommand_4() { - chip::Controller::ApplicationLauncherClusterTest cluster; + chip::Controller::ColorControlClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ApplicationLauncher::Commands::LaunchApp::Type; - using responseType = chip::app::Clusters::ApplicationLauncher::Commands::LaunchAppResponse::DecodableType; + using requestType = chip::app::Clusters::ColorControl::Commands::MoveToHue::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::ApplicationLauncher::Commands::LaunchApp::Type request; - request.data = chip::Span("exampleData", strlen("exampleData")); - request.catalogVendorId = 1U; - request.applicationId = chip::Span("appId", strlen("appId")); + chip::app::Clusters::ColorControl::Commands::MoveToHue::Type request; + request.hue = 250; + request.direction = static_cast(2); + request.transitionTime = 100U; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context)) - ->OnSuccessResponse_1(data.status, - chip::ByteSpan(reinterpret_cast(data.data.data()), data.data.size())); + (static_cast(context))->OnSuccessResponse_4(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_4(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint8_t status, chip::ByteSpan data) { NextTest(); } + void OnSuccessResponse_4() { NextTest(); } - CHIP_ERROR TestReadAttributeCatalogVendorId_2() + CHIP_ERROR TestMoveToHueDownCommand_5() { - chip::Controller::ApplicationLauncherClusterTest cluster; + chip::Controller::ColorControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeCatalogVendorId(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + using requestType = chip::app::Clusters::ColorControl::Commands::MoveToHue::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::MoveToHue::Type request; + request.hue = 225; + request.direction = static_cast(3); + request.transitionTime = 100U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_5(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_5(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint8_t catalogVendorId) + void OnSuccessResponse_5() { NextTest(); } + + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_6() { - VerifyOrReturn(CheckValue("catalogVendorId", catalogVendorId, 0)); - NextTest(); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_6(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_6(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - CHIP_ERROR TestReadAttributeApplicationId_3() + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_6() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7() { - chip::Controller::ApplicationLauncherClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeApplicationId(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3(uint8_t applicationId) + void OnSuccessResponse_7(bool onOff) { - VerifyOrReturn(CheckValue("applicationId", applicationId, 0)); + VerifyOrReturn(CheckValue("onOff", onOff, 0)); NextTest(); } }; -class TV_KeypadInputCluster : public TestCommand +class Test_TC_CC_3_2 : public TestCommand { public: - TV_KeypadInputCluster() : TestCommand("TV_KeypadInputCluster"), mTestIndex(0) {} + Test_TC_CC_3_2() : TestCommand("Test_TC_CC_3_2"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -469,12 +560,12 @@ class TV_KeypadInputCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TV_KeypadInputCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_3_2\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TV_KeypadInputCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_3_2\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -488,8 +579,36 @@ class TV_KeypadInputCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Send Key Command\n"); - err = TestSendKeyCommand_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Move hue up command\n"); + err = TestMoveHueUpCommand_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Move hue stop command\n"); + err = TestMoveHueStopCommand_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Move hue down command\n"); + err = TestMoveHueDownCommand_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Move hue stop command\n"); + err = TestMoveHueStopCommand_5(); + break; + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_6(); + break; + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7(); break; } @@ -502,151 +621,234 @@ class TV_KeypadInputCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; + const uint16_t mTestCount = 8; - // - // Tests methods - // + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; - CHIP_ERROR TestSendKeyCommand_0() + static void OnFailureCallback_1(void * context, uint8_t status) { - chip::Controller::KeypadInputClusterTest cluster; + (static_cast(context))->OnFailureResponse_1(status); + } + + static void OnSuccessCallback_1(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_1(onOff); + } + + static void OnFailureCallback_7(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_7(status); + } + + static void OnSuccessCallback_7(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_7(onOff); + } + + // + // Tests methods + // + + CHIP_ERROR TestTurnOnLightForColorControlTests_0() + { + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::KeypadInput::Commands::SendKey::Type; - using responseType = chip::app::Clusters::KeypadInput::Commands::SendKeyResponse::DecodableType; + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::KeypadInput::Commands::SendKey::Type request; - request.keyCode = static_cast(3); + chip::app::Clusters::OnOff::Commands::On::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(data.status); + (static_cast(context))->OnSuccessResponse_0(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); }; return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint8_t status) { NextTest(); } -}; + void OnSuccessResponse_0() { NextTest(); } -class TV_AccountLoginCluster : public TestCommand -{ -public: - TV_AccountLoginCluster() : TestCommand("TV_AccountLoginCluster"), mTestIndex(0) {} + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - /////////// TestCommand Interface ///////// - void NextTest() override + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + } + + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(bool onOff) { - CHIP_ERROR err = CHIP_NO_ERROR; + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: TV_AccountLoginCluster\n"); - } + CHIP_ERROR TestMoveHueUpCommand_2() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: TV_AccountLoginCluster\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + using requestType = chip::app::Clusters::ColorControl::Commands::MoveHue::Type; + using responseType = chip::app::DataModel::NullObjectType; - Wait(); + chip::app::Clusters::ColorControl::Commands::MoveHue::Type request; + request.moveMode = static_cast(1); + request.rate = 50; + request.optionsMask = 0; + request.optionsOverride = 0; - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Get Setup PIN Command\n"); - err = TestGetSetupPinCommand_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Login Command\n"); - err = TestLoginCommand_1(); - break; - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 2; + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - // - // Tests methods - // + void OnSuccessResponse_2() { NextTest(); } - CHIP_ERROR TestGetSetupPinCommand_0() + CHIP_ERROR TestMoveHueStopCommand_3() { - chip::Controller::AccountLoginClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::AccountLogin::Commands::GetSetupPIN::Type; - using responseType = chip::app::Clusters::AccountLogin::Commands::GetSetupPINResponse::DecodableType; + using requestType = chip::app::Clusters::ColorControl::Commands::MoveHue::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::AccountLogin::Commands::GetSetupPIN::Type request; - request.tempAccountIdentifier = chip::Span("asdf", strlen("asdf")); + chip::app::Clusters::ColorControl::Commands::MoveHue::Type request; + request.moveMode = static_cast(0); + request.rate = 50; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context)) - ->OnSuccessResponse_0( - chip::ByteSpan(reinterpret_cast(data.setupPIN.data()), data.setupPIN.size())); + (static_cast(context))->OnSuccessResponse_3(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_3(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(chip::ByteSpan setupPIN) { NextTest(); } + void OnSuccessResponse_3() { NextTest(); } - CHIP_ERROR TestLoginCommand_1() + CHIP_ERROR TestMoveHueDownCommand_4() { - chip::Controller::AccountLoginClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::AccountLogin::Commands::Login::Type; + using requestType = chip::app::Clusters::ColorControl::Commands::MoveHue::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::AccountLogin::Commands::Login::Type request; - request.tempAccountIdentifier = chip::Span("asdf", strlen("asdf")); - request.setupPIN = chip::Span("tempPin123", strlen("tempPin123")); + chip::app::Clusters::ColorControl::Commands::MoveHue::Type request; + request.moveMode = static_cast(3); + request.rate = 50; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(); + (static_cast(context))->OnSuccessResponse_4(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_4(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1() { NextTest(); } + void OnSuccessResponse_4() { NextTest(); } + + CHIP_ERROR TestMoveHueStopCommand_5() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::MoveHue::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::MoveHue::Type request; + request.moveMode = static_cast(0); + request.rate = 50; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_5(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_5(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_5() { NextTest(); } + + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_6() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_6(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_6(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_6() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + } + + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_7(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } }; -class TV_WakeOnLanCluster : public TestCommand +class Test_TC_CC_3_3 : public TestCommand { public: - TV_WakeOnLanCluster() : TestCommand("TV_WakeOnLanCluster"), mTestIndex(0) {} + Test_TC_CC_3_3() : TestCommand("Test_TC_CC_3_3"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -655,12 +857,12 @@ class TV_WakeOnLanCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TV_WakeOnLanCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_3_3\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TV_WakeOnLanCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_3_3\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -674,11 +876,31 @@ class TV_WakeOnLanCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Read mac address\n"); - err = TestReadMacAddress_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; - } - + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Step hue up command\n"); + err = TestStepHueUpCommand_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Step hue down command\n"); + err = TestStepHueDownCommand_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); + break; + } + if (CHIP_NO_ERROR != err) { ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); @@ -688,48 +910,180 @@ class TV_WakeOnLanCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; + const uint16_t mTestCount = 6; - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ - OnSuccessCallback_0, this - }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; - static void OnFailureCallback_0(void * context, uint8_t status) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_0(void * context, chip::ByteSpan wakeOnLanMacAddress) + static void OnSuccessCallback_1(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_0(wakeOnLanMacAddress); + (static_cast(context))->OnSuccessResponse_1(onOff); + } + + static void OnFailureCallback_5(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_5(status); + } + + static void OnSuccessCallback_5(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_5(onOff); } // // Tests methods // - CHIP_ERROR TestReadMacAddress_0() + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - chip::Controller::WakeOnLanClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeWakeOnLanMacAddress(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(chip::ByteSpan wakeOnLanMacAddress) + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - VerifyOrReturn(CheckValueAsString("wakeOnLanMacAddress", wakeOnLanMacAddress, "00:00:00:00:00")); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + } + + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } + + CHIP_ERROR TestStepHueUpCommand_2() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::StepHue::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::StepHue::Type request; + request.stepMode = static_cast(1); + request.stepSize = 5; + request.transitionTime = 25; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestStepHueDownCommand_3() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::StepHue::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::StepHue::Type request; + request.stepMode = static_cast(3); + request.stepSize = 5; + request.transitionTime = 25; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3() { NextTest(); } + + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_4(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_4(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_4() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + } + + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_5(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); NextTest(); } }; -class TV_ApplicationBasicCluster : public TestCommand +class Test_TC_CC_4_1 : public TestCommand { public: - TV_ApplicationBasicCluster() : TestCommand("TV_ApplicationBasicCluster"), mTestIndex(0) {} + Test_TC_CC_4_1() : TestCommand("Test_TC_CC_4_1"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -738,12 +1092,12 @@ class TV_ApplicationBasicCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TV_ApplicationBasicCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_4_1\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TV_ApplicationBasicCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_4_1\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -757,20 +1111,24 @@ class TV_ApplicationBasicCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Change Status Command\n"); - err = TestChangeStatusCommand_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Read attribute vendor id\n"); - err = TestReadAttributeVendorId_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Read attribute product id\n"); - err = TestReadAttributeProductId_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Move to saturation command\n"); + err = TestMoveToSaturationCommand_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Read attribute catalog vendor id\n"); - err = TestReadAttributeCatalogVendorId_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); break; } @@ -783,66 +1141,53 @@ class TV_ApplicationBasicCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 4; + const uint16_t mTestCount = 5; chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); - } - - static void OnSuccessCallback_1(void * context, uint16_t vendorId) - { - (static_cast(context))->OnSuccessResponse_1(vendorId); - } - - static void OnFailureCallback_2(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_2(void * context, uint16_t productId) + static void OnSuccessCallback_1(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_2(productId); + (static_cast(context))->OnSuccessResponse_1(onOff); } - static void OnFailureCallback_3(void * context, uint8_t status) + static void OnFailureCallback_4(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_3(status); + (static_cast(context))->OnFailureResponse_4(status); } - static void OnSuccessCallback_3(void * context, uint16_t catalogVendorId) + static void OnSuccessCallback_4(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_3(catalogVendorId); + (static_cast(context))->OnSuccessResponse_4(onOff); } // // Tests methods // - CHIP_ERROR TestChangeStatusCommand_0() + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - chip::Controller::ApplicationBasicClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ApplicationBasic::Commands::ChangeStatus::Type; + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::ApplicationBasic::Commands::ChangeStatus::Type request; - request.status = static_cast(1); + chip::app::Clusters::OnOff::Commands::On::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); + (static_cast(context))->OnSuccessResponse_0(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); }; return cluster.InvokeCommand(request, this, success, failure); } @@ -851,59 +1196,95 @@ class TV_ApplicationBasicCluster : public TestCommand void OnSuccessResponse_0() { NextTest(); } - CHIP_ERROR TestReadAttributeVendorId_1() + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - chip::Controller::ApplicationBasicClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeVendorId(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint16_t vendorId) + void OnSuccessResponse_1(bool onOff) { - VerifyOrReturn(CheckValue("vendorId", vendorId, 1U)); + VerifyOrReturn(CheckValue("onOff", onOff, 1)); NextTest(); } - CHIP_ERROR TestReadAttributeProductId_2() + CHIP_ERROR TestMoveToSaturationCommand_2() { - chip::Controller::ApplicationBasicClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeProductId(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + using requestType = chip::app::Clusters::ColorControl::Commands::MoveToSaturation::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::MoveToSaturation::Type request; + request.saturation = 90; + request.transitionTime = 10U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint16_t productId) + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() { - VerifyOrReturn(CheckValue("productId", productId, 1U)); - NextTest(); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - CHIP_ERROR TestReadAttributeCatalogVendorId_3() + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() { - chip::Controller::ApplicationBasicClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeCatalogVendorId(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3(uint16_t catalogVendorId) + void OnSuccessResponse_4(bool onOff) { - VerifyOrReturn(CheckValue("catalogVendorId", catalogVendorId, 1U)); + VerifyOrReturn(CheckValue("onOff", onOff, 0)); NextTest(); } }; -class TV_MediaPlaybackCluster : public TestCommand +class Test_TC_CC_4_2 : public TestCommand { public: - TV_MediaPlaybackCluster() : TestCommand("TV_MediaPlaybackCluster"), mTestIndex(0) {} + Test_TC_CC_4_2() : TestCommand("Test_TC_CC_4_2"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -912,12 +1293,12 @@ class TV_MediaPlaybackCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TV_MediaPlaybackCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_4_2\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TV_MediaPlaybackCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_4_2\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -931,48 +1312,28 @@ class TV_MediaPlaybackCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Media Playback Play Command\n"); - err = TestMediaPlaybackPlayCommand_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Media Playback Pause Command\n"); - err = TestMediaPlaybackPauseCommand_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Media Playback Stop Command\n"); - err = TestMediaPlaybackStopCommand_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Move saturation up command\n"); + err = TestMoveSaturationUpCommand_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Media Playback Start Over Command\n"); - err = TestMediaPlaybackStartOverCommand_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Move saturation down command\n"); + err = TestMoveSaturationDownCommand_3(); break; case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Media Playback Previous Command\n"); - err = TestMediaPlaybackPreviousCommand_4(); + ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_4(); break; case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Media Playback Next Command\n"); - err = TestMediaPlaybackNextCommand_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : Media Playback Rewind Command\n"); - err = TestMediaPlaybackRewindCommand_6(); - break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : Media Playback Fast Forward Command\n"); - err = TestMediaPlaybackFastForwardCommand_7(); - break; - case 8: - ChipLogProgress(chipTool, " ***** Test Step 8 : Media Playback Skip Forward Command\n"); - err = TestMediaPlaybackSkipForwardCommand_8(); - break; - case 9: - ChipLogProgress(chipTool, " ***** Test Step 9 : Media Playback Skip Backward Command\n"); - err = TestMediaPlaybackSkipBackwardCommand_9(); - break; - case 10: - ChipLogProgress(chipTool, " ***** Test Step 10 : Media Playback Seek Command\n"); - err = TestMediaPlaybackSeekCommand_10(); + ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); break; } @@ -985,328 +1346,413 @@ class TV_MediaPlaybackCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 11; + const uint16_t mTestCount = 6; + + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); + } + + static void OnSuccessCallback_1(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_1(onOff); + } + + static void OnFailureCallback_5(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_5(status); + } + + static void OnSuccessCallback_5(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_5(onOff); + } // // Tests methods // - CHIP_ERROR TestMediaPlaybackPlayCommand_0() + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaPlay::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaPlayResponse::DecodableType; + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaPlayback::Commands::MediaPlay::Type request; + chip::app::Clusters::OnOff::Commands::On::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(data.mediaPlaybackStatus); + (static_cast(context))->OnSuccessResponse_0(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); }; return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint8_t mediaPlaybackStatus) - { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); - NextTest(); - } + void OnSuccessResponse_0() { NextTest(); } - CHIP_ERROR TestMediaPlaybackPauseCommand_1() + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); - - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaPause::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaPauseResponse::DecodableType; - - chip::app::Clusters::MediaPlayback::Commands::MediaPause::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(data.mediaPlaybackStatus); - }; + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint8_t mediaPlaybackStatus) + void OnSuccessResponse_1(bool onOff) { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + VerifyOrReturn(CheckValue("onOff", onOff, 1)); NextTest(); } - CHIP_ERROR TestMediaPlaybackStopCommand_2() + CHIP_ERROR TestMoveSaturationUpCommand_2() { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaStop::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaStopResponse::DecodableType; + using requestType = chip::app::Clusters::ColorControl::Commands::MoveSaturation::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaPlayback::Commands::MediaStop::Type request; + chip::app::Clusters::ColorControl::Commands::MoveSaturation::Type request; + request.moveMode = static_cast(1); + request.rate = 5; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(data.mediaPlaybackStatus); + (static_cast(context))->OnSuccessResponse_2(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_2(status); }; return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint8_t mediaPlaybackStatus) - { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); - NextTest(); - } + void OnSuccessResponse_2() { NextTest(); } - CHIP_ERROR TestMediaPlaybackStartOverCommand_3() + CHIP_ERROR TestMoveSaturationDownCommand_3() { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaStartOver::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaStartOverResponse::DecodableType; + using requestType = chip::app::Clusters::ColorControl::Commands::MoveSaturation::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaPlayback::Commands::MediaStartOver::Type request; + chip::app::Clusters::ColorControl::Commands::MoveSaturation::Type request; + request.moveMode = static_cast(3); + request.rate = 5; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(data.mediaPlaybackStatus); + (static_cast(context))->OnSuccessResponse_3(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); + (static_cast(context))->OnFailureResponse_3(status); }; return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3(uint8_t mediaPlaybackStatus) - { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); - NextTest(); - } + void OnSuccessResponse_3() { NextTest(); } - CHIP_ERROR TestMediaPlaybackPreviousCommand_4() + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaPrevious::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaPreviousResponse::DecodableType; + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaPlayback::Commands::MediaPrevious::Type request; + chip::app::Clusters::OnOff::Commands::Off::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(data.mediaPlaybackStatus); + (static_cast(context))->OnSuccessResponse_4(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_4(status); }; return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4(uint8_t mediaPlaybackStatus) + void OnSuccessResponse_4() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + } + + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_5(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); NextTest(); } +}; - CHIP_ERROR TestMediaPlaybackNextCommand_5() +class Test_TC_CC_4_3 : public TestCommand +{ +public: + Test_TC_CC_4_3() : TestCommand("Test_TC_CC_4_3"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); + CHIP_ERROR err = CHIP_NO_ERROR; - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaNext::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaNextResponse::DecodableType; + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_4_3\n"); + } - chip::app::Clusters::MediaPlayback::Commands::MediaNext::Type request; + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_4_3\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_5(data.mediaPlaybackStatus); - }; + Wait(); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_5(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Step saturation up command\n"); + err = TestStepSaturationUpCommand_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Step saturation down command\n"); + err = TestStepSaturationDownCommand_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); + break; + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 6; - void OnSuccessResponse_5(uint8_t mediaPlaybackStatus) + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + + static void OnFailureCallback_1(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); - NextTest(); + (static_cast(context))->OnFailureResponse_1(status); } - CHIP_ERROR TestMediaPlaybackRewindCommand_6() + static void OnSuccessCallback_1(void * context, bool onOff) { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); + (static_cast(context))->OnSuccessResponse_1(onOff); + } - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaRewind::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaRewindResponse::DecodableType; + static void OnFailureCallback_5(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_5(status); + } - chip::app::Clusters::MediaPlayback::Commands::MediaRewind::Type request; + static void OnSuccessCallback_5(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_5(onOff); + } + + // + // Tests methods + // + + CHIP_ERROR TestTurnOnLightForColorControlTests_0() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_6(data.mediaPlaybackStatus); + (static_cast(context))->OnSuccessResponse_0(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_6(status); + (static_cast(context))->OnFailureResponse_0(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_6(uint8_t mediaPlaybackStatus) + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + } + + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); NextTest(); } - CHIP_ERROR TestMediaPlaybackFastForwardCommand_7() + CHIP_ERROR TestStepSaturationUpCommand_2() { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaFastForward::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaFastForwardResponse::DecodableType; + using requestType = chip::app::Clusters::ColorControl::Commands::StepSaturation::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaPlayback::Commands::MediaFastForward::Type request; + chip::app::Clusters::ColorControl::Commands::StepSaturation::Type request; + request.stepMode = static_cast(1); + request.stepSize = 15; + request.transitionTime = 10; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_7(data.mediaPlaybackStatus); + (static_cast(context))->OnSuccessResponse_2(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_7(status); + (static_cast(context))->OnFailureResponse_2(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_7(uint8_t mediaPlaybackStatus) - { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); - NextTest(); - } + void OnSuccessResponse_2() { NextTest(); } - CHIP_ERROR TestMediaPlaybackSkipForwardCommand_8() + CHIP_ERROR TestStepSaturationDownCommand_3() { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaSkipForward::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaSkipForwardResponse::DecodableType; + using requestType = chip::app::Clusters::ColorControl::Commands::StepSaturation::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaPlayback::Commands::MediaSkipForward::Type request; - request.deltaPositionMilliseconds = 100ULL; + chip::app::Clusters::ColorControl::Commands::StepSaturation::Type request; + request.stepMode = static_cast(3); + request.stepSize = 20; + request.transitionTime = 10; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_8(data.mediaPlaybackStatus); + (static_cast(context))->OnSuccessResponse_3(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_8(status); + (static_cast(context))->OnFailureResponse_3(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_8(uint8_t mediaPlaybackStatus) - { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); - NextTest(); - } + void OnSuccessResponse_3() { NextTest(); } - CHIP_ERROR TestMediaPlaybackSkipBackwardCommand_9() + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaSkipBackward::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaSkipBackwardResponse::DecodableType; + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaPlayback::Commands::MediaSkipBackward::Type request; - request.deltaPositionMilliseconds = 100ULL; + chip::app::Clusters::OnOff::Commands::Off::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_9(data.mediaPlaybackStatus); + (static_cast(context))->OnSuccessResponse_4(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_9(status); + (static_cast(context))->OnFailureResponse_4(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_9(uint8_t mediaPlaybackStatus) - { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); - NextTest(); - } + void OnSuccessResponse_4() { NextTest(); } - CHIP_ERROR TestMediaPlaybackSeekCommand_10() + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() { - chip::Controller::MediaPlaybackClusterTest cluster; - cluster.Associate(mDevice, 3); - - using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaSeek::Type; - using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaSeekResponse::DecodableType; - - chip::app::Clusters::MediaPlayback::Commands::MediaSeek::Type request; - request.position = 100ULL; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_10(data.mediaPlaybackStatus); - }; + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_10(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); } - void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_10(uint8_t mediaPlaybackStatus) + void OnSuccessResponse_5(bool onOff) { - VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + VerifyOrReturn(CheckValue("onOff", onOff, 0)); NextTest(); } }; -class TV_TvChannelCluster : public TestCommand +class Test_TC_CC_4_4 : public TestCommand { public: - TV_TvChannelCluster() : TestCommand("TV_TvChannelCluster"), mTestIndex(0) {} + Test_TC_CC_4_4() : TestCommand("Test_TC_CC_4_4"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -1315,12 +1761,12 @@ class TV_TvChannelCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TV_TvChannelCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_4_4\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TV_TvChannelCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_4_4\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -1334,16 +1780,24 @@ class TV_TvChannelCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute TV Channel list\n"); - err = TestReadAttributeTvChannelList_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Change Channel By Number Command\n"); - err = TestChangeChannelByNumberCommand_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Skip Channel Command\n"); - err = TestSkipChannelCommand_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Move To current hue and saturation command\n"); + err = TestMoveToCurrentHueAndSaturationCommand_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); break; } @@ -1356,99 +1810,151 @@ class TV_TvChannelCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 3; + const uint16_t mTestCount = 5; - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ - OnSuccessCallback_0, this - }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; - static void OnFailureCallback_0(void * context, uint8_t status) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_0(void * context, uint16_t count, _TvChannelInfo * tvChannelList) + static void OnSuccessCallback_1(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_0(count, tvChannelList); + (static_cast(context))->OnSuccessResponse_1(onOff); + } + + static void OnFailureCallback_4(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_4(status); + } + + static void OnSuccessCallback_4(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_4(onOff); } // // Tests methods // - CHIP_ERROR TestReadAttributeTvChannelList_0() + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - chip::Controller::TvChannelClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeTvChannelList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint16_t count, _TvChannelInfo * tvChannelList) + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - VerifyOrReturn(CheckValueAsList("tvChannelList", count, 2)); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + } + + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); NextTest(); } - CHIP_ERROR TestChangeChannelByNumberCommand_1() + CHIP_ERROR TestMoveToCurrentHueAndSaturationCommand_2() { - chip::Controller::TvChannelClusterTest cluster; + chip::Controller::ColorControlClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::TvChannel::Commands::ChangeChannelByNumber::Type; + using requestType = chip::app::Clusters::ColorControl::Commands::MoveToHueAndSaturation::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::TvChannel::Commands::ChangeChannelByNumber::Type request; - request.majorNumber = 1U; - request.minorNumber = 2U; + chip::app::Clusters::ColorControl::Commands::MoveToHueAndSaturation::Type request; + request.hue = 40; + request.saturation = 160; + request.transitionTime = 10U; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(); + (static_cast(context))->OnSuccessResponse_2(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_2(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1() { NextTest(); } + void OnSuccessResponse_2() { NextTest(); } - CHIP_ERROR TestSkipChannelCommand_2() + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() { - chip::Controller::TvChannelClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::TvChannel::Commands::SkipChannel::Type; + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::TvChannel::Commands::SkipChannel::Type request; - request.count = 1U; + chip::app::Clusters::OnOff::Commands::Off::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); + (static_cast(context))->OnSuccessResponse_3(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_3(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_3() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + } + + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_4(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } }; -class TV_LowPowerCluster : public TestCommand +class Test_TC_CC_5_1 : public TestCommand { public: - TV_LowPowerCluster() : TestCommand("TV_LowPowerCluster"), mTestIndex(0) {} + Test_TC_CC_5_1() : TestCommand("Test_TC_CC_5_1"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -1457,12 +1963,12 @@ class TV_LowPowerCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TV_LowPowerCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_5_1\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TV_LowPowerCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_5_1\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -1476,8 +1982,24 @@ class TV_LowPowerCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Sleep Input Status Command\n"); - err = TestSleepInputStatusCommand_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Move to Color command\n"); + err = TestMoveToColorCommand_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); break; } @@ -1490,28 +2012,53 @@ class TV_LowPowerCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; + const uint16_t mTestCount = 5; + + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); + } + + static void OnSuccessCallback_1(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_1(onOff); + } + + static void OnFailureCallback_4(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_4(status); + } + + static void OnSuccessCallback_4(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_4(onOff); + } // // Tests methods // - CHIP_ERROR TestSleepInputStatusCommand_0() + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - chip::Controller::LowPowerClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::LowPower::Commands::Sleep::Type; + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::LowPower::Commands::Sleep::Type request; + chip::app::Clusters::OnOff::Commands::On::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); + (static_cast(context))->OnSuccessResponse_0(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); }; return cluster.InvokeCommand(request, this, success, failure); } @@ -1519,26 +2066,111 @@ class TV_LowPowerCluster : public TestCommand void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } void OnSuccessResponse_0() { NextTest(); } -}; - -class TV_MediaInputCluster : public TestCommand -{ -public: - TV_MediaInputCluster() : TestCommand("TV_MediaInputCluster"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: TV_MediaInputCluster\n"); - } + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + } - if (mTestCount == mTestIndex) + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } + + CHIP_ERROR TestMoveToColorCommand_2() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::MoveToColor::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::MoveToColor::Type request; + request.colorX = 200U; + request.colorY = 300U; + request.transitionTime = 20U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + } + + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_4(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } +}; + +class Test_TC_CC_5_2 : public TestCommand +{ +public: + Test_TC_CC_5_2() : TestCommand("Test_TC_CC_5_2"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; + + if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TV_MediaInputCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_5_2\n"); + } + + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_5_2\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -1552,28 +2184,28 @@ class TV_MediaInputCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute media input list\n"); - err = TestReadAttributeMediaInputList_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Select Input Command\n"); - err = TestSelectInputCommand_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Read current input list\n"); - err = TestReadCurrentInputList_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Move Color command\n"); + err = TestMoveColorCommand_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Hide Input Status Command\n"); - err = TestHideInputStatusCommand_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Stop Move Step command\n"); + err = TestStopMoveStepCommand_3(); break; case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Show Input Status Command\n"); - err = TestShowInputStatusCommand_4(); + ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_4(); break; case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Rename Input Command\n"); - err = TestRenameInputCommand_5(); + ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); break; } @@ -1588,187 +2220,188 @@ class TV_MediaInputCluster : public TestCommand std::atomic_uint16_t mTestIndex; const uint16_t mTestCount = 6; - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ - OnSuccessCallback_0, this - }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; - static void OnFailureCallback_0(void * context, uint8_t status) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_0(void * context, uint16_t count, _MediaInputInfo * mediaInputList) + static void OnSuccessCallback_1(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_0(count, mediaInputList); + (static_cast(context))->OnSuccessResponse_1(onOff); } - static void OnFailureCallback_2(void * context, uint8_t status) + static void OnFailureCallback_5(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_5(status); } - static void OnSuccessCallback_2(void * context, uint8_t currentMediaInput) + static void OnSuccessCallback_5(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_2(currentMediaInput); + (static_cast(context))->OnSuccessResponse_5(onOff); } // // Tests methods // - CHIP_ERROR TestReadAttributeMediaInputList_0() - { - chip::Controller::MediaInputClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeMediaInputList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); - } - - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0(uint16_t count, _MediaInputInfo * mediaInputList) - { - VerifyOrReturn(CheckValueAsList("mediaInputList", count, 2)); - NextTest(); - } - - CHIP_ERROR TestSelectInputCommand_1() + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - chip::Controller::MediaInputClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaInput::Commands::SelectInput::Type; + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaInput::Commands::SelectInput::Type request; - request.index = 1; + chip::app::Clusters::OnOff::Commands::On::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(); + (static_cast(context))->OnSuccessResponse_0(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_0(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1() { NextTest(); } + void OnSuccessResponse_0() { NextTest(); } - CHIP_ERROR TestReadCurrentInputList_2() + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - chip::Controller::MediaInputClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeCurrentMediaInput(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint8_t currentMediaInput) + void OnSuccessResponse_1(bool onOff) { - VerifyOrReturn(CheckValue("currentMediaInput", currentMediaInput, 1)); + VerifyOrReturn(CheckValue("onOff", onOff, 1)); NextTest(); } - CHIP_ERROR TestHideInputStatusCommand_3() + CHIP_ERROR TestMoveColorCommand_2() { - chip::Controller::MediaInputClusterTest cluster; + chip::Controller::ColorControlClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaInput::Commands::HideInputStatus::Type; + using requestType = chip::app::Clusters::ColorControl::Commands::MoveColor::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaInput::Commands::HideInputStatus::Type request; + chip::app::Clusters::ColorControl::Commands::MoveColor::Type request; + request.rateX = 15; + request.rateY = 20; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); + (static_cast(context))->OnSuccessResponse_2(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); + (static_cast(context))->OnFailureResponse_2(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_2() { NextTest(); } - CHIP_ERROR TestShowInputStatusCommand_4() + CHIP_ERROR TestStopMoveStepCommand_3() { - chip::Controller::MediaInputClusterTest cluster; + chip::Controller::ColorControlClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaInput::Commands::ShowInputStatus::Type; + using requestType = chip::app::Clusters::ColorControl::Commands::StopMoveStep::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaInput::Commands::ShowInputStatus::Type request; + chip::app::Clusters::ColorControl::Commands::StopMoveStep::Type request; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); + (static_cast(context))->OnSuccessResponse_3(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_3(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4() { NextTest(); } + void OnSuccessResponse_3() { NextTest(); } - CHIP_ERROR TestRenameInputCommand_5() + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() { - chip::Controller::MediaInputClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::MediaInput::Commands::RenameInput::Type; + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::MediaInput::Commands::RenameInput::Type request; - request.index = 1; - request.name = chip::Span("newName", strlen("newName")); + chip::app::Clusters::OnOff::Commands::Off::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_5(); + (static_cast(context))->OnSuccessResponse_4(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_5(status); + (static_cast(context))->OnFailureResponse_4(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_5() { NextTest(); } -}; + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } -class TestCluster : public TestCommand -{ -public: - TestCluster() : TestCommand("TestCluster"), mTestIndex(0) {} + void OnSuccessResponse_4() { NextTest(); } - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + } + + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_5(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } +}; + +class Test_TC_CC_5_3 : public TestCommand +{ +public: + Test_TC_CC_5_3() : TestCommand("Test_TC_CC_5_3"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override { CHIP_ERROR err = CHIP_NO_ERROR; if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TestCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_5_3\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TestCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_5_3\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -1782,492 +2415,1184 @@ class TestCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Send Test Command\n"); - err = TestSendTestCommand_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Send Test Not Handled Command\n"); - err = TestSendTestNotHandledCommand_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Send Test Specific Command\n"); - err = TestSendTestSpecificCommand_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Step Color command\n"); + err = TestStepColorCommand_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Send Test Add Arguments Command\n"); - err = TestSendTestAddArgumentsCommand_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_3(); break; case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Send failing Test Add Arguments Command\n"); - err = TestSendFailingTestAddArgumentsCommand_4(); + ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Read attribute BOOLEAN Default Value\n"); - err = TestReadAttributeBooleanDefaultValue_5(); + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } + } + +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 5; + + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); + } + + static void OnSuccessCallback_1(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_1(onOff); + } + + static void OnFailureCallback_4(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_4(status); + } + + static void OnSuccessCallback_4(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_4(onOff); + } + + // + // Tests methods + // + + CHIP_ERROR TestTurnOnLightForColorControlTests_0() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + } + + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } + + CHIP_ERROR TestStepColorCommand_2() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::StepColor::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::StepColor::Type request; + request.stepX = 15; + request.stepY = 20; + request.transitionTime = 50U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + } + + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_4(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } +}; + +class Test_TC_CC_6_1 : public TestCommand +{ +public: + Test_TC_CC_6_1() : TestCommand("Test_TC_CC_6_1"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; + + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_6_1\n"); + } + + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_6_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } + + Wait(); + + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : Write attribute BOOLEAN True\n"); - err = TestWriteAttributeBooleanTrue_6(); + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : Read attribute BOOLEAN True\n"); - err = TestReadAttributeBooleanTrue_7(); + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Move To Color Temperature command\n"); + err = TestMoveToColorTemperatureCommand_2(); break; - case 8: - ChipLogProgress(chipTool, " ***** Test Step 8 : Write attribute BOOLEAN False\n"); - err = TestWriteAttributeBooleanFalse_8(); + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_3(); break; - case 9: - ChipLogProgress(chipTool, " ***** Test Step 9 : Read attribute BOOLEAN False\n"); - err = TestReadAttributeBooleanFalse_9(); - break; - case 10: - ChipLogProgress(chipTool, " ***** Test Step 10 : Read attribute BITMAP8 Default Value\n"); - err = TestReadAttributeBitmap8DefaultValue_10(); - break; - case 11: - ChipLogProgress(chipTool, " ***** Test Step 11 : Write attribute BITMAP8 Max Value\n"); - err = TestWriteAttributeBitmap8MaxValue_11(); - break; - case 12: - ChipLogProgress(chipTool, " ***** Test Step 12 : Read attribute BITMAP8 Max Value\n"); - err = TestReadAttributeBitmap8MaxValue_12(); - break; - case 13: - ChipLogProgress(chipTool, " ***** Test Step 13 : Write attribute BITMAP8 Min Value\n"); - err = TestWriteAttributeBitmap8MinValue_13(); - break; - case 14: - ChipLogProgress(chipTool, " ***** Test Step 14 : Read attribute BITMAP8 Min Value\n"); - err = TestReadAttributeBitmap8MinValue_14(); - break; - case 15: - ChipLogProgress(chipTool, " ***** Test Step 15 : Read attribute BITMAP16 Default Value\n"); - err = TestReadAttributeBitmap16DefaultValue_15(); - break; - case 16: - ChipLogProgress(chipTool, " ***** Test Step 16 : Write attribute BITMAP16 Max Value\n"); - err = TestWriteAttributeBitmap16MaxValue_16(); + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); break; - case 17: - ChipLogProgress(chipTool, " ***** Test Step 17 : Read attribute BITMAP16 Max Value\n"); - err = TestReadAttributeBitmap16MaxValue_17(); + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } + } + +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 5; + + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); + } + + static void OnSuccessCallback_1(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_1(onOff); + } + + static void OnFailureCallback_4(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_4(status); + } + + static void OnSuccessCallback_4(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_4(onOff); + } + + // + // Tests methods + // + + CHIP_ERROR TestTurnOnLightForColorControlTests_0() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + } + + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } + + CHIP_ERROR TestMoveToColorTemperatureCommand_2() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::MoveToColorTemperature::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::MoveToColorTemperature::Type request; + request.colorTemperature = 100U; + request.transitionTime = 10U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + } + + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_4(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } +}; + +class Test_TC_CC_6_2 : public TestCommand +{ +public: + Test_TC_CC_6_2() : TestCommand("Test_TC_CC_6_2"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; + + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_6_2\n"); + } + + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_6_2\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } + + Wait(); + + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; - case 18: - ChipLogProgress(chipTool, " ***** Test Step 18 : Write attribute BITMAP16 Min Value\n"); - err = TestWriteAttributeBitmap16MinValue_18(); + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; - case 19: - ChipLogProgress(chipTool, " ***** Test Step 19 : Read attribute BITMAP16 Min Value\n"); - err = TestReadAttributeBitmap16MinValue_19(); + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Move up color temperature command\n"); + err = TestMoveUpColorTemperatureCommand_2(); break; - case 20: - ChipLogProgress(chipTool, " ***** Test Step 20 : Read attribute BITMAP32 Default Value\n"); - err = TestReadAttributeBitmap32DefaultValue_20(); + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Stop Color Temperature command\n"); + err = TestStopColorTemperatureCommand_3(); break; - case 21: - ChipLogProgress(chipTool, " ***** Test Step 21 : Write attribute BITMAP32 Max Value\n"); - err = TestWriteAttributeBitmap32MaxValue_21(); + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Move down color temperature command\n"); + err = TestMoveDownColorTemperatureCommand_4(); break; - case 22: - ChipLogProgress(chipTool, " ***** Test Step 22 : Read attribute BITMAP32 Max Value\n"); - err = TestReadAttributeBitmap32MaxValue_22(); + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_5(); break; - case 23: - ChipLogProgress(chipTool, " ***** Test Step 23 : Write attribute BITMAP32 Min Value\n"); - err = TestWriteAttributeBitmap32MinValue_23(); + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_6(); break; - case 24: - ChipLogProgress(chipTool, " ***** Test Step 24 : Read attribute BITMAP32 Min Value\n"); - err = TestReadAttributeBitmap32MinValue_24(); + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } + } + +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 7; + + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; + chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); + } + + static void OnSuccessCallback_1(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_1(onOff); + } + + static void OnFailureCallback_6(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_6(status); + } + + static void OnSuccessCallback_6(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_6(onOff); + } + + // + // Tests methods + // + + CHIP_ERROR TestTurnOnLightForColorControlTests_0() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + } + + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } + + CHIP_ERROR TestMoveUpColorTemperatureCommand_2() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type request; + request.moveMode = static_cast(1); + request.rate = 10U; + request.colorTemperatureMinimum = 1U; + request.colorTemperatureMaximum = 255U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestStopColorTemperatureCommand_3() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type request; + request.moveMode = static_cast(0); + request.rate = 10U; + request.colorTemperatureMinimum = 1U; + request.colorTemperatureMaximum = 255U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3() { NextTest(); } + + CHIP_ERROR TestMoveDownColorTemperatureCommand_4() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type request; + request.moveMode = static_cast(3); + request.rate = 20U; + request.colorTemperatureMinimum = 1U; + request.colorTemperatureMaximum = 255U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_4(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_4(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_4() { NextTest(); } + + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_5() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_5(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_5(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_5() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_6() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); + } + + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_6(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } +}; + +class Test_TC_CC_6_3 : public TestCommand +{ +public: + Test_TC_CC_6_3() : TestCommand("Test_TC_CC_6_3"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; + + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_6_3\n"); + } + + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_6_3\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } + + Wait(); + + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; - case 25: - ChipLogProgress(chipTool, " ***** Test Step 25 : Read attribute BITMAP64 Default Value\n"); - err = TestReadAttributeBitmap64DefaultValue_25(); + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; - case 26: - ChipLogProgress(chipTool, " ***** Test Step 26 : Write attribute BITMAP64 Max Value\n"); - err = TestWriteAttributeBitmap64MaxValue_26(); + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Step up color temperature command\n"); + err = TestStepUpColorTemperatureCommand_2(); break; - case 27: - ChipLogProgress(chipTool, " ***** Test Step 27 : Read attribute BITMAP64 Max Value\n"); - err = TestReadAttributeBitmap64MaxValue_27(); + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Step down color temperature command\n"); + err = TestStepDownColorTemperatureCommand_3(); break; - case 28: - ChipLogProgress(chipTool, " ***** Test Step 28 : Write attribute BITMAP64 Min Value\n"); - err = TestWriteAttributeBitmap64MinValue_28(); + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_4(); break; - case 29: - ChipLogProgress(chipTool, " ***** Test Step 29 : Read attribute BITMAP64 Min Value\n"); - err = TestReadAttributeBitmap64MinValue_29(); + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); break; - case 30: - ChipLogProgress(chipTool, " ***** Test Step 30 : Read attribute INT8U Default Value\n"); - err = TestReadAttributeInt8uDefaultValue_30(); + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } + } + +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 6; + + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); + } + + static void OnSuccessCallback_1(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_1(onOff); + } + + static void OnFailureCallback_5(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_5(status); + } + + static void OnSuccessCallback_5(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_5(onOff); + } + + // + // Tests methods + // + + CHIP_ERROR TestTurnOnLightForColorControlTests_0() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + } + + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } + + CHIP_ERROR TestStepUpColorTemperatureCommand_2() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::StepColorTemperature::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::StepColorTemperature::Type request; + request.stepMode = static_cast(1); + request.stepSize = 5U; + request.transitionTime = 50U; + request.colorTemperatureMinimum = 5U; + request.colorTemperatureMaximum = 100U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestStepDownColorTemperatureCommand_3() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::StepColorTemperature::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::StepColorTemperature::Type request; + request.stepMode = static_cast(3); + request.stepSize = 5U; + request.transitionTime = 50U; + request.colorTemperatureMinimum = 5U; + request.colorTemperatureMaximum = 100U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3() { NextTest(); } + + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_4(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_4(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_4() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + } + + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_5(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } +}; + +class Test_TC_CC_7_1 : public TestCommand +{ +public: + Test_TC_CC_7_1() : TestCommand("Test_TC_CC_7_1"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; + + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_7_1\n"); + } + + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_7_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } + + Wait(); + + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; - case 31: - ChipLogProgress(chipTool, " ***** Test Step 31 : Write attribute INT8U Max Value\n"); - err = TestWriteAttributeInt8uMaxValue_31(); + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; - case 32: - ChipLogProgress(chipTool, " ***** Test Step 32 : Read attribute INT8U Max Value\n"); - err = TestReadAttributeInt8uMaxValue_32(); + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Enhanced Move To Hue command\n"); + err = TestEnhancedMoveToHueCommand_2(); break; - case 33: - ChipLogProgress(chipTool, " ***** Test Step 33 : Write attribute INT8U Min Value\n"); - err = TestWriteAttributeInt8uMinValue_33(); - break; - case 34: - ChipLogProgress(chipTool, " ***** Test Step 34 : Read attribute INT8U Min Value\n"); - err = TestReadAttributeInt8uMinValue_34(); + case 3: + ChipLogProgress( + chipTool, " ***** Test Step 3 : Check Remaining time attribute value matched the value sent by the last command\n"); + err = TestCheckRemainingTimeAttributeValueMatchedTheValueSentByTheLastCommand_3(); break; - case 35: - ChipLogProgress(chipTool, " ***** Test Step 35 : Read attribute INT16U Default Value\n"); - err = TestReadAttributeInt16uDefaultValue_35(); + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_4(); break; - case 36: - ChipLogProgress(chipTool, " ***** Test Step 36 : Write attribute INT16U Max Value\n"); - err = TestWriteAttributeInt16uMaxValue_36(); + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); break; - case 37: - ChipLogProgress(chipTool, " ***** Test Step 37 : Read attribute INT16U Max Value\n"); - err = TestReadAttributeInt16uMaxValue_37(); + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } + } + +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 6; + + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); + } + + static void OnSuccessCallback_1(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_1(onOff); + } + + static void OnFailureCallback_3(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_3(status); + } + + static void OnSuccessCallback_3(void * context, uint16_t remainingTime) + { + (static_cast(context))->OnSuccessResponse_3(remainingTime); + } + + static void OnFailureCallback_5(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_5(status); + } + + static void OnSuccessCallback_5(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_5(onOff); + } + + // + // Tests methods + // + + CHIP_ERROR TestTurnOnLightForColorControlTests_0() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + } + + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } + + CHIP_ERROR TestEnhancedMoveToHueCommand_2() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveToHue::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ColorControl::Commands::EnhancedMoveToHue::Type request; + request.enhancedHue = 1025U; + request.direction = static_cast(0); + request.transitionTime = 1U; + request.optionsMask = 0; + request.optionsOverride = 0; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestCheckRemainingTimeAttributeValueMatchedTheValueSentByTheLastCommand_3() + { + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeRemainingTime(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + } + + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3(uint16_t remainingTime) + { + VerifyOrReturn(CheckValue("remainingTime", remainingTime, 1U)); + NextTest(); + } + + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_4(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_4(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_4() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + } + + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_5(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } +}; + +class Test_TC_CC_7_2 : public TestCommand +{ +public: + Test_TC_CC_7_2() : TestCommand("Test_TC_CC_7_2"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; + + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_7_2\n"); + } + + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_7_2\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } + + Wait(); + + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); break; - case 38: - ChipLogProgress(chipTool, " ***** Test Step 38 : Write attribute INT16U Min Value\n"); - err = TestWriteAttributeInt16uMinValue_38(); + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); break; - case 39: - ChipLogProgress(chipTool, " ***** Test Step 39 : Read attribute INT16U Min Value\n"); - err = TestReadAttributeInt16uMinValue_39(); + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Enhanced Move Hue Down command \n"); + err = TestEnhancedMoveHueDownCommand_2(); break; - case 40: - ChipLogProgress(chipTool, " ***** Test Step 40 : Read attribute INT32U Default Value\n"); - err = TestReadAttributeInt32uDefaultValue_40(); + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Enhanced Move Hue Stop command\n"); + err = TestEnhancedMoveHueStopCommand_3(); break; - case 41: - ChipLogProgress(chipTool, " ***** Test Step 41 : Write attribute INT32U Max Value\n"); - err = TestWriteAttributeInt32uMaxValue_41(); - break; - case 42: - ChipLogProgress(chipTool, " ***** Test Step 42 : Read attribute INT32U Max Value\n"); - err = TestReadAttributeInt32uMaxValue_42(); - break; - case 43: - ChipLogProgress(chipTool, " ***** Test Step 43 : Write attribute INT32U Min Value\n"); - err = TestWriteAttributeInt32uMinValue_43(); - break; - case 44: - ChipLogProgress(chipTool, " ***** Test Step 44 : Read attribute INT32U Min Value\n"); - err = TestReadAttributeInt32uMinValue_44(); - break; - case 45: - ChipLogProgress(chipTool, " ***** Test Step 45 : Read attribute INT64U Default Value\n"); - err = TestReadAttributeInt64uDefaultValue_45(); - break; - case 46: - ChipLogProgress(chipTool, " ***** Test Step 46 : Write attribute INT64U Max Value\n"); - err = TestWriteAttributeInt64uMaxValue_46(); - break; - case 47: - ChipLogProgress(chipTool, " ***** Test Step 47 : Read attribute INT64U Max Value\n"); - err = TestReadAttributeInt64uMaxValue_47(); - break; - case 48: - ChipLogProgress(chipTool, " ***** Test Step 48 : Write attribute INT64U Min Value\n"); - err = TestWriteAttributeInt64uMinValue_48(); - break; - case 49: - ChipLogProgress(chipTool, " ***** Test Step 49 : Read attribute INT64U Min Value\n"); - err = TestReadAttributeInt64uMinValue_49(); - break; - case 50: - ChipLogProgress(chipTool, " ***** Test Step 50 : Read attribute INT8S Default Value\n"); - err = TestReadAttributeInt8sDefaultValue_50(); - break; - case 51: - ChipLogProgress(chipTool, " ***** Test Step 51 : Write attribute INT8S Max Value\n"); - err = TestWriteAttributeInt8sMaxValue_51(); - break; - case 52: - ChipLogProgress(chipTool, " ***** Test Step 52 : Read attribute INT8S Max Value\n"); - err = TestReadAttributeInt8sMaxValue_52(); - break; - case 53: - ChipLogProgress(chipTool, " ***** Test Step 53 : Write attribute INT8S Min Value\n"); - err = TestWriteAttributeInt8sMinValue_53(); - break; - case 54: - ChipLogProgress(chipTool, " ***** Test Step 54 : Read attribute INT8S Min Value\n"); - err = TestReadAttributeInt8sMinValue_54(); - break; - case 55: - ChipLogProgress(chipTool, " ***** Test Step 55 : Write attribute INT8S Default Value\n"); - err = TestWriteAttributeInt8sDefaultValue_55(); - break; - case 56: - ChipLogProgress(chipTool, " ***** Test Step 56 : Read attribute INT8S Default Value\n"); - err = TestReadAttributeInt8sDefaultValue_56(); - break; - case 57: - ChipLogProgress(chipTool, " ***** Test Step 57 : Read attribute INT16S Default Value\n"); - err = TestReadAttributeInt16sDefaultValue_57(); - break; - case 58: - ChipLogProgress(chipTool, " ***** Test Step 58 : Write attribute INT16S Max Value\n"); - err = TestWriteAttributeInt16sMaxValue_58(); - break; - case 59: - ChipLogProgress(chipTool, " ***** Test Step 59 : Read attribute INT16S Max Value\n"); - err = TestReadAttributeInt16sMaxValue_59(); - break; - case 60: - ChipLogProgress(chipTool, " ***** Test Step 60 : Write attribute INT16S Min Value\n"); - err = TestWriteAttributeInt16sMinValue_60(); - break; - case 61: - ChipLogProgress(chipTool, " ***** Test Step 61 : Read attribute INT16S Min Value\n"); - err = TestReadAttributeInt16sMinValue_61(); - break; - case 62: - ChipLogProgress(chipTool, " ***** Test Step 62 : Write attribute INT16S Default Value\n"); - err = TestWriteAttributeInt16sDefaultValue_62(); - break; - case 63: - ChipLogProgress(chipTool, " ***** Test Step 63 : Read attribute INT16S Default Value\n"); - err = TestReadAttributeInt16sDefaultValue_63(); - break; - case 64: - ChipLogProgress(chipTool, " ***** Test Step 64 : Read attribute INT32S Default Value\n"); - err = TestReadAttributeInt32sDefaultValue_64(); - break; - case 65: - ChipLogProgress(chipTool, " ***** Test Step 65 : Write attribute INT32S Max Value\n"); - err = TestWriteAttributeInt32sMaxValue_65(); - break; - case 66: - ChipLogProgress(chipTool, " ***** Test Step 66 : Read attribute INT32S Max Value\n"); - err = TestReadAttributeInt32sMaxValue_66(); - break; - case 67: - ChipLogProgress(chipTool, " ***** Test Step 67 : Write attribute INT32S Min Value\n"); - err = TestWriteAttributeInt32sMinValue_67(); - break; - case 68: - ChipLogProgress(chipTool, " ***** Test Step 68 : Read attribute INT32S Min Value\n"); - err = TestReadAttributeInt32sMinValue_68(); - break; - case 69: - ChipLogProgress(chipTool, " ***** Test Step 69 : Write attribute INT32S Default Value\n"); - err = TestWriteAttributeInt32sDefaultValue_69(); - break; - case 70: - ChipLogProgress(chipTool, " ***** Test Step 70 : Read attribute INT32S Default Value\n"); - err = TestReadAttributeInt32sDefaultValue_70(); - break; - case 71: - ChipLogProgress(chipTool, " ***** Test Step 71 : Read attribute INT64S Default Value\n"); - err = TestReadAttributeInt64sDefaultValue_71(); - break; - case 72: - ChipLogProgress(chipTool, " ***** Test Step 72 : Write attribute INT64S Max Value\n"); - err = TestWriteAttributeInt64sMaxValue_72(); - break; - case 73: - ChipLogProgress(chipTool, " ***** Test Step 73 : Read attribute INT64S Max Value\n"); - err = TestReadAttributeInt64sMaxValue_73(); - break; - case 74: - ChipLogProgress(chipTool, " ***** Test Step 74 : Write attribute INT64S Min Value\n"); - err = TestWriteAttributeInt64sMinValue_74(); - break; - case 75: - ChipLogProgress(chipTool, " ***** Test Step 75 : Read attribute INT64S Min Value\n"); - err = TestReadAttributeInt64sMinValue_75(); - break; - case 76: - ChipLogProgress(chipTool, " ***** Test Step 76 : Write attribute INT64S Default Value\n"); - err = TestWriteAttributeInt64sDefaultValue_76(); - break; - case 77: - ChipLogProgress(chipTool, " ***** Test Step 77 : Read attribute INT64S Default Value\n"); - err = TestReadAttributeInt64sDefaultValue_77(); - break; - case 78: - ChipLogProgress(chipTool, " ***** Test Step 78 : Read attribute ENUM8 Default Value\n"); - err = TestReadAttributeEnum8DefaultValue_78(); - break; - case 79: - ChipLogProgress(chipTool, " ***** Test Step 79 : Write attribute ENUM8 Max Value\n"); - err = TestWriteAttributeEnum8MaxValue_79(); - break; - case 80: - ChipLogProgress(chipTool, " ***** Test Step 80 : Read attribute ENUM8 Max Value\n"); - err = TestReadAttributeEnum8MaxValue_80(); - break; - case 81: - ChipLogProgress(chipTool, " ***** Test Step 81 : Write attribute ENUM8 Min Value\n"); - err = TestWriteAttributeEnum8MinValue_81(); - break; - case 82: - ChipLogProgress(chipTool, " ***** Test Step 82 : Read attribute ENUM8 Min Value\n"); - err = TestReadAttributeEnum8MinValue_82(); - break; - case 83: - ChipLogProgress(chipTool, " ***** Test Step 83 : Read attribute ENUM16 Default Value\n"); - err = TestReadAttributeEnum16DefaultValue_83(); - break; - case 84: - ChipLogProgress(chipTool, " ***** Test Step 84 : Write attribute ENUM16 Max Value\n"); - err = TestWriteAttributeEnum16MaxValue_84(); - break; - case 85: - ChipLogProgress(chipTool, " ***** Test Step 85 : Read attribute ENUM16 Max Value\n"); - err = TestReadAttributeEnum16MaxValue_85(); - break; - case 86: - ChipLogProgress(chipTool, " ***** Test Step 86 : Write attribute ENUM16 Min Value\n"); - err = TestWriteAttributeEnum16MinValue_86(); - break; - case 87: - ChipLogProgress(chipTool, " ***** Test Step 87 : Read attribute ENUM16 Min Value\n"); - err = TestReadAttributeEnum16MinValue_87(); - break; - case 88: - ChipLogProgress(chipTool, " ***** Test Step 88 : Read attribute OCTET_STRING Default Value\n"); - err = TestReadAttributeOctetStringDefaultValue_88(); - break; - case 89: - ChipLogProgress(chipTool, " ***** Test Step 89 : Write attribute OCTET_STRING\n"); - err = TestWriteAttributeOctetString_89(); - break; - case 90: - ChipLogProgress(chipTool, " ***** Test Step 90 : Read attribute OCTET_STRING\n"); - err = TestReadAttributeOctetString_90(); - break; - case 91: - ChipLogProgress(chipTool, " ***** Test Step 91 : Write attribute OCTET_STRING\n"); - err = TestWriteAttributeOctetString_91(); - break; - case 92: - ChipLogProgress(chipTool, " ***** Test Step 92 : Read attribute OCTET_STRING\n"); - err = TestReadAttributeOctetString_92(); - break; - case 93: - ChipLogProgress(chipTool, " ***** Test Step 93 : Write attribute OCTET_STRING\n"); - err = TestWriteAttributeOctetString_93(); - break; - case 94: - ChipLogProgress(chipTool, " ***** Test Step 94 : Read attribute LONG_OCTET_STRING Default Value\n"); - err = TestReadAttributeLongOctetStringDefaultValue_94(); - break; - case 95: - ChipLogProgress(chipTool, " ***** Test Step 95 : Write attribute LONG_OCTET_STRING\n"); - err = TestWriteAttributeLongOctetString_95(); - break; - case 96: - ChipLogProgress(chipTool, " ***** Test Step 96 : Read attribute LONG_OCTET_STRING\n"); - err = TestReadAttributeLongOctetString_96(); - break; - case 97: - ChipLogProgress(chipTool, " ***** Test Step 97 : Write attribute LONG_OCTET_STRING\n"); - err = TestWriteAttributeLongOctetString_97(); - break; - case 98: - ChipLogProgress(chipTool, " ***** Test Step 98 : Read attribute CHAR_STRING Default Value\n"); - err = TestReadAttributeCharStringDefaultValue_98(); - break; - case 99: - ChipLogProgress(chipTool, " ***** Test Step 99 : Write attribute CHAR_STRING\n"); - err = TestWriteAttributeCharString_99(); + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Enhanced Move Hue Up command\n"); + err = TestEnhancedMoveHueUpCommand_4(); break; - case 100: - ChipLogProgress(chipTool, " ***** Test Step 100 : Write attribute CHAR_STRING - Value too long\n"); - err = TestWriteAttributeCharStringValueTooLong_100(); + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Enhanced Move Hue Stop command\n"); + err = TestEnhancedMoveHueStopCommand_5(); break; - case 101: - ChipLogProgress(chipTool, " ***** Test Step 101 : Write attribute CHAR_STRING - Empty\n"); - err = TestWriteAttributeCharStringEmpty_101(); + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_6(); break; - case 102: - ChipLogProgress(chipTool, " ***** Test Step 102 : Read attribute LONG_CHAR_STRING Default Value\n"); - err = TestReadAttributeLongCharStringDefaultValue_102(); - break; - case 103: - ChipLogProgress(chipTool, " ***** Test Step 103 : Write attribute LONG_CHAR_STRING\n"); - err = TestWriteAttributeLongCharString_103(); - break; - case 104: - ChipLogProgress(chipTool, " ***** Test Step 104 : Read attribute LONG_CHAR_STRING\n"); - err = TestReadAttributeLongCharString_104(); - break; - case 105: - ChipLogProgress(chipTool, " ***** Test Step 105 : Write attribute LONG_CHAR_STRING\n"); - err = TestWriteAttributeLongCharString_105(); - break; - case 106: - ChipLogProgress(chipTool, " ***** Test Step 106 : Read attribute LIST\n"); - err = TestReadAttributeList_106(); - break; - case 107: - ChipLogProgress(chipTool, " ***** Test Step 107 : Read attribute LIST_OCTET_STRING\n"); - err = TestReadAttributeListOctetString_107(); - break; - case 108: - ChipLogProgress(chipTool, " ***** Test Step 108 : Read attribute LIST_STRUCT_OCTET_STRING\n"); - err = TestReadAttributeListStructOctetString_108(); - break; - case 109: - ChipLogProgress(chipTool, " ***** Test Step 109 : Read attribute EPOCH_US Default Value\n"); - err = TestReadAttributeEpochUsDefaultValue_109(); - break; - case 110: - ChipLogProgress(chipTool, " ***** Test Step 110 : Write attribute EPOCH_US Max Value\n"); - err = TestWriteAttributeEpochUsMaxValue_110(); - break; - case 111: - ChipLogProgress(chipTool, " ***** Test Step 111 : Read attribute EPOCH_US Max Value\n"); - err = TestReadAttributeEpochUsMaxValue_111(); - break; - case 112: - ChipLogProgress(chipTool, " ***** Test Step 112 : Write attribute EPOCH_US Min Value\n"); - err = TestWriteAttributeEpochUsMinValue_112(); - break; - case 113: - ChipLogProgress(chipTool, " ***** Test Step 113 : Read attribute EPOCH_US Min Value\n"); - err = TestReadAttributeEpochUsMinValue_113(); - break; - case 114: - ChipLogProgress(chipTool, " ***** Test Step 114 : Read attribute EPOCH_S Default Value\n"); - err = TestReadAttributeEpochSDefaultValue_114(); - break; - case 115: - ChipLogProgress(chipTool, " ***** Test Step 115 : Write attribute EPOCH_S Max Value\n"); - err = TestWriteAttributeEpochSMaxValue_115(); - break; - case 116: - ChipLogProgress(chipTool, " ***** Test Step 116 : Read attribute EPOCH_S Max Value\n"); - err = TestReadAttributeEpochSMaxValue_116(); - break; - case 117: - ChipLogProgress(chipTool, " ***** Test Step 117 : Write attribute EPOCH_S Min Value\n"); - err = TestWriteAttributeEpochSMinValue_117(); - break; - case 118: - ChipLogProgress(chipTool, " ***** Test Step 118 : Read attribute EPOCH_S Min Value\n"); - err = TestReadAttributeEpochSMinValue_118(); - break; - case 119: - ChipLogProgress(chipTool, " ***** Test Step 119 : Read attribute UNSUPPORTED\n"); - err = TestReadAttributeUnsupported_119(); - break; - case 120: - ChipLogProgress(chipTool, " ***** Test Step 120 : Writeattribute UNSUPPORTED\n"); - err = TestWriteattributeUnsupported_120(); - break; - case 121: - ChipLogProgress(chipTool, " ***** Test Step 121 : Send Test Command to unsupported endpoint\n"); - err = TestSendTestCommandToUnsupportedEndpoint_121(); + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7(); break; } @@ -2280,3401 +3605,3355 @@ class TestCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 122; + const uint16_t mTestCount = 8; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; - chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; - chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; - chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; - chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; - chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; - chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; - chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; - chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, this }; - chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; - chip::Callback::Callback mOnSuccessCallback_11{ OnSuccessCallback_11, this }; - chip::Callback::Callback mOnFailureCallback_12{ OnFailureCallback_12, this }; - chip::Callback::Callback mOnSuccessCallback_12{ OnSuccessCallback_12, this }; - chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; - chip::Callback::Callback mOnSuccessCallback_13{ OnSuccessCallback_13, this }; - chip::Callback::Callback mOnFailureCallback_14{ OnFailureCallback_14, this }; - chip::Callback::Callback mOnSuccessCallback_14{ OnSuccessCallback_14, this }; - chip::Callback::Callback mOnFailureCallback_15{ OnFailureCallback_15, this }; - chip::Callback::Callback mOnSuccessCallback_15{ OnSuccessCallback_15, this }; - chip::Callback::Callback mOnFailureCallback_16{ OnFailureCallback_16, this }; - chip::Callback::Callback mOnSuccessCallback_16{ OnSuccessCallback_16, this }; - chip::Callback::Callback mOnFailureCallback_17{ OnFailureCallback_17, this }; - chip::Callback::Callback mOnSuccessCallback_17{ OnSuccessCallback_17, this }; - chip::Callback::Callback mOnFailureCallback_18{ OnFailureCallback_18, this }; - chip::Callback::Callback mOnSuccessCallback_18{ OnSuccessCallback_18, this }; - chip::Callback::Callback mOnFailureCallback_19{ OnFailureCallback_19, this }; - chip::Callback::Callback mOnSuccessCallback_19{ OnSuccessCallback_19, this }; - chip::Callback::Callback mOnFailureCallback_20{ OnFailureCallback_20, this }; - chip::Callback::Callback mOnSuccessCallback_20{ OnSuccessCallback_20, this }; - chip::Callback::Callback mOnFailureCallback_21{ OnFailureCallback_21, this }; - chip::Callback::Callback mOnSuccessCallback_21{ OnSuccessCallback_21, this }; - chip::Callback::Callback mOnFailureCallback_22{ OnFailureCallback_22, this }; - chip::Callback::Callback mOnSuccessCallback_22{ OnSuccessCallback_22, this }; - chip::Callback::Callback mOnFailureCallback_23{ OnFailureCallback_23, this }; - chip::Callback::Callback mOnSuccessCallback_23{ OnSuccessCallback_23, this }; - chip::Callback::Callback mOnFailureCallback_24{ OnFailureCallback_24, this }; - chip::Callback::Callback mOnSuccessCallback_24{ OnSuccessCallback_24, this }; - chip::Callback::Callback mOnFailureCallback_25{ OnFailureCallback_25, this }; - chip::Callback::Callback mOnSuccessCallback_25{ OnSuccessCallback_25, this }; - chip::Callback::Callback mOnFailureCallback_26{ OnFailureCallback_26, this }; - chip::Callback::Callback mOnSuccessCallback_26{ OnSuccessCallback_26, this }; - chip::Callback::Callback mOnFailureCallback_27{ OnFailureCallback_27, this }; - chip::Callback::Callback mOnSuccessCallback_27{ OnSuccessCallback_27, this }; - chip::Callback::Callback mOnFailureCallback_28{ OnFailureCallback_28, this }; - chip::Callback::Callback mOnSuccessCallback_28{ OnSuccessCallback_28, this }; - chip::Callback::Callback mOnFailureCallback_29{ OnFailureCallback_29, this }; - chip::Callback::Callback mOnSuccessCallback_29{ OnSuccessCallback_29, this }; - chip::Callback::Callback mOnFailureCallback_30{ OnFailureCallback_30, this }; - chip::Callback::Callback mOnSuccessCallback_30{ OnSuccessCallback_30, this }; - chip::Callback::Callback mOnFailureCallback_31{ OnFailureCallback_31, this }; - chip::Callback::Callback mOnSuccessCallback_31{ OnSuccessCallback_31, this }; - chip::Callback::Callback mOnFailureCallback_32{ OnFailureCallback_32, this }; - chip::Callback::Callback mOnSuccessCallback_32{ OnSuccessCallback_32, this }; - chip::Callback::Callback mOnFailureCallback_33{ OnFailureCallback_33, this }; - chip::Callback::Callback mOnSuccessCallback_33{ OnSuccessCallback_33, this }; - chip::Callback::Callback mOnFailureCallback_34{ OnFailureCallback_34, this }; - chip::Callback::Callback mOnSuccessCallback_34{ OnSuccessCallback_34, this }; - chip::Callback::Callback mOnFailureCallback_35{ OnFailureCallback_35, this }; - chip::Callback::Callback mOnSuccessCallback_35{ OnSuccessCallback_35, this }; - chip::Callback::Callback mOnFailureCallback_36{ OnFailureCallback_36, this }; - chip::Callback::Callback mOnSuccessCallback_36{ OnSuccessCallback_36, this }; - chip::Callback::Callback mOnFailureCallback_37{ OnFailureCallback_37, this }; - chip::Callback::Callback mOnSuccessCallback_37{ OnSuccessCallback_37, this }; - chip::Callback::Callback mOnFailureCallback_38{ OnFailureCallback_38, this }; - chip::Callback::Callback mOnSuccessCallback_38{ OnSuccessCallback_38, this }; - chip::Callback::Callback mOnFailureCallback_39{ OnFailureCallback_39, this }; - chip::Callback::Callback mOnSuccessCallback_39{ OnSuccessCallback_39, this }; - chip::Callback::Callback mOnFailureCallback_40{ OnFailureCallback_40, this }; - chip::Callback::Callback mOnSuccessCallback_40{ OnSuccessCallback_40, this }; - chip::Callback::Callback mOnFailureCallback_41{ OnFailureCallback_41, this }; - chip::Callback::Callback mOnSuccessCallback_41{ OnSuccessCallback_41, this }; - chip::Callback::Callback mOnFailureCallback_42{ OnFailureCallback_42, this }; - chip::Callback::Callback mOnSuccessCallback_42{ OnSuccessCallback_42, this }; - chip::Callback::Callback mOnFailureCallback_43{ OnFailureCallback_43, this }; - chip::Callback::Callback mOnSuccessCallback_43{ OnSuccessCallback_43, this }; - chip::Callback::Callback mOnFailureCallback_44{ OnFailureCallback_44, this }; - chip::Callback::Callback mOnSuccessCallback_44{ OnSuccessCallback_44, this }; - chip::Callback::Callback mOnFailureCallback_45{ OnFailureCallback_45, this }; - chip::Callback::Callback mOnSuccessCallback_45{ OnSuccessCallback_45, this }; - chip::Callback::Callback mOnFailureCallback_46{ OnFailureCallback_46, this }; - chip::Callback::Callback mOnSuccessCallback_46{ OnSuccessCallback_46, this }; - chip::Callback::Callback mOnFailureCallback_47{ OnFailureCallback_47, this }; - chip::Callback::Callback mOnSuccessCallback_47{ OnSuccessCallback_47, this }; - chip::Callback::Callback mOnFailureCallback_48{ OnFailureCallback_48, this }; - chip::Callback::Callback mOnSuccessCallback_48{ OnSuccessCallback_48, this }; - chip::Callback::Callback mOnFailureCallback_49{ OnFailureCallback_49, this }; - chip::Callback::Callback mOnSuccessCallback_49{ OnSuccessCallback_49, this }; - chip::Callback::Callback mOnFailureCallback_50{ OnFailureCallback_50, this }; - chip::Callback::Callback mOnSuccessCallback_50{ OnSuccessCallback_50, this }; - chip::Callback::Callback mOnFailureCallback_51{ OnFailureCallback_51, this }; - chip::Callback::Callback mOnSuccessCallback_51{ OnSuccessCallback_51, this }; - chip::Callback::Callback mOnFailureCallback_52{ OnFailureCallback_52, this }; - chip::Callback::Callback mOnSuccessCallback_52{ OnSuccessCallback_52, this }; - chip::Callback::Callback mOnFailureCallback_53{ OnFailureCallback_53, this }; - chip::Callback::Callback mOnSuccessCallback_53{ OnSuccessCallback_53, this }; - chip::Callback::Callback mOnFailureCallback_54{ OnFailureCallback_54, this }; - chip::Callback::Callback mOnSuccessCallback_54{ OnSuccessCallback_54, this }; - chip::Callback::Callback mOnFailureCallback_55{ OnFailureCallback_55, this }; - chip::Callback::Callback mOnSuccessCallback_55{ OnSuccessCallback_55, this }; - chip::Callback::Callback mOnFailureCallback_56{ OnFailureCallback_56, this }; - chip::Callback::Callback mOnSuccessCallback_56{ OnSuccessCallback_56, this }; - chip::Callback::Callback mOnFailureCallback_57{ OnFailureCallback_57, this }; - chip::Callback::Callback mOnSuccessCallback_57{ OnSuccessCallback_57, this }; - chip::Callback::Callback mOnFailureCallback_58{ OnFailureCallback_58, this }; - chip::Callback::Callback mOnSuccessCallback_58{ OnSuccessCallback_58, this }; - chip::Callback::Callback mOnFailureCallback_59{ OnFailureCallback_59, this }; - chip::Callback::Callback mOnSuccessCallback_59{ OnSuccessCallback_59, this }; - chip::Callback::Callback mOnFailureCallback_60{ OnFailureCallback_60, this }; - chip::Callback::Callback mOnSuccessCallback_60{ OnSuccessCallback_60, this }; - chip::Callback::Callback mOnFailureCallback_61{ OnFailureCallback_61, this }; - chip::Callback::Callback mOnSuccessCallback_61{ OnSuccessCallback_61, this }; - chip::Callback::Callback mOnFailureCallback_62{ OnFailureCallback_62, this }; - chip::Callback::Callback mOnSuccessCallback_62{ OnSuccessCallback_62, this }; - chip::Callback::Callback mOnFailureCallback_63{ OnFailureCallback_63, this }; - chip::Callback::Callback mOnSuccessCallback_63{ OnSuccessCallback_63, this }; - chip::Callback::Callback mOnFailureCallback_64{ OnFailureCallback_64, this }; - chip::Callback::Callback mOnSuccessCallback_64{ OnSuccessCallback_64, this }; - chip::Callback::Callback mOnFailureCallback_65{ OnFailureCallback_65, this }; - chip::Callback::Callback mOnSuccessCallback_65{ OnSuccessCallback_65, this }; - chip::Callback::Callback mOnFailureCallback_66{ OnFailureCallback_66, this }; - chip::Callback::Callback mOnSuccessCallback_66{ OnSuccessCallback_66, this }; - chip::Callback::Callback mOnFailureCallback_67{ OnFailureCallback_67, this }; - chip::Callback::Callback mOnSuccessCallback_67{ OnSuccessCallback_67, this }; - chip::Callback::Callback mOnFailureCallback_68{ OnFailureCallback_68, this }; - chip::Callback::Callback mOnSuccessCallback_68{ OnSuccessCallback_68, this }; - chip::Callback::Callback mOnFailureCallback_69{ OnFailureCallback_69, this }; - chip::Callback::Callback mOnSuccessCallback_69{ OnSuccessCallback_69, this }; - chip::Callback::Callback mOnFailureCallback_70{ OnFailureCallback_70, this }; - chip::Callback::Callback mOnSuccessCallback_70{ OnSuccessCallback_70, this }; - chip::Callback::Callback mOnFailureCallback_71{ OnFailureCallback_71, this }; - chip::Callback::Callback mOnSuccessCallback_71{ OnSuccessCallback_71, this }; - chip::Callback::Callback mOnFailureCallback_72{ OnFailureCallback_72, this }; - chip::Callback::Callback mOnSuccessCallback_72{ OnSuccessCallback_72, this }; - chip::Callback::Callback mOnFailureCallback_73{ OnFailureCallback_73, this }; - chip::Callback::Callback mOnSuccessCallback_73{ OnSuccessCallback_73, this }; - chip::Callback::Callback mOnFailureCallback_74{ OnFailureCallback_74, this }; - chip::Callback::Callback mOnSuccessCallback_74{ OnSuccessCallback_74, this }; - chip::Callback::Callback mOnFailureCallback_75{ OnFailureCallback_75, this }; - chip::Callback::Callback mOnSuccessCallback_75{ OnSuccessCallback_75, this }; - chip::Callback::Callback mOnFailureCallback_76{ OnFailureCallback_76, this }; - chip::Callback::Callback mOnSuccessCallback_76{ OnSuccessCallback_76, this }; - chip::Callback::Callback mOnFailureCallback_77{ OnFailureCallback_77, this }; - chip::Callback::Callback mOnSuccessCallback_77{ OnSuccessCallback_77, this }; - chip::Callback::Callback mOnFailureCallback_78{ OnFailureCallback_78, this }; - chip::Callback::Callback mOnSuccessCallback_78{ OnSuccessCallback_78, this }; - chip::Callback::Callback mOnFailureCallback_79{ OnFailureCallback_79, this }; - chip::Callback::Callback mOnSuccessCallback_79{ OnSuccessCallback_79, this }; - chip::Callback::Callback mOnFailureCallback_80{ OnFailureCallback_80, this }; - chip::Callback::Callback mOnSuccessCallback_80{ OnSuccessCallback_80, this }; - chip::Callback::Callback mOnFailureCallback_81{ OnFailureCallback_81, this }; - chip::Callback::Callback mOnSuccessCallback_81{ OnSuccessCallback_81, this }; - chip::Callback::Callback mOnFailureCallback_82{ OnFailureCallback_82, this }; - chip::Callback::Callback mOnSuccessCallback_82{ OnSuccessCallback_82, this }; - chip::Callback::Callback mOnFailureCallback_83{ OnFailureCallback_83, this }; - chip::Callback::Callback mOnSuccessCallback_83{ OnSuccessCallback_83, this }; - chip::Callback::Callback mOnFailureCallback_84{ OnFailureCallback_84, this }; - chip::Callback::Callback mOnSuccessCallback_84{ OnSuccessCallback_84, this }; - chip::Callback::Callback mOnFailureCallback_85{ OnFailureCallback_85, this }; - chip::Callback::Callback mOnSuccessCallback_85{ OnSuccessCallback_85, this }; - chip::Callback::Callback mOnFailureCallback_86{ OnFailureCallback_86, this }; - chip::Callback::Callback mOnSuccessCallback_86{ OnSuccessCallback_86, this }; - chip::Callback::Callback mOnFailureCallback_87{ OnFailureCallback_87, this }; - chip::Callback::Callback mOnSuccessCallback_87{ OnSuccessCallback_87, this }; - chip::Callback::Callback mOnFailureCallback_88{ OnFailureCallback_88, this }; - chip::Callback::Callback mOnSuccessCallback_88{ OnSuccessCallback_88, - this }; - chip::Callback::Callback mOnFailureCallback_89{ OnFailureCallback_89, this }; - chip::Callback::Callback mOnSuccessCallback_89{ OnSuccessCallback_89, - this }; - chip::Callback::Callback mOnFailureCallback_90{ OnFailureCallback_90, this }; - chip::Callback::Callback mOnSuccessCallback_90{ OnSuccessCallback_90, - this }; - chip::Callback::Callback mOnFailureCallback_91{ OnFailureCallback_91, this }; - chip::Callback::Callback mOnSuccessCallback_91{ OnSuccessCallback_91, - this }; - chip::Callback::Callback mOnFailureCallback_92{ OnFailureCallback_92, this }; - chip::Callback::Callback mOnSuccessCallback_92{ OnSuccessCallback_92, - this }; - chip::Callback::Callback mOnFailureCallback_93{ OnFailureCallback_93, this }; - chip::Callback::Callback mOnSuccessCallback_93{ OnSuccessCallback_93, - this }; - chip::Callback::Callback mOnFailureCallback_94{ OnFailureCallback_94, this }; - chip::Callback::Callback mOnSuccessCallback_94{ OnSuccessCallback_94, - this }; - chip::Callback::Callback mOnFailureCallback_95{ OnFailureCallback_95, this }; - chip::Callback::Callback mOnSuccessCallback_95{ OnSuccessCallback_95, - this }; - chip::Callback::Callback mOnFailureCallback_96{ OnFailureCallback_96, this }; - chip::Callback::Callback mOnSuccessCallback_96{ OnSuccessCallback_96, - this }; - chip::Callback::Callback mOnFailureCallback_97{ OnFailureCallback_97, this }; - chip::Callback::Callback mOnSuccessCallback_97{ OnSuccessCallback_97, - this }; - chip::Callback::Callback mOnFailureCallback_98{ OnFailureCallback_98, this }; - chip::Callback::Callback mOnSuccessCallback_98{ OnSuccessCallback_98, - this }; - chip::Callback::Callback mOnFailureCallback_99{ OnFailureCallback_99, this }; - chip::Callback::Callback mOnSuccessCallback_99{ OnSuccessCallback_99, - this }; - chip::Callback::Callback mOnFailureCallback_100{ OnFailureCallback_100, this }; - chip::Callback::Callback mOnSuccessCallback_100{ OnSuccessCallback_100, - this }; - chip::Callback::Callback mOnFailureCallback_101{ OnFailureCallback_101, this }; - chip::Callback::Callback mOnSuccessCallback_101{ OnSuccessCallback_101, - this }; - chip::Callback::Callback mOnFailureCallback_102{ OnFailureCallback_102, this }; - chip::Callback::Callback mOnSuccessCallback_102{ OnSuccessCallback_102, - this }; - chip::Callback::Callback mOnFailureCallback_103{ OnFailureCallback_103, this }; - chip::Callback::Callback mOnSuccessCallback_103{ OnSuccessCallback_103, - this }; - chip::Callback::Callback mOnFailureCallback_104{ OnFailureCallback_104, this }; - chip::Callback::Callback mOnSuccessCallback_104{ OnSuccessCallback_104, - this }; - chip::Callback::Callback mOnFailureCallback_105{ OnFailureCallback_105, this }; - chip::Callback::Callback mOnSuccessCallback_105{ OnSuccessCallback_105, - this }; - chip::Callback::Callback mOnFailureCallback_106{ OnFailureCallback_106, this }; - chip::Callback::Callback mOnSuccessCallback_106{ - OnSuccessCallback_106, this - }; - chip::Callback::Callback mOnFailureCallback_107{ OnFailureCallback_107, this }; - chip::Callback::Callback mOnSuccessCallback_107{ - OnSuccessCallback_107, this - }; - chip::Callback::Callback mOnFailureCallback_108{ OnFailureCallback_108, this }; - chip::Callback::Callback - mOnSuccessCallback_108{ OnSuccessCallback_108, this }; - chip::Callback::Callback mOnFailureCallback_109{ OnFailureCallback_109, this }; - chip::Callback::Callback mOnSuccessCallback_109{ OnSuccessCallback_109, this }; - chip::Callback::Callback mOnFailureCallback_110{ OnFailureCallback_110, this }; - chip::Callback::Callback mOnSuccessCallback_110{ OnSuccessCallback_110, this }; - chip::Callback::Callback mOnFailureCallback_111{ OnFailureCallback_111, this }; - chip::Callback::Callback mOnSuccessCallback_111{ OnSuccessCallback_111, this }; - chip::Callback::Callback mOnFailureCallback_112{ OnFailureCallback_112, this }; - chip::Callback::Callback mOnSuccessCallback_112{ OnSuccessCallback_112, this }; - chip::Callback::Callback mOnFailureCallback_113{ OnFailureCallback_113, this }; - chip::Callback::Callback mOnSuccessCallback_113{ OnSuccessCallback_113, this }; - chip::Callback::Callback mOnFailureCallback_114{ OnFailureCallback_114, this }; - chip::Callback::Callback mOnSuccessCallback_114{ OnSuccessCallback_114, this }; - chip::Callback::Callback mOnFailureCallback_115{ OnFailureCallback_115, this }; - chip::Callback::Callback mOnSuccessCallback_115{ OnSuccessCallback_115, this }; - chip::Callback::Callback mOnFailureCallback_116{ OnFailureCallback_116, this }; - chip::Callback::Callback mOnSuccessCallback_116{ OnSuccessCallback_116, this }; - chip::Callback::Callback mOnFailureCallback_117{ OnFailureCallback_117, this }; - chip::Callback::Callback mOnSuccessCallback_117{ OnSuccessCallback_117, this }; - chip::Callback::Callback mOnFailureCallback_118{ OnFailureCallback_118, this }; - chip::Callback::Callback mOnSuccessCallback_118{ OnSuccessCallback_118, this }; - chip::Callback::Callback mOnFailureCallback_119{ OnFailureCallback_119, this }; - chip::Callback::Callback mOnSuccessCallback_119{ OnSuccessCallback_119, this }; - chip::Callback::Callback mOnFailureCallback_120{ OnFailureCallback_120, this }; - chip::Callback::Callback mOnSuccessCallback_120{ OnSuccessCallback_120, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; - static void OnFailureCallback_5(void * context, uint8_t status) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_5(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_5(void * context, bool boolean) + static void OnSuccessCallback_1(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_5(boolean); + (static_cast(context))->OnSuccessResponse_1(onOff); } - static void OnFailureCallback_6(void * context, uint8_t status) + static void OnFailureCallback_7(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_6(status); + (static_cast(context))->OnFailureResponse_7(status); } - static void OnSuccessCallback_6(void * context, bool boolean) + static void OnSuccessCallback_7(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_6(boolean); + (static_cast(context))->OnSuccessResponse_7(onOff); } - static void OnFailureCallback_7(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_7(status); - } + // + // Tests methods + // - static void OnSuccessCallback_7(void * context, bool boolean) + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - (static_cast(context))->OnSuccessResponse_7(boolean); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_8(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_8(status); - } + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnSuccessCallback_8(void * context, bool boolean) - { - (static_cast(context))->OnSuccessResponse_8(boolean); - } + chip::app::Clusters::OnOff::Commands::On::Type request; - static void OnFailureCallback_9(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_9(status); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; - static void OnSuccessCallback_9(void * context, bool boolean) - { - (static_cast(context))->OnSuccessResponse_9(boolean); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnFailureCallback_10(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_10(status); - } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_10(void * context, uint8_t bitmap8) - { - (static_cast(context))->OnSuccessResponse_10(bitmap8); - } + void OnSuccessResponse_0() { NextTest(); } - static void OnFailureCallback_11(void * context, uint8_t status) + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - (static_cast(context))->OnFailureResponse_11(status); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_11(void * context, uint8_t bitmap8) - { - (static_cast(context))->OnSuccessResponse_11(bitmap8); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - static void OnFailureCallback_12(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_12(status); - } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_12(void * context, uint8_t bitmap8) + void OnSuccessResponse_1(bool onOff) { - (static_cast(context))->OnSuccessResponse_12(bitmap8); + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); } - static void OnFailureCallback_13(void * context, uint8_t status) + CHIP_ERROR TestEnhancedMoveHueDownCommand_2() { - (static_cast(context))->OnFailureResponse_13(status); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_13(void * context, uint8_t bitmap8) - { - (static_cast(context))->OnSuccessResponse_13(bitmap8); - } + using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnFailureCallback_14(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_14(status); - } + chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type request; + request.moveMode = static_cast(3); + request.rate = 5U; + request.optionsMask = 0; + request.optionsOverride = 0; - static void OnSuccessCallback_14(void * context, uint8_t bitmap8) - { - (static_cast(context))->OnSuccessResponse_14(bitmap8); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; - static void OnFailureCallback_15(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_15(status); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_15(void * context, uint16_t bitmap16) - { - (static_cast(context))->OnSuccessResponse_15(bitmap16); - } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_16(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_16(status); - } + void OnSuccessResponse_2() { NextTest(); } - static void OnSuccessCallback_16(void * context, uint16_t bitmap16) + CHIP_ERROR TestEnhancedMoveHueStopCommand_3() { - (static_cast(context))->OnSuccessResponse_16(bitmap16); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_17(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_17(status); - } + using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnSuccessCallback_17(void * context, uint16_t bitmap16) - { - (static_cast(context))->OnSuccessResponse_17(bitmap16); - } + chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type request; + request.moveMode = static_cast(0); + request.rate = 0U; + request.optionsMask = 0; + request.optionsOverride = 0; - static void OnFailureCallback_18(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_18(status); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; - static void OnSuccessCallback_18(void * context, uint16_t bitmap16) - { - (static_cast(context))->OnSuccessResponse_18(bitmap16); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnFailureCallback_19(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_19(status); - } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_19(void * context, uint16_t bitmap16) - { - (static_cast(context))->OnSuccessResponse_19(bitmap16); - } + void OnSuccessResponse_3() { NextTest(); } - static void OnFailureCallback_20(void * context, uint8_t status) + CHIP_ERROR TestEnhancedMoveHueUpCommand_4() { - (static_cast(context))->OnFailureResponse_20(status); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_20(void * context, uint32_t bitmap32) - { - (static_cast(context))->OnSuccessResponse_20(bitmap32); - } + using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnFailureCallback_21(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_21(status); - } + chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type request; + request.moveMode = static_cast(1); + request.rate = 50U; + request.optionsMask = 0; + request.optionsOverride = 0; - static void OnSuccessCallback_21(void * context, uint32_t bitmap32) - { - (static_cast(context))->OnSuccessResponse_21(bitmap32); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_4(); + }; - static void OnFailureCallback_22(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_22(status); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_4(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_22(void * context, uint32_t bitmap32) - { - (static_cast(context))->OnSuccessResponse_22(bitmap32); - } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_23(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_23(status); - } + void OnSuccessResponse_4() { NextTest(); } - static void OnSuccessCallback_23(void * context, uint32_t bitmap32) + CHIP_ERROR TestEnhancedMoveHueStopCommand_5() { - (static_cast(context))->OnSuccessResponse_23(bitmap32); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_24(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_24(status); - } + using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnSuccessCallback_24(void * context, uint32_t bitmap32) - { - (static_cast(context))->OnSuccessResponse_24(bitmap32); - } + chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type request; + request.moveMode = static_cast(0); + request.rate = 0U; + request.optionsMask = 0; + request.optionsOverride = 0; - static void OnFailureCallback_25(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_25(status); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_5(); + }; - static void OnSuccessCallback_25(void * context, uint64_t bitmap64) - { - (static_cast(context))->OnSuccessResponse_25(bitmap64); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_5(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnFailureCallback_26(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_26(status); - } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_26(void * context, uint64_t bitmap64) - { - (static_cast(context))->OnSuccessResponse_26(bitmap64); - } + void OnSuccessResponse_5() { NextTest(); } - static void OnFailureCallback_27(void * context, uint8_t status) + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_6() { - (static_cast(context))->OnFailureResponse_27(status); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_27(void * context, uint64_t bitmap64) - { - (static_cast(context))->OnSuccessResponse_27(bitmap64); - } + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnFailureCallback_28(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_28(status); - } + chip::app::Clusters::OnOff::Commands::Off::Type request; - static void OnSuccessCallback_28(void * context, uint64_t bitmap64) - { - (static_cast(context))->OnSuccessResponse_28(bitmap64); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_6(); + }; - static void OnFailureCallback_29(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_29(status); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_6(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_29(void * context, uint64_t bitmap64) - { - (static_cast(context))->OnSuccessResponse_29(bitmap64); - } + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_30(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_30(status); - } + void OnSuccessResponse_6() { NextTest(); } - static void OnSuccessCallback_30(void * context, uint8_t int8u) + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7() { - (static_cast(context))->OnSuccessResponse_30(int8u); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_31(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_31(status); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); } - static void OnSuccessCallback_31(void * context, uint8_t int8u) - { - (static_cast(context))->OnSuccessResponse_31(int8u); - } + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_32(void * context, uint8_t status) + void OnSuccessResponse_7(bool onOff) { - (static_cast(context))->OnFailureResponse_32(status); + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); } +}; - static void OnSuccessCallback_32(void * context, uint8_t int8u) - { - (static_cast(context))->OnSuccessResponse_32(int8u); - } +class Test_TC_CC_7_3 : public TestCommand +{ +public: + Test_TC_CC_7_3() : TestCommand("Test_TC_CC_7_3"), mTestIndex(0) {} - static void OnFailureCallback_33(void * context, uint8_t status) + /////////// TestCommand Interface ///////// + void NextTest() override { - (static_cast(context))->OnFailureResponse_33(status); - } + CHIP_ERROR err = CHIP_NO_ERROR; - static void OnSuccessCallback_33(void * context, uint8_t int8u) - { - (static_cast(context))->OnSuccessResponse_33(int8u); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_7_3\n"); + } - static void OnFailureCallback_34(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_34(status); - } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_7_3\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - static void OnSuccessCallback_34(void * context, uint8_t int8u) - { - (static_cast(context))->OnSuccessResponse_34(int8u); - } + Wait(); - static void OnFailureCallback_35(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_35(status); - } + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Enhanced Step Hue Up command\n"); + err = TestEnhancedStepHueUpCommand_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Enhanced Step Hue Down command\n"); + err = TestEnhancedStepHueDownCommand_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); + break; + } - static void OnSuccessCallback_35(void * context, uint16_t int16u) - { - (static_cast(context))->OnSuccessResponse_35(int16u); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - static void OnFailureCallback_36(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_36(status); - } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 6; - static void OnSuccessCallback_36(void * context, uint16_t int16u) + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_36(int16u); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnFailureCallback_37(void * context, uint8_t status) + static void OnSuccessCallback_1(void * context, bool onOff) { - (static_cast(context))->OnFailureResponse_37(status); + (static_cast(context))->OnSuccessResponse_1(onOff); } - static void OnSuccessCallback_37(void * context, uint16_t int16u) + static void OnFailureCallback_5(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_37(int16u); + (static_cast(context))->OnFailureResponse_5(status); } - static void OnFailureCallback_38(void * context, uint8_t status) + static void OnSuccessCallback_5(void * context, bool onOff) { - (static_cast(context))->OnFailureResponse_38(status); + (static_cast(context))->OnSuccessResponse_5(onOff); } - static void OnSuccessCallback_38(void * context, uint16_t int16u) - { - (static_cast(context))->OnSuccessResponse_38(int16u); - } + // + // Tests methods + // - static void OnFailureCallback_39(void * context, uint8_t status) + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - (static_cast(context))->OnFailureResponse_39(status); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_39(void * context, uint16_t int16u) - { - (static_cast(context))->OnSuccessResponse_39(int16u); - } + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnFailureCallback_40(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_40(status); - } + chip::app::Clusters::OnOff::Commands::On::Type request; - static void OnSuccessCallback_40(void * context, uint32_t int32u) - { - (static_cast(context))->OnSuccessResponse_40(int32u); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; - static void OnFailureCallback_41(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_41(status); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_41(void * context, uint32_t int32u) - { - (static_cast(context))->OnSuccessResponse_41(int32u); - } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_42(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_42(status); - } + void OnSuccessResponse_0() { NextTest(); } - static void OnSuccessCallback_42(void * context, uint32_t int32u) + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - (static_cast(context))->OnSuccessResponse_42(int32u); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_43(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_43(status); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - static void OnSuccessCallback_43(void * context, uint32_t int32u) - { - (static_cast(context))->OnSuccessResponse_43(int32u); - } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_44(void * context, uint8_t status) + void OnSuccessResponse_1(bool onOff) { - (static_cast(context))->OnFailureResponse_44(status); + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); } - static void OnSuccessCallback_44(void * context, uint32_t int32u) + CHIP_ERROR TestEnhancedStepHueUpCommand_2() { - (static_cast(context))->OnSuccessResponse_44(int32u); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_45(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_45(status); - } + using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedStepHue::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnSuccessCallback_45(void * context, uint64_t int64u) - { - (static_cast(context))->OnSuccessResponse_45(int64u); - } + chip::app::Clusters::ColorControl::Commands::EnhancedStepHue::Type request; + request.stepMode = static_cast(0); + request.stepSize = 50U; + request.transitionTime = 1U; + request.optionsMask = 0; + request.optionsOverride = 0; - static void OnFailureCallback_46(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_46(status); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; - static void OnSuccessCallback_46(void * context, uint64_t int64u) - { - (static_cast(context))->OnSuccessResponse_46(int64u); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnFailureCallback_47(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_47(status); - } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_47(void * context, uint64_t int64u) - { - (static_cast(context))->OnSuccessResponse_47(int64u); - } + void OnSuccessResponse_2() { NextTest(); } - static void OnFailureCallback_48(void * context, uint8_t status) + CHIP_ERROR TestEnhancedStepHueDownCommand_3() { - (static_cast(context))->OnFailureResponse_48(status); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_48(void * context, uint64_t int64u) - { - (static_cast(context))->OnSuccessResponse_48(int64u); - } + using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedStepHue::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnFailureCallback_49(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_49(status); - } + chip::app::Clusters::ColorControl::Commands::EnhancedStepHue::Type request; + request.stepMode = static_cast(1); + request.stepSize = 75U; + request.transitionTime = 1U; + request.optionsMask = 0; + request.optionsOverride = 0; - static void OnSuccessCallback_49(void * context, uint64_t int64u) - { - (static_cast(context))->OnSuccessResponse_49(int64u); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; - static void OnFailureCallback_50(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_50(status); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_50(void * context, int8_t int8s) - { - (static_cast(context))->OnSuccessResponse_50(int8s); - } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_51(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_51(status); - } + void OnSuccessResponse_3() { NextTest(); } - static void OnSuccessCallback_51(void * context, int8_t int8s) + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() { - (static_cast(context))->OnSuccessResponse_51(int8s); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_52(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_52(status); - } + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnSuccessCallback_52(void * context, int8_t int8s) - { - (static_cast(context))->OnSuccessResponse_52(int8s); - } + chip::app::Clusters::OnOff::Commands::Off::Type request; - static void OnFailureCallback_53(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_53(status); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_4(); + }; - static void OnSuccessCallback_53(void * context, int8_t int8s) - { - (static_cast(context))->OnSuccessResponse_53(int8s); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_4(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnFailureCallback_54(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_54(status); - } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_54(void * context, int8_t int8s) - { - (static_cast(context))->OnSuccessResponse_54(int8s); - } + void OnSuccessResponse_4() { NextTest(); } - static void OnFailureCallback_55(void * context, uint8_t status) + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() { - (static_cast(context))->OnFailureResponse_55(status); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_55(void * context, int8_t int8s) - { - (static_cast(context))->OnSuccessResponse_55(int8s); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); } - static void OnFailureCallback_56(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_56(status); - } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_56(void * context, int8_t int8s) + void OnSuccessResponse_5(bool onOff) { - (static_cast(context))->OnSuccessResponse_56(int8s); + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); } +}; - static void OnFailureCallback_57(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_57(status); - } +class Test_TC_CC_7_4 : public TestCommand +{ +public: + Test_TC_CC_7_4() : TestCommand("Test_TC_CC_7_4"), mTestIndex(0) {} - static void OnSuccessCallback_57(void * context, int16_t int16s) + /////////// TestCommand Interface ///////// + void NextTest() override { - (static_cast(context))->OnSuccessResponse_57(int16s); - } + CHIP_ERROR err = CHIP_NO_ERROR; - static void OnFailureCallback_58(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_58(status); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_7_4\n"); + } - static void OnSuccessCallback_58(void * context, int16_t int16s) - { - (static_cast(context))->OnSuccessResponse_58(int16s); - } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_7_4\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - static void OnFailureCallback_59(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_59(status); - } - - static void OnSuccessCallback_59(void * context, int16_t int16s) - { - (static_cast(context))->OnSuccessResponse_59(int16s); - } + Wait(); - static void OnFailureCallback_60(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_60(status); - } + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Enhanced move to hue and saturation command\n"); + err = TestEnhancedMoveToHueAndSaturationCommand_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); + break; + } - static void OnSuccessCallback_60(void * context, int16_t int16s) - { - (static_cast(context))->OnSuccessResponse_60(int16s); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - static void OnFailureCallback_61(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_61(status); - } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 5; - static void OnSuccessCallback_61(void * context, int16_t int16s) - { - (static_cast(context))->OnSuccessResponse_61(int16s); - } + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; - static void OnFailureCallback_62(void * context, uint8_t status) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_62(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_62(void * context, int16_t int16s) + static void OnSuccessCallback_1(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_62(int16s); + (static_cast(context))->OnSuccessResponse_1(onOff); } - static void OnFailureCallback_63(void * context, uint8_t status) + static void OnFailureCallback_4(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_63(status); + (static_cast(context))->OnFailureResponse_4(status); } - static void OnSuccessCallback_63(void * context, int16_t int16s) + static void OnSuccessCallback_4(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_63(int16s); + (static_cast(context))->OnSuccessResponse_4(onOff); } - static void OnFailureCallback_64(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_64(status); - } + // + // Tests methods + // - static void OnSuccessCallback_64(void * context, int32_t int32s) + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - (static_cast(context))->OnSuccessResponse_64(int32s); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_65(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_65(status); - } + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnSuccessCallback_65(void * context, int32_t int32s) - { - (static_cast(context))->OnSuccessResponse_65(int32s); - } + chip::app::Clusters::OnOff::Commands::On::Type request; - static void OnFailureCallback_66(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_66(status); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; - static void OnSuccessCallback_66(void * context, int32_t int32s) - { - (static_cast(context))->OnSuccessResponse_66(int32s); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnFailureCallback_67(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_67(status); - } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_67(void * context, int32_t int32s) - { - (static_cast(context))->OnSuccessResponse_67(int32s); - } + void OnSuccessResponse_0() { NextTest(); } - static void OnFailureCallback_68(void * context, uint8_t status) + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - (static_cast(context))->OnFailureResponse_68(status); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_68(void * context, int32_t int32s) - { - (static_cast(context))->OnSuccessResponse_68(int32s); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - static void OnFailureCallback_69(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_69(status); - } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_69(void * context, int32_t int32s) + void OnSuccessResponse_1(bool onOff) { - (static_cast(context))->OnSuccessResponse_69(int32s); + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); } - static void OnFailureCallback_70(void * context, uint8_t status) + CHIP_ERROR TestEnhancedMoveToHueAndSaturationCommand_2() { - (static_cast(context))->OnFailureResponse_70(status); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_70(void * context, int32_t int32s) - { - (static_cast(context))->OnSuccessResponse_70(int32s); - } + using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveToHueAndSaturation::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnFailureCallback_71(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_71(status); - } + chip::app::Clusters::ColorControl::Commands::EnhancedMoveToHueAndSaturation::Type request; + request.enhancedHue = 1200U; + request.saturation = 90; + request.transitionTime = 10U; + request.optionsMask = 0; + request.optionsOverride = 0; - static void OnSuccessCallback_71(void * context, int64_t int64s) - { - (static_cast(context))->OnSuccessResponse_71(int64s); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; - static void OnFailureCallback_72(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_72(status); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_72(void * context, int64_t int64s) - { - (static_cast(context))->OnSuccessResponse_72(int64s); - } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_73(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_73(status); - } + void OnSuccessResponse_2() { NextTest(); } - static void OnSuccessCallback_73(void * context, int64_t int64s) + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() { - (static_cast(context))->OnSuccessResponse_73(int64s); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_74(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_74(status); - } + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnSuccessCallback_74(void * context, int64_t int64s) - { - (static_cast(context))->OnSuccessResponse_74(int64s); - } + chip::app::Clusters::OnOff::Commands::Off::Type request; - static void OnFailureCallback_75(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_75(status); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; - static void OnSuccessCallback_75(void * context, int64_t int64s) - { - (static_cast(context))->OnSuccessResponse_75(int64s); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnFailureCallback_76(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_76(status); - } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_76(void * context, int64_t int64s) - { - (static_cast(context))->OnSuccessResponse_76(int64s); - } + void OnSuccessResponse_3() { NextTest(); } - static void OnFailureCallback_77(void * context, uint8_t status) + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() { - (static_cast(context))->OnFailureResponse_77(status); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_77(void * context, int64_t int64s) - { - (static_cast(context))->OnSuccessResponse_77(int64s); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); } - static void OnFailureCallback_78(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_78(status); - } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_78(void * context, uint8_t enum8) + void OnSuccessResponse_4(bool onOff) { - (static_cast(context))->OnSuccessResponse_78(enum8); + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); } +}; - static void OnFailureCallback_79(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_79(status); - } +class Test_TC_CC_8_1 : public TestCommand +{ +public: + Test_TC_CC_8_1() : TestCommand("Test_TC_CC_8_1"), mTestIndex(0) {} - static void OnSuccessCallback_79(void * context, uint8_t enum8) + /////////// TestCommand Interface ///////// + void NextTest() override { - (static_cast(context))->OnSuccessResponse_79(enum8); - } + CHIP_ERROR err = CHIP_NO_ERROR; - static void OnFailureCallback_80(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_80(status); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_8_1\n"); + } - static void OnSuccessCallback_80(void * context, uint8_t enum8) - { - (static_cast(context))->OnSuccessResponse_80(enum8); - } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_8_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - static void OnFailureCallback_81(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_81(status); - } + Wait(); - static void OnSuccessCallback_81(void * context, uint8_t enum8) - { - (static_cast(context))->OnSuccessResponse_81(enum8); - } + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); + err = TestTurnOnLightForColorControlTests_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Color Loop Set Command - Set all Attributs\n"); + err = TestColorLoopSetCommandSetAllAttributs_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Check ColorLoopDirection Value\n"); + err = TestCheckColorLoopDirectionValue_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Check ColorLoopTime Value\n"); + err = TestCheckColorLoopTimeValue_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Check ColorLoopStartEnhancedHue Value\n"); + err = TestCheckColorLoopStartEnhancedHueValue_5(); + break; + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : Check ColorLoopActive Value\n"); + err = TestCheckColorLoopActiveValue_6(); + break; + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : Color Loop Set Command - Start Color Loop\n"); + err = TestColorLoopSetCommandStartColorLoop_7(); + break; + case 8: + ChipLogProgress(chipTool, " ***** Test Step 8 : Check ColorLoopActive Value\n"); + err = TestCheckColorLoopActiveValue_8(); + break; + case 9: + ChipLogProgress(chipTool, " ***** Test Step 9 : Color Loop Set Command - Set direction and time while running\n"); + err = TestColorLoopSetCommandSetDirectionAndTimeWhileRunning_9(); + break; + case 10: + ChipLogProgress(chipTool, " ***** Test Step 10 : Check ColorLoopDirection Value\n"); + err = TestCheckColorLoopDirectionValue_10(); + break; + case 11: + ChipLogProgress(chipTool, " ***** Test Step 11 : Check ColorLoopTime Value\n"); + err = TestCheckColorLoopTimeValue_11(); + break; + case 12: + ChipLogProgress(chipTool, " ***** Test Step 12 : Color Loop Set Command - Set direction while running\n"); + err = TestColorLoopSetCommandSetDirectionWhileRunning_12(); + break; + case 13: + ChipLogProgress(chipTool, " ***** Test Step 13 : Check ColorLoopDirection Value\n"); + err = TestCheckColorLoopDirectionValue_13(); + break; + case 14: + ChipLogProgress(chipTool, " ***** Test Step 14 : Turn off light that we turned on\n"); + err = TestTurnOffLightThatWeTurnedOn_14(); + break; + case 15: + ChipLogProgress(chipTool, " ***** Test Step 15 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_15(); + break; + } - static void OnFailureCallback_82(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_82(status); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - static void OnSuccessCallback_82(void * context, uint8_t enum8) - { - (static_cast(context))->OnSuccessResponse_82(enum8); - } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 16; - static void OnFailureCallback_83(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_83(status); - } + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, + this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ + OnSuccessCallback_5, this + }; + chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; + chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; + chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; + chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; + chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, + this }; + chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; + chip::Callback::Callback mOnSuccessCallback_11{ OnSuccessCallback_11, this }; + chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; + chip::Callback::Callback mOnSuccessCallback_13{ OnSuccessCallback_13, + this }; + chip::Callback::Callback mOnFailureCallback_15{ OnFailureCallback_15, this }; + chip::Callback::Callback mOnSuccessCallback_15{ OnSuccessCallback_15, this }; - static void OnSuccessCallback_83(void * context, uint16_t enum16) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_83(enum16); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnFailureCallback_84(void * context, uint8_t status) + static void OnSuccessCallback_1(void * context, bool onOff) { - (static_cast(context))->OnFailureResponse_84(status); + (static_cast(context))->OnSuccessResponse_1(onOff); } - static void OnSuccessCallback_84(void * context, uint16_t enum16) + static void OnFailureCallback_3(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_84(enum16); + (static_cast(context))->OnFailureResponse_3(status); } - static void OnFailureCallback_85(void * context, uint8_t status) + static void OnSuccessCallback_3(void * context, uint8_t colorLoopDirection) { - (static_cast(context))->OnFailureResponse_85(status); + (static_cast(context))->OnSuccessResponse_3(colorLoopDirection); } - static void OnSuccessCallback_85(void * context, uint16_t enum16) + static void OnFailureCallback_4(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_85(enum16); + (static_cast(context))->OnFailureResponse_4(status); } - static void OnFailureCallback_86(void * context, uint8_t status) + static void OnSuccessCallback_4(void * context, uint16_t colorLoopTime) { - (static_cast(context))->OnFailureResponse_86(status); + (static_cast(context))->OnSuccessResponse_4(colorLoopTime); } - static void OnSuccessCallback_86(void * context, uint16_t enum16) + static void OnFailureCallback_5(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_86(enum16); + (static_cast(context))->OnFailureResponse_5(status); } - static void OnFailureCallback_87(void * context, uint8_t status) + static void OnSuccessCallback_5(void * context, uint16_t colorLoopStartEnhancedHue) { - (static_cast(context))->OnFailureResponse_87(status); + (static_cast(context))->OnSuccessResponse_5(colorLoopStartEnhancedHue); } - static void OnSuccessCallback_87(void * context, uint16_t enum16) + static void OnFailureCallback_6(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_87(enum16); + (static_cast(context))->OnFailureResponse_6(status); } - static void OnFailureCallback_88(void * context, uint8_t status) + static void OnSuccessCallback_6(void * context, uint8_t colorLoopActive) { - (static_cast(context))->OnFailureResponse_88(status); + (static_cast(context))->OnSuccessResponse_6(colorLoopActive); } - static void OnSuccessCallback_88(void * context, chip::ByteSpan octetString) + static void OnFailureCallback_8(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_88(octetString); + (static_cast(context))->OnFailureResponse_8(status); } - static void OnFailureCallback_89(void * context, uint8_t status) + static void OnSuccessCallback_8(void * context, uint8_t colorLoopActive) { - (static_cast(context))->OnFailureResponse_89(status); + (static_cast(context))->OnSuccessResponse_8(colorLoopActive); } - static void OnSuccessCallback_89(void * context, chip::ByteSpan octetString) + static void OnFailureCallback_10(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_89(octetString); + (static_cast(context))->OnFailureResponse_10(status); } - static void OnFailureCallback_90(void * context, uint8_t status) + static void OnSuccessCallback_10(void * context, uint8_t colorLoopDirection) { - (static_cast(context))->OnFailureResponse_90(status); + (static_cast(context))->OnSuccessResponse_10(colorLoopDirection); } - static void OnSuccessCallback_90(void * context, chip::ByteSpan octetString) + static void OnFailureCallback_11(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_90(octetString); + (static_cast(context))->OnFailureResponse_11(status); } - static void OnFailureCallback_91(void * context, uint8_t status) + static void OnSuccessCallback_11(void * context, uint16_t colorLoopTime) { - (static_cast(context))->OnFailureResponse_91(status); + (static_cast(context))->OnSuccessResponse_11(colorLoopTime); } - static void OnSuccessCallback_91(void * context, chip::ByteSpan octetString) + static void OnFailureCallback_13(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_91(octetString); + (static_cast(context))->OnFailureResponse_13(status); } - static void OnFailureCallback_92(void * context, uint8_t status) + static void OnSuccessCallback_13(void * context, uint8_t colorLoopDirection) { - (static_cast(context))->OnFailureResponse_92(status); + (static_cast(context))->OnSuccessResponse_13(colorLoopDirection); } - static void OnSuccessCallback_92(void * context, chip::ByteSpan octetString) + static void OnFailureCallback_15(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_92(octetString); + (static_cast(context))->OnFailureResponse_15(status); } - static void OnFailureCallback_93(void * context, uint8_t status) + static void OnSuccessCallback_15(void * context, bool onOff) { - (static_cast(context))->OnFailureResponse_93(status); + (static_cast(context))->OnSuccessResponse_15(onOff); } - static void OnSuccessCallback_93(void * context, chip::ByteSpan octetString) - { - (static_cast(context))->OnSuccessResponse_93(octetString); - } + // + // Tests methods + // - static void OnFailureCallback_94(void * context, uint8_t status) + CHIP_ERROR TestTurnOnLightForColorControlTests_0() { - (static_cast(context))->OnFailureResponse_94(status); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_94(void * context, chip::ByteSpan longOctetString) - { - (static_cast(context))->OnSuccessResponse_94(longOctetString); - } + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnFailureCallback_95(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_95(status); - } + chip::app::Clusters::OnOff::Commands::On::Type request; - static void OnSuccessCallback_95(void * context, chip::ByteSpan longOctetString) - { - (static_cast(context))->OnSuccessResponse_95(longOctetString); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; - static void OnFailureCallback_96(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_96(status); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_96(void * context, chip::ByteSpan longOctetString) - { - (static_cast(context))->OnSuccessResponse_96(longOctetString); - } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_97(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_97(status); - } + void OnSuccessResponse_0() { NextTest(); } - static void OnSuccessCallback_97(void * context, chip::ByteSpan longOctetString) + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() { - (static_cast(context))->OnSuccessResponse_97(longOctetString); - } + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_98(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_98(status); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - static void OnSuccessCallback_98(void * context, chip::ByteSpan charString) - { - (static_cast(context))->OnSuccessResponse_98(charString); - } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_99(void * context, uint8_t status) + void OnSuccessResponse_1(bool onOff) { - (static_cast(context))->OnFailureResponse_99(status); + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); } - static void OnSuccessCallback_99(void * context, chip::ByteSpan charString) + CHIP_ERROR TestColorLoopSetCommandSetAllAttributs_2() { - (static_cast(context))->OnSuccessResponse_99(charString); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_100(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_100(status); - } + using requestType = chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnSuccessCallback_100(void * context, chip::ByteSpan charString) - { - (static_cast(context))->OnSuccessResponse_100(charString); - } + chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type request; + request.updateFlags = static_cast>(14); + request.action = static_cast(0); + request.direction = static_cast(1); + request.time = 100U; + request.startHue = 500U; + request.optionsMask = 0; + request.optionsOverride = 0; - static void OnFailureCallback_101(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_101(status); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; - static void OnSuccessCallback_101(void * context, chip::ByteSpan charString) - { - (static_cast(context))->OnSuccessResponse_101(charString); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnFailureCallback_102(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_102(status); - } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_102(void * context, chip::ByteSpan longCharString) - { - (static_cast(context))->OnSuccessResponse_102(longCharString); - } + void OnSuccessResponse_2() { NextTest(); } - static void OnFailureCallback_103(void * context, uint8_t status) + CHIP_ERROR TestCheckColorLoopDirectionValue_3() { - (static_cast(context))->OnFailureResponse_103(status); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_103(void * context, chip::ByteSpan longCharString) - { - (static_cast(context))->OnSuccessResponse_103(longCharString); + return cluster.ReadAttributeColorLoopDirection(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } - static void OnFailureCallback_104(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_104(status); - } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_104(void * context, chip::ByteSpan longCharString) + void OnSuccessResponse_3(uint8_t colorLoopDirection) { - (static_cast(context))->OnSuccessResponse_104(longCharString); + VerifyOrReturn(CheckValue("colorLoopDirection", colorLoopDirection, 1)); + NextTest(); } - static void OnFailureCallback_105(void * context, uint8_t status) + CHIP_ERROR TestCheckColorLoopTimeValue_4() { - (static_cast(context))->OnFailureResponse_105(status); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_105(void * context, chip::ByteSpan longCharString) - { - (static_cast(context))->OnSuccessResponse_105(longCharString); + return cluster.ReadAttributeColorLoopTime(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); } - static void OnFailureCallback_106(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_106(status); - } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_106(void * context, uint16_t count, uint8_t * listInt8u) + void OnSuccessResponse_4(uint16_t colorLoopTime) { - (static_cast(context))->OnSuccessResponse_106(count, listInt8u); + VerifyOrReturn(CheckValue("colorLoopTime", colorLoopTime, 100U)); + NextTest(); } - static void OnFailureCallback_107(void * context, uint8_t status) + CHIP_ERROR TestCheckColorLoopStartEnhancedHueValue_5() { - (static_cast(context))->OnFailureResponse_107(status); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_107(void * context, uint16_t count, chip::ByteSpan * listOctetString) - { - (static_cast(context))->OnSuccessResponse_107(count, listOctetString); + return cluster.ReadAttributeColorLoopStartEnhancedHue(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); } - static void OnFailureCallback_108(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_108(status); - } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_108(void * context, uint16_t count, _TestListStructOctet * listStructOctetString) + void OnSuccessResponse_5(uint16_t colorLoopStartEnhancedHue) { - (static_cast(context))->OnSuccessResponse_108(count, listStructOctetString); + VerifyOrReturn(CheckValue("colorLoopStartEnhancedHue", colorLoopStartEnhancedHue, 500U)); + NextTest(); } - static void OnFailureCallback_109(void * context, uint8_t status) + CHIP_ERROR TestCheckColorLoopActiveValue_6() { - (static_cast(context))->OnFailureResponse_109(status); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_109(void * context, uint64_t epochUs) - { - (static_cast(context))->OnSuccessResponse_109(epochUs); + return cluster.ReadAttributeColorLoopActive(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); } - static void OnFailureCallback_110(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_110(status); - } + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_110(void * context, uint64_t epochUs) + void OnSuccessResponse_6(uint8_t colorLoopActive) { - (static_cast(context))->OnSuccessResponse_110(epochUs); + VerifyOrReturn(CheckValue("colorLoopActive", colorLoopActive, 0)); + NextTest(); } - static void OnFailureCallback_111(void * context, uint8_t status) + CHIP_ERROR TestColorLoopSetCommandStartColorLoop_7() { - (static_cast(context))->OnFailureResponse_111(status); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_111(void * context, uint64_t epochUs) - { - (static_cast(context))->OnSuccessResponse_111(epochUs); - } + using requestType = chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnFailureCallback_112(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_112(status); - } + chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type request; + request.updateFlags = static_cast>(1); + request.action = static_cast(1); + request.direction = static_cast(0); + request.time = 0U; + request.startHue = 0U; + request.optionsMask = 0; + request.optionsOverride = 0; - static void OnSuccessCallback_112(void * context, uint64_t epochUs) - { - (static_cast(context))->OnSuccessResponse_112(epochUs); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_7(); + }; - static void OnFailureCallback_113(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_113(status); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_7(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_113(void * context, uint64_t epochUs) - { - (static_cast(context))->OnSuccessResponse_113(epochUs); - } + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_114(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_114(status); - } + void OnSuccessResponse_7() { NextTest(); } - static void OnSuccessCallback_114(void * context, uint32_t epochS) + CHIP_ERROR TestCheckColorLoopActiveValue_8() { - (static_cast(context))->OnSuccessResponse_114(epochS); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_115(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_115(status); + return cluster.ReadAttributeColorLoopActive(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel()); } - static void OnSuccessCallback_115(void * context, uint32_t epochS) - { - (static_cast(context))->OnSuccessResponse_115(epochS); - } + void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_116(void * context, uint8_t status) + void OnSuccessResponse_8(uint8_t colorLoopActive) { - (static_cast(context))->OnFailureResponse_116(status); + VerifyOrReturn(CheckValue("colorLoopActive", colorLoopActive, 1)); + NextTest(); } - static void OnSuccessCallback_116(void * context, uint32_t epochS) + CHIP_ERROR TestColorLoopSetCommandSetDirectionAndTimeWhileRunning_9() { - (static_cast(context))->OnSuccessResponse_116(epochS); - } + chip::Controller::ColorControlClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnFailureCallback_117(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_117(status); - } + using requestType = chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnSuccessCallback_117(void * context, uint32_t epochS) - { - (static_cast(context))->OnSuccessResponse_117(epochS); - } - - static void OnFailureCallback_118(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_118(status); - } - - static void OnSuccessCallback_118(void * context, uint32_t epochS) - { - (static_cast(context))->OnSuccessResponse_118(epochS); - } - - static void OnFailureCallback_119(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_119(status); - } - - static void OnSuccessCallback_119(void * context, bool unsupported) - { - (static_cast(context))->OnSuccessResponse_119(unsupported); - } - - static void OnFailureCallback_120(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_120(status); - } - - static void OnSuccessCallback_120(void * context, bool unsupported) - { - (static_cast(context))->OnSuccessResponse_120(unsupported); - } - - // - // Tests methods - // - - CHIP_ERROR TestSendTestCommand_0() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::TestCluster::Commands::Test::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::TestCluster::Commands::Test::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); - } - - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0() { NextTest(); } - - CHIP_ERROR TestSendTestNotHandledCommand_1() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::TestCluster::Commands::TestNotHandled::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::TestCluster::Commands::TestNotHandled::Type request; + chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type request; + request.updateFlags = static_cast>(6); + request.action = static_cast(0); + request.direction = static_cast(0); + request.time = 3500U; + request.startHue = 0U; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(); + (static_cast(context))->OnSuccessResponse_9(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_9(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_1(uint8_t status) { NextTest(); } + void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1() { ThrowSuccessResponse(); } + void OnSuccessResponse_9() { NextTest(); } - CHIP_ERROR TestSendTestSpecificCommand_2() + CHIP_ERROR TestCheckColorLoopDirectionValue_10() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::ColorControlClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::TestCluster::Commands::TestSpecific::Type; - using responseType = chip::app::Clusters::TestCluster::Commands::TestSpecificResponse::DecodableType; - - chip::app::Clusters::TestCluster::Commands::TestSpecific::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(data.returnValue); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeColorLoopDirection(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint8_t returnValue) + void OnSuccessResponse_10(uint8_t colorLoopDirection) { - VerifyOrReturn(CheckValue("returnValue", returnValue, 7)); + VerifyOrReturn(CheckValue("colorLoopDirection", colorLoopDirection, 0)); NextTest(); } - CHIP_ERROR TestSendTestAddArgumentsCommand_3() + CHIP_ERROR TestCheckColorLoopTimeValue_11() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::ColorControlClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::TestCluster::Commands::TestAddArguments::Type; - using responseType = chip::app::Clusters::TestCluster::Commands::TestAddArgumentsResponse::DecodableType; - - chip::app::Clusters::TestCluster::Commands::TestAddArguments::Type request; - request.arg1 = 3; - request.arg2 = 17; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(data.returnValue); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeColorLoopTime(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel()); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3(uint8_t returnValue) + void OnSuccessResponse_11(uint16_t colorLoopTime) { - VerifyOrReturn(CheckValue("returnValue", returnValue, 20)); + VerifyOrReturn(CheckValue("colorLoopTime", colorLoopTime, 3500U)); NextTest(); } - CHIP_ERROR TestSendFailingTestAddArgumentsCommand_4() + CHIP_ERROR TestColorLoopSetCommandSetDirectionWhileRunning_12() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::ColorControlClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::TestCluster::Commands::TestAddArguments::Type; - using responseType = chip::app::Clusters::TestCluster::Commands::TestAddArgumentsResponse::DecodableType; + using requestType = chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type; + using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::TestCluster::Commands::TestAddArguments::Type request; - request.arg1 = 250; - request.arg2 = 6; + chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type request; + request.updateFlags = static_cast>(2); + request.action = static_cast(0); + request.direction = static_cast(1); + request.time = 0U; + request.startHue = 0U; + request.optionsMask = 0; + request.optionsOverride = 0; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(data.returnValue); + (static_cast(context))->OnSuccessResponse_12(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_12(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_4(uint8_t status) { NextTest(); } + void OnFailureResponse_12(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4(uint8_t returnValue) { ThrowSuccessResponse(); } + void OnSuccessResponse_12() { NextTest(); } - CHIP_ERROR TestReadAttributeBooleanDefaultValue_5() + CHIP_ERROR TestCheckColorLoopDirectionValue_13() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::ColorControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeBoolean(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + return cluster.ReadAttributeColorLoopDirection(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel()); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_13(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5(bool boolean) + void OnSuccessResponse_13(uint8_t colorLoopDirection) { - VerifyOrReturn(CheckValue("boolean", boolean, 0)); + VerifyOrReturn(CheckValue("colorLoopDirection", colorLoopDirection, 1)); NextTest(); } - CHIP_ERROR TestWriteAttributeBooleanTrue_6() + CHIP_ERROR TestTurnOffLightThatWeTurnedOn_14() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - bool booleanArgument = 1; + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; - return cluster.WriteAttributeBoolean(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel(), booleanArgument); + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_14(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_14(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_14(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_6(bool boolean) { NextTest(); } + void OnSuccessResponse_14() { NextTest(); } - CHIP_ERROR TestReadAttributeBooleanTrue_7() + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_15() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeBoolean(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_15.Cancel(), mOnFailureCallback_15.Cancel()); } - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_15(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_7(bool boolean) + void OnSuccessResponse_15(bool onOff) { - VerifyOrReturn(CheckValue("boolean", boolean, 1)); + VerifyOrReturn(CheckValue("onOff", onOff, 0)); NextTest(); } +}; - CHIP_ERROR TestWriteAttributeBooleanFalse_8() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - bool booleanArgument = 0; - - return cluster.WriteAttributeBoolean(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel(), booleanArgument); - } - - void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_8(bool boolean) { NextTest(); } +class Test_TC_DM_1_1 : public TestCommand +{ +public: + Test_TC_DM_1_1() : TestCommand("Test_TC_DM_1_1"), mTestIndex(0) {} - CHIP_ERROR TestReadAttributeBooleanFalse_9() + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + CHIP_ERROR err = CHIP_NO_ERROR; - return cluster.ReadAttributeBoolean(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel()); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_DM_1_1\n"); + } - void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_DM_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - void OnSuccessResponse_9(bool boolean) - { - VerifyOrReturn(CheckValue("boolean", boolean, 0)); - NextTest(); - } + Wait(); - CHIP_ERROR TestReadAttributeBitmap8DefaultValue_10() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Query Interaction Model Version\n"); + err = TestQueryInteractionModelVersion_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Query Vendor Name\n"); + err = TestQueryVendorName_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Query VendorID\n"); + err = TestQueryVendorID_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Query Product Name\n"); + err = TestQueryProductName_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Query ProductID\n"); + err = TestQueryProductID_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Query User Label\n"); + err = TestQueryUserLabel_5(); + break; + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : Query User Location\n"); + err = TestQueryUserLocation_6(); + break; + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : Query HardwareVersion\n"); + err = TestQueryHardwareVersion_7(); + break; + case 8: + ChipLogProgress(chipTool, " ***** Test Step 8 : Query HardwareVersionString\n"); + err = TestQueryHardwareVersionString_8(); + break; + case 9: + ChipLogProgress(chipTool, " ***** Test Step 9 : Query SoftwareVersion\n"); + err = TestQuerySoftwareVersion_9(); + break; + case 10: + ChipLogProgress(chipTool, " ***** Test Step 10 : Query SoftwareVersionString\n"); + err = TestQuerySoftwareVersionString_10(); + break; + case 11: + ChipLogProgress(chipTool, " ***** Test Step 11 : Query ManufacturingDate\n"); + err = TestQueryManufacturingDate_11(); + break; + case 12: + ChipLogProgress(chipTool, " ***** Test Step 12 : Query PartNumber\n"); + err = TestQueryPartNumber_12(); + break; + case 13: + ChipLogProgress(chipTool, " ***** Test Step 13 : Query ProductURL\n"); + err = TestQueryProductURL_13(); + break; + case 14: + ChipLogProgress(chipTool, " ***** Test Step 14 : Query ProductLabel\n"); + err = TestQueryProductLabel_14(); + break; + case 15: + ChipLogProgress(chipTool, " ***** Test Step 15 : Query SerialNumber\n"); + err = TestQuerySerialNumber_15(); + break; + case 16: + ChipLogProgress(chipTool, " ***** Test Step 16 : Query LocalConfigDisabled\n"); + err = TestQueryLocalConfigDisabled_16(); + break; + case 17: + ChipLogProgress(chipTool, " ***** Test Step 17 : Query Reachable\n"); + err = TestQueryReachable_17(); + break; + } - return cluster.ReadAttributeBitmap8(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 18; - void OnSuccessResponse_10(uint8_t bitmap8) + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, + this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, + this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; + chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; + chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; + chip::Callback::Callback mOnSuccessCallback_8{ + OnSuccessCallback_8, this + }; + chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; + chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; + chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; + chip::Callback::Callback mOnSuccessCallback_10{ + OnSuccessCallback_10, this + }; + chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; + chip::Callback::Callback mOnSuccessCallback_11{ + OnSuccessCallback_11, this + }; + chip::Callback::Callback mOnFailureCallback_12{ OnFailureCallback_12, this }; + chip::Callback::Callback mOnSuccessCallback_12{ OnSuccessCallback_12, + this }; + chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; + chip::Callback::Callback mOnSuccessCallback_13{ OnSuccessCallback_13, + this }; + chip::Callback::Callback mOnFailureCallback_14{ OnFailureCallback_14, this }; + chip::Callback::Callback mOnSuccessCallback_14{ OnSuccessCallback_14, + this }; + chip::Callback::Callback mOnFailureCallback_15{ OnFailureCallback_15, this }; + chip::Callback::Callback mOnSuccessCallback_15{ OnSuccessCallback_15, + this }; + chip::Callback::Callback mOnFailureCallback_16{ OnFailureCallback_16, this }; + chip::Callback::Callback mOnSuccessCallback_16{ OnSuccessCallback_16, + this }; + chip::Callback::Callback mOnFailureCallback_17{ OnFailureCallback_17, this }; + chip::Callback::Callback mOnSuccessCallback_17{ OnSuccessCallback_17, this }; + + static void OnFailureCallback_0(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("bitmap8", bitmap8, 0)); - NextTest(); + (static_cast(context))->OnFailureResponse_0(status); } - CHIP_ERROR TestWriteAttributeBitmap8MaxValue_11() + static void OnSuccessCallback_0(void * context, uint16_t interactionModelVersion) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint8_t bitmap8Argument = 255; - - return cluster.WriteAttributeBitmap8(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel(), bitmap8Argument); + (static_cast(context))->OnSuccessResponse_0(interactionModelVersion); } - void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_11(uint8_t bitmap8) { NextTest(); } - - CHIP_ERROR TestReadAttributeBitmap8MaxValue_12() + static void OnFailureCallback_1(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeBitmap8(mOnSuccessCallback_12.Cancel(), mOnFailureCallback_12.Cancel()); + (static_cast(context))->OnFailureResponse_1(status); } - void OnFailureResponse_12(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_12(uint8_t bitmap8) + static void OnSuccessCallback_1(void * context, chip::ByteSpan vendorName) { - VerifyOrReturn(CheckValue("bitmap8", bitmap8, 255)); - NextTest(); + (static_cast(context))->OnSuccessResponse_1(vendorName); } - CHIP_ERROR TestWriteAttributeBitmap8MinValue_13() + static void OnFailureCallback_2(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint8_t bitmap8Argument = 0; - - return cluster.WriteAttributeBitmap8(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel(), bitmap8Argument); + (static_cast(context))->OnFailureResponse_2(status); } - void OnFailureResponse_13(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_13(uint8_t bitmap8) { NextTest(); } - - CHIP_ERROR TestReadAttributeBitmap8MinValue_14() + static void OnSuccessCallback_2(void * context, uint16_t vendorID) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeBitmap8(mOnSuccessCallback_14.Cancel(), mOnFailureCallback_14.Cancel()); + (static_cast(context))->OnSuccessResponse_2(vendorID); } - void OnFailureResponse_14(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_14(uint8_t bitmap8) + static void OnFailureCallback_3(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("bitmap8", bitmap8, 0)); - NextTest(); + (static_cast(context))->OnFailureResponse_3(status); } - CHIP_ERROR TestReadAttributeBitmap16DefaultValue_15() + static void OnSuccessCallback_3(void * context, chip::ByteSpan productName) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeBitmap16(mOnSuccessCallback_15.Cancel(), mOnFailureCallback_15.Cancel()); + (static_cast(context))->OnSuccessResponse_3(productName); } - void OnFailureResponse_15(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_15(uint16_t bitmap16) + static void OnFailureCallback_4(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("bitmap16", bitmap16, 0U)); - NextTest(); + (static_cast(context))->OnFailureResponse_4(status); } - CHIP_ERROR TestWriteAttributeBitmap16MaxValue_16() + static void OnSuccessCallback_4(void * context, uint16_t productID) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t bitmap16Argument = 65535U; + (static_cast(context))->OnSuccessResponse_4(productID); + } - return cluster.WriteAttributeBitmap16(mOnSuccessCallback_16.Cancel(), mOnFailureCallback_16.Cancel(), bitmap16Argument); + static void OnFailureCallback_5(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_5(status); } - void OnFailureResponse_16(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_5(void * context, chip::ByteSpan userLabel) + { + (static_cast(context))->OnSuccessResponse_5(userLabel); + } - void OnSuccessResponse_16(uint16_t bitmap16) { NextTest(); } + static void OnFailureCallback_6(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_6(status); + } - CHIP_ERROR TestReadAttributeBitmap16MaxValue_17() + static void OnSuccessCallback_6(void * context, chip::ByteSpan location) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_6(location); + } - return cluster.ReadAttributeBitmap16(mOnSuccessCallback_17.Cancel(), mOnFailureCallback_17.Cancel()); + static void OnFailureCallback_7(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_7(status); } - void OnFailureResponse_17(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_7(void * context, uint16_t hardwareVersion) + { + (static_cast(context))->OnSuccessResponse_7(hardwareVersion); + } - void OnSuccessResponse_17(uint16_t bitmap16) + static void OnFailureCallback_8(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("bitmap16", bitmap16, 65535U)); - NextTest(); + (static_cast(context))->OnFailureResponse_8(status); } - CHIP_ERROR TestWriteAttributeBitmap16MinValue_18() + static void OnSuccessCallback_8(void * context, chip::ByteSpan hardwareVersionString) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t bitmap16Argument = 0U; - - return cluster.WriteAttributeBitmap16(mOnSuccessCallback_18.Cancel(), mOnFailureCallback_18.Cancel(), bitmap16Argument); + (static_cast(context))->OnSuccessResponse_8(hardwareVersionString); } - void OnFailureResponse_18(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_18(uint16_t bitmap16) { NextTest(); } - - CHIP_ERROR TestReadAttributeBitmap16MinValue_19() + static void OnFailureCallback_9(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeBitmap16(mOnSuccessCallback_19.Cancel(), mOnFailureCallback_19.Cancel()); + (static_cast(context))->OnFailureResponse_9(status); } - void OnFailureResponse_19(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_19(uint16_t bitmap16) + static void OnSuccessCallback_9(void * context, uint32_t softwareVersion) { - VerifyOrReturn(CheckValue("bitmap16", bitmap16, 0U)); - NextTest(); + (static_cast(context))->OnSuccessResponse_9(softwareVersion); } - CHIP_ERROR TestReadAttributeBitmap32DefaultValue_20() + static void OnFailureCallback_10(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeBitmap32(mOnSuccessCallback_20.Cancel(), mOnFailureCallback_20.Cancel()); + (static_cast(context))->OnFailureResponse_10(status); } - void OnFailureResponse_20(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_10(void * context, chip::ByteSpan softwareVersionString) + { + (static_cast(context))->OnSuccessResponse_10(softwareVersionString); + } - void OnSuccessResponse_20(uint32_t bitmap32) + static void OnFailureCallback_11(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("bitmap32", bitmap32, 0UL)); - NextTest(); + (static_cast(context))->OnFailureResponse_11(status); } - CHIP_ERROR TestWriteAttributeBitmap32MaxValue_21() + static void OnSuccessCallback_11(void * context, chip::ByteSpan manufacturingDate) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_11(manufacturingDate); + } - uint32_t bitmap32Argument = 4294967295UL; + static void OnFailureCallback_12(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_12(status); + } - return cluster.WriteAttributeBitmap32(mOnSuccessCallback_21.Cancel(), mOnFailureCallback_21.Cancel(), bitmap32Argument); + static void OnSuccessCallback_12(void * context, chip::ByteSpan partNumber) + { + (static_cast(context))->OnSuccessResponse_12(partNumber); } - void OnFailureResponse_21(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_13(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_13(status); + } - void OnSuccessResponse_21(uint32_t bitmap32) { NextTest(); } + static void OnSuccessCallback_13(void * context, chip::ByteSpan productURL) + { + (static_cast(context))->OnSuccessResponse_13(productURL); + } - CHIP_ERROR TestReadAttributeBitmap32MaxValue_22() + static void OnFailureCallback_14(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_14(status); + } - return cluster.ReadAttributeBitmap32(mOnSuccessCallback_22.Cancel(), mOnFailureCallback_22.Cancel()); + static void OnSuccessCallback_14(void * context, chip::ByteSpan productLabel) + { + (static_cast(context))->OnSuccessResponse_14(productLabel); } - void OnFailureResponse_22(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_15(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_15(status); + } - void OnSuccessResponse_22(uint32_t bitmap32) + static void OnSuccessCallback_15(void * context, chip::ByteSpan serialNumber) { - VerifyOrReturn(CheckValue("bitmap32", bitmap32, 4294967295UL)); - NextTest(); + (static_cast(context))->OnSuccessResponse_15(serialNumber); } - CHIP_ERROR TestWriteAttributeBitmap32MinValue_23() + static void OnFailureCallback_16(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_16(status); + } - uint32_t bitmap32Argument = 0UL; + static void OnSuccessCallback_16(void * context, bool localConfigDisabled) + { + (static_cast(context))->OnSuccessResponse_16(localConfigDisabled); + } - return cluster.WriteAttributeBitmap32(mOnSuccessCallback_23.Cancel(), mOnFailureCallback_23.Cancel(), bitmap32Argument); + static void OnFailureCallback_17(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_17(status); } - void OnFailureResponse_23(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_17(void * context, bool reachable) + { + (static_cast(context))->OnSuccessResponse_17(reachable); + } - void OnSuccessResponse_23(uint32_t bitmap32) { NextTest(); } + // + // Tests methods + // - CHIP_ERROR TestReadAttributeBitmap32MinValue_24() + CHIP_ERROR TestQueryInteractionModelVersion_0() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeBitmap32(mOnSuccessCallback_24.Cancel(), mOnFailureCallback_24.Cancel()); + return cluster.ReadAttributeInteractionModelVersion(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - void OnFailureResponse_24(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_24(uint32_t bitmap32) + void OnSuccessResponse_0(uint16_t interactionModelVersion) { - VerifyOrReturn(CheckValue("bitmap32", bitmap32, 0UL)); + VerifyOrReturn(CheckConstraintType("interactionModelVersion", "", "uint16")); NextTest(); } - CHIP_ERROR TestReadAttributeBitmap64DefaultValue_25() + CHIP_ERROR TestQueryVendorName_1() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeBitmap64(mOnSuccessCallback_25.Cancel(), mOnFailureCallback_25.Cancel()); + return cluster.ReadAttributeVendorName(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - void OnFailureResponse_25(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_25(uint64_t bitmap64) + void OnSuccessResponse_1(chip::ByteSpan vendorName) { - VerifyOrReturn(CheckValue("bitmap64", bitmap64, 0ULL)); + VerifyOrReturn(CheckConstraintType("vendorName", "", "string")); + VerifyOrReturn(CheckConstraintMaxLength("vendorName", vendorName.size(), 32)); NextTest(); } - CHIP_ERROR TestWriteAttributeBitmap64MaxValue_26() + CHIP_ERROR TestQueryVendorID_2() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint64_t bitmap64Argument = 18446744073709551615ULL; + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.WriteAttributeBitmap64(mOnSuccessCallback_26.Cancel(), mOnFailureCallback_26.Cancel(), bitmap64Argument); + return cluster.ReadAttributeVendorID(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } - void OnFailureResponse_26(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_26(uint64_t bitmap64) { NextTest(); } + void OnSuccessResponse_2(uint16_t vendorID) + { + VerifyOrReturn(CheckConstraintType("vendorID", "", "uint16")); + NextTest(); + } - CHIP_ERROR TestReadAttributeBitmap64MaxValue_27() + CHIP_ERROR TestQueryProductName_3() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeBitmap64(mOnSuccessCallback_27.Cancel(), mOnFailureCallback_27.Cancel()); + return cluster.ReadAttributeProductName(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } - void OnFailureResponse_27(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_27(uint64_t bitmap64) + void OnSuccessResponse_3(chip::ByteSpan productName) { - VerifyOrReturn(CheckValue("bitmap64", bitmap64, 18446744073709551615ULL)); + VerifyOrReturn(CheckConstraintType("productName", "", "string")); + VerifyOrReturn(CheckConstraintMaxLength("productName", productName.size(), 32)); NextTest(); } - CHIP_ERROR TestWriteAttributeBitmap64MinValue_28() + CHIP_ERROR TestQueryProductID_4() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint64_t bitmap64Argument = 0ULL; + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.WriteAttributeBitmap64(mOnSuccessCallback_28.Cancel(), mOnFailureCallback_28.Cancel(), bitmap64Argument); + return cluster.ReadAttributeProductID(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); } - void OnFailureResponse_28(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_28(uint64_t bitmap64) { NextTest(); } + void OnSuccessResponse_4(uint16_t productID) + { + VerifyOrReturn(CheckConstraintType("productID", "", "uint16")); + NextTest(); + } - CHIP_ERROR TestReadAttributeBitmap64MinValue_29() + CHIP_ERROR TestQueryUserLabel_5() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeBitmap64(mOnSuccessCallback_29.Cancel(), mOnFailureCallback_29.Cancel()); + return cluster.ReadAttributeUserLabel(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); } - void OnFailureResponse_29(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_29(uint64_t bitmap64) + void OnSuccessResponse_5(chip::ByteSpan userLabel) { - VerifyOrReturn(CheckValue("bitmap64", bitmap64, 0ULL)); + VerifyOrReturn(CheckConstraintType("userLabel", "", "string")); + VerifyOrReturn(CheckConstraintMaxLength("userLabel", userLabel.size(), 32)); NextTest(); } - CHIP_ERROR TestReadAttributeInt8uDefaultValue_30() + CHIP_ERROR TestQueryUserLocation_6() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeInt8u(mOnSuccessCallback_30.Cancel(), mOnFailureCallback_30.Cancel()); + return cluster.ReadAttributeLocation(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); } - void OnFailureResponse_30(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_30(uint8_t int8u) + void OnSuccessResponse_6(chip::ByteSpan location) { - VerifyOrReturn(CheckValue("int8u", int8u, 0)); + VerifyOrReturn(CheckConstraintType("location", "", "string")); + VerifyOrReturn(CheckConstraintFormat("location", "", "ISO 3166-1 alpha-2")); + VerifyOrReturn(CheckConstraintMaxLength("location", location.size(), 2)); NextTest(); } - CHIP_ERROR TestWriteAttributeInt8uMaxValue_31() + CHIP_ERROR TestQueryHardwareVersion_7() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint8_t int8uArgument = 255; + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.WriteAttributeInt8u(mOnSuccessCallback_31.Cancel(), mOnFailureCallback_31.Cancel(), int8uArgument); + return cluster.ReadAttributeHardwareVersion(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); } - void OnFailureResponse_31(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_31(uint8_t int8u) { NextTest(); } + void OnSuccessResponse_7(uint16_t hardwareVersion) + { + VerifyOrReturn(CheckConstraintType("hardwareVersion", "", "uint16")); + NextTest(); + } - CHIP_ERROR TestReadAttributeInt8uMaxValue_32() + CHIP_ERROR TestQueryHardwareVersionString_8() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeInt8u(mOnSuccessCallback_32.Cancel(), mOnFailureCallback_32.Cancel()); + return cluster.ReadAttributeHardwareVersionString(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel()); } - void OnFailureResponse_32(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_32(uint8_t int8u) + void OnSuccessResponse_8(chip::ByteSpan hardwareVersionString) { - VerifyOrReturn(CheckValue("int8u", int8u, 255)); + VerifyOrReturn(CheckConstraintType("hardwareVersionString", "", "string")); + VerifyOrReturn(CheckConstraintMinLength("hardwareVersionString", hardwareVersionString.size(), 1)); + VerifyOrReturn(CheckConstraintMaxLength("hardwareVersionString", hardwareVersionString.size(), 64)); NextTest(); } - CHIP_ERROR TestWriteAttributeInt8uMinValue_33() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint8_t int8uArgument = 0; - - return cluster.WriteAttributeInt8u(mOnSuccessCallback_33.Cancel(), mOnFailureCallback_33.Cancel(), int8uArgument); - } - - void OnFailureResponse_33(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_33(uint8_t int8u) { NextTest(); } - - CHIP_ERROR TestReadAttributeInt8uMinValue_34() + CHIP_ERROR TestQuerySoftwareVersion_9() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeInt8u(mOnSuccessCallback_34.Cancel(), mOnFailureCallback_34.Cancel()); + return cluster.ReadAttributeSoftwareVersion(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel()); } - void OnFailureResponse_34(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_34(uint8_t int8u) + void OnSuccessResponse_9(uint32_t softwareVersion) { - VerifyOrReturn(CheckValue("int8u", int8u, 0)); + VerifyOrReturn(CheckConstraintType("softwareVersion", "", "uint32")); NextTest(); } - CHIP_ERROR TestReadAttributeInt16uDefaultValue_35() + CHIP_ERROR TestQuerySoftwareVersionString_10() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeInt16u(mOnSuccessCallback_35.Cancel(), mOnFailureCallback_35.Cancel()); + return cluster.ReadAttributeSoftwareVersionString(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); } - void OnFailureResponse_35(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_35(uint16_t int16u) + void OnSuccessResponse_10(chip::ByteSpan softwareVersionString) { - VerifyOrReturn(CheckValue("int16u", int16u, 0U)); + VerifyOrReturn(CheckConstraintType("softwareVersionString", "", "string")); + VerifyOrReturn(CheckConstraintFormat("softwareVersionString", "", "ASCII")); + VerifyOrReturn(CheckConstraintMinLength("softwareVersionString", softwareVersionString.size(), 1)); + VerifyOrReturn(CheckConstraintMaxLength("softwareVersionString", softwareVersionString.size(), 64)); NextTest(); } - CHIP_ERROR TestWriteAttributeInt16uMaxValue_36() + CHIP_ERROR TestQueryManufacturingDate_11() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t int16uArgument = 65535U; + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.WriteAttributeInt16u(mOnSuccessCallback_36.Cancel(), mOnFailureCallback_36.Cancel(), int16uArgument); + return cluster.ReadAttributeManufacturingDate(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel()); } - void OnFailureResponse_36(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_36(uint16_t int16u) { NextTest(); } - - CHIP_ERROR TestReadAttributeInt16uMaxValue_37() + void OnFailureResponse_11(uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeInt16u(mOnSuccessCallback_37.Cancel(), mOnFailureCallback_37.Cancel()); + (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); } - void OnFailureResponse_37(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_37(uint16_t int16u) + void OnSuccessResponse_11(chip::ByteSpan manufacturingDate) { - VerifyOrReturn(CheckValue("int16u", int16u, 65535U)); + VerifyOrReturn(CheckConstraintType("manufacturingDate", "", "string")); + VerifyOrReturn(CheckConstraintFormat("manufacturingDate", "", "ISO 8601")); + VerifyOrReturn(CheckConstraintMinLength("manufacturingDate", manufacturingDate.size(), 8)); + VerifyOrReturn(CheckConstraintMaxLength("manufacturingDate", manufacturingDate.size(), 16)); NextTest(); } - CHIP_ERROR TestWriteAttributeInt16uMinValue_38() + CHIP_ERROR TestQueryPartNumber_12() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t int16uArgument = 0U; + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.WriteAttributeInt16u(mOnSuccessCallback_38.Cancel(), mOnFailureCallback_38.Cancel(), int16uArgument); + return cluster.ReadAttributePartNumber(mOnSuccessCallback_12.Cancel(), mOnFailureCallback_12.Cancel()); } - void OnFailureResponse_38(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_38(uint16_t int16u) { NextTest(); } - - CHIP_ERROR TestReadAttributeInt16uMinValue_39() + void OnFailureResponse_12(uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeInt16u(mOnSuccessCallback_39.Cancel(), mOnFailureCallback_39.Cancel()); + (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); } - void OnFailureResponse_39(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_39(uint16_t int16u) + void OnSuccessResponse_12(chip::ByteSpan partNumber) { - VerifyOrReturn(CheckValue("int16u", int16u, 0U)); + VerifyOrReturn(CheckConstraintType("partNumber", "", "string")); + VerifyOrReturn(CheckConstraintMaxLength("partNumber", partNumber.size(), 32)); NextTest(); } - CHIP_ERROR TestReadAttributeInt32uDefaultValue_40() + CHIP_ERROR TestQueryProductURL_13() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeInt32u(mOnSuccessCallback_40.Cancel(), mOnFailureCallback_40.Cancel()); + return cluster.ReadAttributeProductURL(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel()); } - void OnFailureResponse_40(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_13(uint8_t status) + { + (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); + } - void OnSuccessResponse_40(uint32_t int32u) + void OnSuccessResponse_13(chip::ByteSpan productURL) { - VerifyOrReturn(CheckValue("int32u", int32u, 0UL)); + VerifyOrReturn(CheckConstraintType("productURL", "", "string")); + VerifyOrReturn(CheckConstraintFormat("productURL", "", "RFC3986")); + VerifyOrReturn(CheckConstraintMaxLength("productURL", productURL.size(), 256)); NextTest(); } - CHIP_ERROR TestWriteAttributeInt32uMaxValue_41() + CHIP_ERROR TestQueryProductLabel_14() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint32_t int32uArgument = 4294967295UL; + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.WriteAttributeInt32u(mOnSuccessCallback_41.Cancel(), mOnFailureCallback_41.Cancel(), int32uArgument); + return cluster.ReadAttributeProductLabel(mOnSuccessCallback_14.Cancel(), mOnFailureCallback_14.Cancel()); } - void OnFailureResponse_41(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_41(uint32_t int32u) { NextTest(); } - - CHIP_ERROR TestReadAttributeInt32uMaxValue_42() + void OnFailureResponse_14(uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeInt32u(mOnSuccessCallback_42.Cancel(), mOnFailureCallback_42.Cancel()); + (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); } - void OnFailureResponse_42(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_42(uint32_t int32u) + void OnSuccessResponse_14(chip::ByteSpan productLabel) { - VerifyOrReturn(CheckValue("int32u", int32u, 4294967295UL)); + VerifyOrReturn(CheckConstraintType("productLabel", "", "string")); + VerifyOrReturn(CheckConstraintMaxLength("productLabel", productLabel.size(), 64)); NextTest(); } - CHIP_ERROR TestWriteAttributeInt32uMinValue_43() + CHIP_ERROR TestQuerySerialNumber_15() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint32_t int32uArgument = 0UL; + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.WriteAttributeInt32u(mOnSuccessCallback_43.Cancel(), mOnFailureCallback_43.Cancel(), int32uArgument); + return cluster.ReadAttributeSerialNumber(mOnSuccessCallback_15.Cancel(), mOnFailureCallback_15.Cancel()); } - void OnFailureResponse_43(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_43(uint32_t int32u) { NextTest(); } - - CHIP_ERROR TestReadAttributeInt32uMinValue_44() + void OnFailureResponse_15(uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeInt32u(mOnSuccessCallback_44.Cancel(), mOnFailureCallback_44.Cancel()); + (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); } - void OnFailureResponse_44(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_44(uint32_t int32u) + void OnSuccessResponse_15(chip::ByteSpan serialNumber) { - VerifyOrReturn(CheckValue("int32u", int32u, 0UL)); + VerifyOrReturn(CheckConstraintType("serialNumber", "", "string")); + VerifyOrReturn(CheckConstraintMaxLength("serialNumber", serialNumber.size(), 32)); NextTest(); } - CHIP_ERROR TestReadAttributeInt64uDefaultValue_45() + CHIP_ERROR TestQueryLocalConfigDisabled_16() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeInt64u(mOnSuccessCallback_45.Cancel(), mOnFailureCallback_45.Cancel()); + return cluster.ReadAttributeLocalConfigDisabled(mOnSuccessCallback_16.Cancel(), mOnFailureCallback_16.Cancel()); } - void OnFailureResponse_45(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_16(uint8_t status) + { + (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); + } - void OnSuccessResponse_45(uint64_t int64u) + void OnSuccessResponse_16(bool localConfigDisabled) { - VerifyOrReturn(CheckValue("int64u", int64u, 0ULL)); + VerifyOrReturn(CheckConstraintType("localConfigDisabled", "", "boolean")); NextTest(); } - CHIP_ERROR TestWriteAttributeInt64uMaxValue_46() + CHIP_ERROR TestQueryReachable_17() { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint64_t int64uArgument = 18446744073709551615ULL; + chip::Controller::BasicClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.WriteAttributeInt64u(mOnSuccessCallback_46.Cancel(), mOnFailureCallback_46.Cancel(), int64uArgument); + return cluster.ReadAttributeReachable(mOnSuccessCallback_17.Cancel(), mOnFailureCallback_17.Cancel()); } - void OnFailureResponse_46(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_46(uint64_t int64u) { NextTest(); } - - CHIP_ERROR TestReadAttributeInt64uMaxValue_47() + void OnFailureResponse_17(uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeInt64u(mOnSuccessCallback_47.Cancel(), mOnFailureCallback_47.Cancel()); + (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); } - void OnFailureResponse_47(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_47(uint64_t int64u) + void OnSuccessResponse_17(bool reachable) { - VerifyOrReturn(CheckValue("int64u", int64u, 18446744073709551615ULL)); + VerifyOrReturn(CheckConstraintType("reachable", "", "boolean")); NextTest(); } +}; - CHIP_ERROR TestWriteAttributeInt64uMinValue_48() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint64_t int64uArgument = 0ULL; +class Test_TC_DM_3_1 : public TestCommand +{ +public: + Test_TC_DM_3_1() : TestCommand("Test_TC_DM_3_1"), mTestIndex(0) {} - return cluster.WriteAttributeInt64u(mOnSuccessCallback_48.Cancel(), mOnFailureCallback_48.Cancel(), int64uArgument); - } + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; - void OnFailureResponse_48(uint8_t status) { ThrowFailureResponse(); } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_DM_3_1\n"); + } - void OnSuccessResponse_48(uint64_t int64u) { NextTest(); } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_DM_3_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - CHIP_ERROR TestReadAttributeInt64uMinValue_49() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + Wait(); - return cluster.ReadAttributeInt64u(mOnSuccessCallback_49.Cancel(), mOnFailureCallback_49.Cancel()); - } - - void OnFailureResponse_49(uint8_t status) { ThrowFailureResponse(); } + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + } - void OnSuccessResponse_49(uint64_t int64u) - { - VerifyOrReturn(CheckValue("int64u", int64u, 0ULL)); - NextTest(); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - CHIP_ERROR TestReadAttributeInt8sDefaultValue_50() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeInt8s(mOnSuccessCallback_50.Cancel(), mOnFailureCallback_50.Cancel()); - } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 0; - void OnFailureResponse_50(uint8_t status) { ThrowFailureResponse(); } + // + // Tests methods + // +}; - void OnSuccessResponse_50(int8_t int8s) - { - VerifyOrReturn(CheckValue("int8s", int8s, 0)); - NextTest(); - } +class Test_TC_FLW_1_1 : public TestCommand +{ +public: + Test_TC_FLW_1_1() : TestCommand("Test_TC_FLW_1_1"), mTestIndex(0) {} - CHIP_ERROR TestWriteAttributeInt8sMaxValue_51() + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - int8_t int8sArgument = 127; + CHIP_ERROR err = CHIP_NO_ERROR; - return cluster.WriteAttributeInt8s(mOnSuccessCallback_51.Cancel(), mOnFailureCallback_51.Cancel(), int8sArgument); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_FLW_1_1\n"); + } - void OnFailureResponse_51(uint8_t status) { ThrowFailureResponse(); } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_FLW_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - void OnSuccessResponse_51(int8_t int8s) { NextTest(); } + Wait(); - CHIP_ERROR TestReadAttributeInt8sMaxValue_52() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, + " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); + break; + } - return cluster.ReadAttributeInt8s(mOnSuccessCallback_52.Cancel(), mOnFailureCallback_52.Cancel()); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_52(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 1; - void OnSuccessResponse_52(int8_t int8s) + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + + static void OnFailureCallback_0(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("int8s", int8s, 127)); - NextTest(); + (static_cast(context))->OnFailureResponse_0(status); } - CHIP_ERROR TestWriteAttributeInt8sMinValue_53() + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - int8_t int8sArgument = -128; - - return cluster.WriteAttributeInt8s(mOnSuccessCallback_53.Cancel(), mOnFailureCallback_53.Cancel(), int8sArgument); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } - void OnFailureResponse_53(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_53(int8_t int8s) { NextTest(); } + // + // Tests methods + // - CHIP_ERROR TestReadAttributeInt8sMinValue_54() + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::FlowMeasurementClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeInt8s(mOnSuccessCallback_54.Cancel(), mOnFailureCallback_54.Cancel()); + uint16_t clusterRevisionArgument = 2U; + + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), + clusterRevisionArgument); } - void OnFailureResponse_54(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { NextTest(); } - void OnSuccessResponse_54(int8_t int8s) - { - VerifyOrReturn(CheckValue("int8s", int8s, -128)); - NextTest(); - } + void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } +}; - CHIP_ERROR TestWriteAttributeInt8sDefaultValue_55() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); +class Test_TC_LVL_1_1 : public TestCommand +{ +public: + Test_TC_LVL_1_1() : TestCommand("Test_TC_LVL_1_1"), mTestIndex(0) {} - int8_t int8sArgument = 0; + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; - return cluster.WriteAttributeInt8s(mOnSuccessCallback_55.Cancel(), mOnFailureCallback_55.Cancel(), int8sArgument); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_LVL_1_1\n"); + } - void OnFailureResponse_55(uint8_t status) { ThrowFailureResponse(); } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_LVL_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - void OnSuccessResponse_55(int8_t int8s) { NextTest(); } + Wait(); - CHIP_ERROR TestReadAttributeInt8sDefaultValue_56() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, + " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); + break; + } - return cluster.ReadAttributeInt8s(mOnSuccessCallback_56.Cancel(), mOnFailureCallback_56.Cancel()); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_56(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 1; - void OnSuccessResponse_56(int8_t int8s) - { - VerifyOrReturn(CheckValue("int8s", int8s, 0)); - NextTest(); - } + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - CHIP_ERROR TestReadAttributeInt16sDefaultValue_57() + static void OnFailureCallback_0(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeInt16s(mOnSuccessCallback_57.Cancel(), mOnFailureCallback_57.Cancel()); + (static_cast(context))->OnFailureResponse_0(status); } - void OnFailureResponse_57(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_57(int16_t int16s) + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - VerifyOrReturn(CheckValue("int16s", int16s, 0)); - NextTest(); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } - CHIP_ERROR TestWriteAttributeInt16sMaxValue_58() + // + // Tests methods + // + + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - int16_t int16sArgument = 32767; + uint16_t clusterRevisionArgument = 4U; - return cluster.WriteAttributeInt16s(mOnSuccessCallback_58.Cancel(), mOnFailureCallback_58.Cancel(), int16sArgument); + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), + clusterRevisionArgument); } - void OnFailureResponse_58(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_58(int16_t int16s) { NextTest(); } - - CHIP_ERROR TestReadAttributeInt16sMaxValue_59() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + void OnFailureResponse_0(uint8_t status) { NextTest(); } - return cluster.ReadAttributeInt16s(mOnSuccessCallback_59.Cancel(), mOnFailureCallback_59.Cancel()); - } + void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } +}; - void OnFailureResponse_59(uint8_t status) { ThrowFailureResponse(); } +class Test_TC_LVL_2_1 : public TestCommand +{ +public: + Test_TC_LVL_2_1() : TestCommand("Test_TC_LVL_2_1"), mTestIndex(0) {} - void OnSuccessResponse_59(int16_t int16s) + /////////// TestCommand Interface ///////// + void NextTest() override { - VerifyOrReturn(CheckValue("int16s", int16s, 32767)); - NextTest(); - } + CHIP_ERROR err = CHIP_NO_ERROR; - CHIP_ERROR TestWriteAttributeInt16sMinValue_60() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_LVL_2_1\n"); + } - int16_t int16sArgument = -32768; + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_LVL_2_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - return cluster.WriteAttributeInt16s(mOnSuccessCallback_60.Cancel(), mOnFailureCallback_60.Cancel(), int16sArgument); + Wait(); + + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : reads current Level attribute from DUT\n"); + err = TestReadsCurrentLevelAttributeFromDut_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : sends a Move to level command\n"); + err = TestSendsAMoveToLevelCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Wait 10ms\n"); + err = TestWait10ms_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : reads current Level attribute from DUT\n"); + err = TestReadsCurrentLevelAttributeFromDut_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : sends a Move to level command\n"); + err = TestSendsAMoveToLevelCommand_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Wait 100ms\n"); + err = TestWait100ms_5(); + break; + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : reads current Level attribute from DUT\n"); + err = TestReadsCurrentLevelAttributeFromDut_6(); + break; + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : reads On Off Transition Time attribute from DUT\n"); + err = TestReadsOnOffTransitionTimeAttributeFromDut_7(); + break; + case 8: + ChipLogProgress(chipTool, " ***** Test Step 8 : sends a Move to level command\n"); + err = TestSendsAMoveToLevelCommand_8(); + break; + case 9: + ChipLogProgress(chipTool, " ***** Test Step 9 : Wait 1ms\n"); + err = TestWait1ms_9(); + break; + case 10: + ChipLogProgress(chipTool, " ***** Test Step 10 : reads current Level attribute from DUT\n"); + err = TestReadsCurrentLevelAttributeFromDut_10(); + break; + case 11: + ChipLogProgress(chipTool, " ***** Test Step 11 : Reset level to 0\n"); + err = TestResetLevelTo0_11(); + break; + case 12: + ChipLogProgress(chipTool, " ***** Test Step 12 : Wait 10ms\n"); + err = TestWait10ms_12(); + break; + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_60(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 13; - void OnSuccessResponse_60(int16_t int16s) { NextTest(); } + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; + chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, + this }; + chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; + chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, this }; - CHIP_ERROR TestReadAttributeInt16sMinValue_61() + static void OnFailureCallback_0(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeInt16s(mOnSuccessCallback_61.Cancel(), mOnFailureCallback_61.Cancel()); + (static_cast(context))->OnFailureResponse_0(status); } - void OnFailureResponse_61(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_61(int16_t int16s) + static void OnSuccessCallback_0(void * context, uint8_t currentLevel) { - VerifyOrReturn(CheckValue("int16s", int16s, -32768)); - NextTest(); + (static_cast(context))->OnSuccessResponse_0(currentLevel); } - CHIP_ERROR TestWriteAttributeInt16sDefaultValue_62() + static void OnFailureCallback_3(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - int16_t int16sArgument = 0; + (static_cast(context))->OnFailureResponse_3(status); + } - return cluster.WriteAttributeInt16s(mOnSuccessCallback_62.Cancel(), mOnFailureCallback_62.Cancel(), int16sArgument); + static void OnSuccessCallback_3(void * context, uint8_t currentLevel) + { + (static_cast(context))->OnSuccessResponse_3(currentLevel); } - void OnFailureResponse_62(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_6(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_6(status); + } - void OnSuccessResponse_62(int16_t int16s) { NextTest(); } + static void OnSuccessCallback_6(void * context, uint8_t currentLevel) + { + (static_cast(context))->OnSuccessResponse_6(currentLevel); + } - CHIP_ERROR TestReadAttributeInt16sDefaultValue_63() + static void OnFailureCallback_7(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_7(status); + } - return cluster.ReadAttributeInt16s(mOnSuccessCallback_63.Cancel(), mOnFailureCallback_63.Cancel()); + static void OnSuccessCallback_7(void * context, uint16_t onOffTransitionTime) + { + (static_cast(context))->OnSuccessResponse_7(onOffTransitionTime); } - void OnFailureResponse_63(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_10(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_10(status); + } - void OnSuccessResponse_63(int16_t int16s) + static void OnSuccessCallback_10(void * context, uint8_t currentLevel) { - VerifyOrReturn(CheckValue("int16s", int16s, 0)); - NextTest(); + (static_cast(context))->OnSuccessResponse_10(currentLevel); } - CHIP_ERROR TestReadAttributeInt32sDefaultValue_64() + // + // Tests methods + // + + CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_0() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeInt32s(mOnSuccessCallback_64.Cancel(), mOnFailureCallback_64.Cancel()); + return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - void OnFailureResponse_64(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_64(int32_t int32s) + void OnSuccessResponse_0(uint8_t currentLevel) { - VerifyOrReturn(CheckValue("int32s", int32s, 0L)); + VerifyOrReturn(CheckValue("currentLevel", currentLevel, 0)); NextTest(); } - CHIP_ERROR TestWriteAttributeInt32sMaxValue_65() + CHIP_ERROR TestSendsAMoveToLevelCommand_1() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - int32_t int32sArgument = 2147483647L; + using requestType = chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type; + using responseType = chip::app::DataModel::NullObjectType; - return cluster.WriteAttributeInt32s(mOnSuccessCallback_65.Cancel(), mOnFailureCallback_65.Cancel(), int32sArgument); + chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type request; + request.level = 64; + request.transitionTime = 0U; + request.optionMask = 1; + request.optionOverride = 1; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_1(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_1(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_65(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_65(int32_t int32s) { NextTest(); } + void OnSuccessResponse_1() { NextTest(); } - CHIP_ERROR TestReadAttributeInt32sMaxValue_66() + CHIP_ERROR TestWait10ms_2() { return WaitForMs(10); } + + CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_3() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeInt32s(mOnSuccessCallback_66.Cancel(), mOnFailureCallback_66.Cancel()); + return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } - void OnFailureResponse_66(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_66(int32_t int32s) + void OnSuccessResponse_3(uint8_t currentLevel) { - VerifyOrReturn(CheckValue("int32s", int32s, 2147483647L)); + VerifyOrReturn(CheckValue("currentLevel", currentLevel, 64)); NextTest(); } - CHIP_ERROR TestWriteAttributeInt32sMinValue_67() + CHIP_ERROR TestSendsAMoveToLevelCommand_4() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - int32_t int32sArgument = -2147483648L; + using requestType = chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type; + using responseType = chip::app::DataModel::NullObjectType; - return cluster.WriteAttributeInt32s(mOnSuccessCallback_67.Cancel(), mOnFailureCallback_67.Cancel(), int32sArgument); + chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type request; + request.level = 128; + request.transitionTime = 1U; + request.optionMask = 1; + request.optionOverride = 1; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_4(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_4(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_67(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_67(int32_t int32s) { NextTest(); } + void OnSuccessResponse_4() { NextTest(); } - CHIP_ERROR TestReadAttributeInt32sMinValue_68() + CHIP_ERROR TestWait100ms_5() { return WaitForMs(100); } + + CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_6() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeInt32s(mOnSuccessCallback_68.Cancel(), mOnFailureCallback_68.Cancel()); + return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); } - void OnFailureResponse_68(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_68(int32_t int32s) + void OnSuccessResponse_6(uint8_t currentLevel) { - VerifyOrReturn(CheckValue("int32s", int32s, -2147483648L)); + VerifyOrReturn(CheckValue("currentLevel", currentLevel, 128)); NextTest(); } - CHIP_ERROR TestWriteAttributeInt32sDefaultValue_69() + CHIP_ERROR TestReadsOnOffTransitionTimeAttributeFromDut_7() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - int32_t int32sArgument = 0L; - - return cluster.WriteAttributeInt32s(mOnSuccessCallback_69.Cancel(), mOnFailureCallback_69.Cancel(), int32sArgument); + return cluster.ReadAttributeOnOffTransitionTime(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); } - void OnFailureResponse_69(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_69(int32_t int32s) { NextTest(); } + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestReadAttributeInt32sDefaultValue_70() + void OnSuccessResponse_7(uint16_t onOffTransitionTime) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeInt32s(mOnSuccessCallback_70.Cancel(), mOnFailureCallback_70.Cancel()); - } - - void OnFailureResponse_70(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_70(int32_t int32s) - { - VerifyOrReturn(CheckValue("int32s", int32s, 0L)); + VerifyOrReturn(CheckValue("onOffTransitionTime", onOffTransitionTime, 0U)); NextTest(); } - CHIP_ERROR TestReadAttributeInt64sDefaultValue_71() + CHIP_ERROR TestSendsAMoveToLevelCommand_8() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeInt64s(mOnSuccessCallback_71.Cancel(), mOnFailureCallback_71.Cancel()); - } - - void OnFailureResponse_71(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_71(int64_t int64s) - { - VerifyOrReturn(CheckValue("int64s", int64s, 0LL)); - NextTest(); - } + using requestType = chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type; + using responseType = chip::app::DataModel::NullObjectType; - CHIP_ERROR TestWriteAttributeInt64sMaxValue_72() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type request; + request.level = 254; + request.transitionTime = 65535U; + request.optionMask = 1; + request.optionOverride = 1; - int64_t int64sArgument = 9223372036854775807LL; + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_8(); + }; - return cluster.WriteAttributeInt64s(mOnSuccessCallback_72.Cancel(), mOnFailureCallback_72.Cancel(), int64sArgument); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_8(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_72(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_72(int64_t int64s) { NextTest(); } + void OnSuccessResponse_8() { NextTest(); } - CHIP_ERROR TestReadAttributeInt64sMaxValue_73() + CHIP_ERROR TestWait1ms_9() { return WaitForMs(1); } + + CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_10() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeInt64s(mOnSuccessCallback_73.Cancel(), mOnFailureCallback_73.Cancel()); + return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); } - void OnFailureResponse_73(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_73(int64_t int64s) + void OnSuccessResponse_10(uint8_t currentLevel) { - VerifyOrReturn(CheckValue("int64s", int64s, 9223372036854775807LL)); + VerifyOrReturn(CheckValue("currentLevel", currentLevel, 254)); NextTest(); } - CHIP_ERROR TestWriteAttributeInt64sMinValue_74() + CHIP_ERROR TestResetLevelTo0_11() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - int64_t int64sArgument = -9223372036854775807LL; + using requestType = chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type; + using responseType = chip::app::DataModel::NullObjectType; - return cluster.WriteAttributeInt64s(mOnSuccessCallback_74.Cancel(), mOnFailureCallback_74.Cancel(), int64sArgument); - } + chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type request; + request.level = 0; + request.transitionTime = 0U; + request.optionMask = 1; + request.optionOverride = 1; - void OnFailureResponse_74(uint8_t status) { ThrowFailureResponse(); } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_11(); + }; - void OnSuccessResponse_74(int64_t int64s) { NextTest(); } + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_11(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } - CHIP_ERROR TestReadAttributeInt64sMinValue_75() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } - return cluster.ReadAttributeInt64s(mOnSuccessCallback_75.Cancel(), mOnFailureCallback_75.Cancel()); - } + void OnSuccessResponse_11() { NextTest(); } - void OnFailureResponse_75(uint8_t status) { ThrowFailureResponse(); } + CHIP_ERROR TestWait10ms_12() { return WaitForMs(10); } +}; - void OnSuccessResponse_75(int64_t int64s) - { - VerifyOrReturn(CheckValue("int64s", int64s, -9223372036854775807LL)); - NextTest(); - } +class Test_TC_LVL_3_1 : public TestCommand +{ +public: + Test_TC_LVL_3_1() : TestCommand("Test_TC_LVL_3_1"), mTestIndex(0) {} - CHIP_ERROR TestWriteAttributeInt64sDefaultValue_76() + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - int64_t int64sArgument = 0LL; + CHIP_ERROR err = CHIP_NO_ERROR; - return cluster.WriteAttributeInt64s(mOnSuccessCallback_76.Cancel(), mOnFailureCallback_76.Cancel(), int64sArgument); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_LVL_3_1\n"); + } - void OnFailureResponse_76(uint8_t status) { ThrowFailureResponse(); } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_LVL_3_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - void OnSuccessResponse_76(int64_t int64s) { NextTest(); } + Wait(); - CHIP_ERROR TestReadAttributeInt64sDefaultValue_77() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : reads current level attribute from DUT\n"); + err = TestReadsCurrentLevelAttributeFromDut_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : reads max level attribute from DUT\n"); + err = TestReadsMaxLevelAttributeFromDut_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : sends a Move up command\n"); + err = TestSendsAMoveUpCommand_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Wait 2500ms\n"); + err = TestWait2500ms_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : reads current level attribute from DUT\n"); + err = TestReadsCurrentLevelAttributeFromDut_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : reads min level attribute from DUT\n"); + err = TestReadsMinLevelAttributeFromDut_5(); + break; + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : sends a Move down command\n"); + err = TestSendsAMoveDownCommand_6(); + break; + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : Wait 2500ms\n"); + err = TestWait2500ms_7(); + break; + case 8: + ChipLogProgress(chipTool, " ***** Test Step 8 : reads current level attribute from DUT\n"); + err = TestReadsCurrentLevelAttributeFromDut_8(); + break; + case 9: + ChipLogProgress(chipTool, " ***** Test Step 9 : Write default move rate attribute from DUT\n"); + err = TestWriteDefaultMoveRateAttributeFromDut_9(); + break; + case 10: + ChipLogProgress(chipTool, " ***** Test Step 10 : reads default move rate attribute from DUT\n"); + err = TestReadsDefaultMoveRateAttributeFromDut_10(); + break; + case 11: + ChipLogProgress(chipTool, " ***** Test Step 11 : sends a Move up command at default move rate\n"); + err = TestSendsAMoveUpCommandAtDefaultMoveRate_11(); + break; + case 12: + ChipLogProgress(chipTool, " ***** Test Step 12 : Wait 10ms\n"); + err = TestWait10ms_12(); + break; + case 13: + ChipLogProgress(chipTool, " ***** Test Step 13 : reads current level attribute from DUT\n"); + err = TestReadsCurrentLevelAttributeFromDut_13(); + break; + } - return cluster.ReadAttributeInt64s(mOnSuccessCallback_77.Cancel(), mOnFailureCallback_77.Cancel()); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_77(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 14; - void OnSuccessResponse_77(int64_t int64s) + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; + chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; + chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; + chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; + chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; + chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, this }; + chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; + chip::Callback::Callback mOnSuccessCallback_13{ OnSuccessCallback_13, this }; + + static void OnFailureCallback_0(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("int64s", int64s, 0LL)); - NextTest(); + (static_cast(context))->OnFailureResponse_0(status); } - CHIP_ERROR TestReadAttributeEnum8DefaultValue_78() + static void OnSuccessCallback_0(void * context, uint8_t currentLevel) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeEnum8(mOnSuccessCallback_78.Cancel(), mOnFailureCallback_78.Cancel()); + (static_cast(context))->OnSuccessResponse_0(currentLevel); } - void OnFailureResponse_78(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_78(uint8_t enum8) + static void OnFailureCallback_1(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("enum8", enum8, 0)); - NextTest(); + (static_cast(context))->OnFailureResponse_1(status); } - CHIP_ERROR TestWriteAttributeEnum8MaxValue_79() + static void OnSuccessCallback_1(void * context, uint8_t maxLevel) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint8_t enum8Argument = 255; + (static_cast(context))->OnSuccessResponse_1(maxLevel); + } - return cluster.WriteAttributeEnum8(mOnSuccessCallback_79.Cancel(), mOnFailureCallback_79.Cancel(), enum8Argument); + static void OnFailureCallback_4(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_4(status); } - void OnFailureResponse_79(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_79(uint8_t enum8) { NextTest(); } - - CHIP_ERROR TestReadAttributeEnum8MaxValue_80() + static void OnSuccessCallback_4(void * context, uint8_t currentLevel) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeEnum8(mOnSuccessCallback_80.Cancel(), mOnFailureCallback_80.Cancel()); + (static_cast(context))->OnSuccessResponse_4(currentLevel); } - void OnFailureResponse_80(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_80(uint8_t enum8) + static void OnFailureCallback_5(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("enum8", enum8, 255)); - NextTest(); + (static_cast(context))->OnFailureResponse_5(status); } - CHIP_ERROR TestWriteAttributeEnum8MinValue_81() + static void OnSuccessCallback_5(void * context, uint8_t minLevel) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint8_t enum8Argument = 0; - - return cluster.WriteAttributeEnum8(mOnSuccessCallback_81.Cancel(), mOnFailureCallback_81.Cancel(), enum8Argument); + (static_cast(context))->OnSuccessResponse_5(minLevel); } - void OnFailureResponse_81(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_81(uint8_t enum8) { NextTest(); } - - CHIP_ERROR TestReadAttributeEnum8MinValue_82() + static void OnFailureCallback_8(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_8(status); + } - return cluster.ReadAttributeEnum8(mOnSuccessCallback_82.Cancel(), mOnFailureCallback_82.Cancel()); + static void OnSuccessCallback_8(void * context, uint8_t currentLevel) + { + (static_cast(context))->OnSuccessResponse_8(currentLevel); } - void OnFailureResponse_82(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_9(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_9(status); + } - void OnSuccessResponse_82(uint8_t enum8) + static void OnSuccessCallback_9(void * context, uint8_t defaultMoveRate) { - VerifyOrReturn(CheckValue("enum8", enum8, 0)); - NextTest(); + (static_cast(context))->OnSuccessResponse_9(defaultMoveRate); } - CHIP_ERROR TestReadAttributeEnum16DefaultValue_83() + static void OnFailureCallback_10(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_10(status); + } - return cluster.ReadAttributeEnum16(mOnSuccessCallback_83.Cancel(), mOnFailureCallback_83.Cancel()); + static void OnSuccessCallback_10(void * context, uint8_t defaultMoveRate) + { + (static_cast(context))->OnSuccessResponse_10(defaultMoveRate); } - void OnFailureResponse_83(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_13(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_13(status); + } - void OnSuccessResponse_83(uint16_t enum16) + static void OnSuccessCallback_13(void * context, uint8_t currentLevel) { - VerifyOrReturn(CheckValue("enum16", enum16, 0U)); - NextTest(); + (static_cast(context))->OnSuccessResponse_13(currentLevel); } - CHIP_ERROR TestWriteAttributeEnum16MaxValue_84() + // + // Tests methods + // + + CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_0() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - uint16_t enum16Argument = 65535U; - - return cluster.WriteAttributeEnum16(mOnSuccessCallback_84.Cancel(), mOnFailureCallback_84.Cancel(), enum16Argument); + return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - void OnFailureResponse_84(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_84(uint16_t enum16) { NextTest(); } + void OnSuccessResponse_0(uint8_t currentLevel) + { + VerifyOrReturn(CheckValue("currentLevel", currentLevel, 0)); + NextTest(); + } - CHIP_ERROR TestReadAttributeEnum16MaxValue_85() + CHIP_ERROR TestReadsMaxLevelAttributeFromDut_1() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeEnum16(mOnSuccessCallback_85.Cancel(), mOnFailureCallback_85.Cancel()); + return cluster.ReadAttributeMaxLevel(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - void OnFailureResponse_85(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_85(uint16_t enum16) + void OnSuccessResponse_1(uint8_t maxLevel) { - VerifyOrReturn(CheckValue("enum16", enum16, 65535U)); + VerifyOrReturn(CheckValue("maxLevel", maxLevel, 255)); NextTest(); } - CHIP_ERROR TestWriteAttributeEnum16MinValue_86() + CHIP_ERROR TestSendsAMoveUpCommand_2() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - uint16_t enum16Argument = 0U; + using requestType = chip::app::Clusters::LevelControl::Commands::Move::Type; + using responseType = chip::app::DataModel::NullObjectType; - return cluster.WriteAttributeEnum16(mOnSuccessCallback_86.Cancel(), mOnFailureCallback_86.Cancel(), enum16Argument); + chip::app::Clusters::LevelControl::Commands::Move::Type request; + request.moveMode = static_cast(0); + request.rate = 200; + request.optionMask = 1; + request.optionOverride = 1; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_86(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_86(uint16_t enum16) { NextTest(); } + void OnSuccessResponse_2() { NextTest(); } - CHIP_ERROR TestReadAttributeEnum16MinValue_87() + CHIP_ERROR TestWait2500ms_3() { return WaitForMs(2500); } + + CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_4() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeEnum16(mOnSuccessCallback_87.Cancel(), mOnFailureCallback_87.Cancel()); + return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); } - void OnFailureResponse_87(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_87(uint16_t enum16) + void OnSuccessResponse_4(uint8_t currentLevel) { - VerifyOrReturn(CheckValue("enum16", enum16, 0U)); + VerifyOrReturn(CheckValue("currentLevel", currentLevel, 255)); NextTest(); } - CHIP_ERROR TestReadAttributeOctetStringDefaultValue_88() + CHIP_ERROR TestReadsMinLevelAttributeFromDut_5() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOctetString(mOnSuccessCallback_88.Cancel(), mOnFailureCallback_88.Cancel()); + return cluster.ReadAttributeMinLevel(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); } - void OnFailureResponse_88(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_88(chip::ByteSpan octetString) + void OnSuccessResponse_5(uint8_t minLevel) { - VerifyOrReturn(CheckValueAsString("octetString", octetString, "")); + VerifyOrReturn(CheckValue("minLevel", minLevel, 0)); NextTest(); } - CHIP_ERROR TestWriteAttributeOctetString_89() + CHIP_ERROR TestSendsAMoveDownCommand_6() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - chip::ByteSpan octetStringArgument = chip::ByteSpan(chip::Uint8::from_const_char("TestValue"), strlen("TestValue")); + using requestType = chip::app::Clusters::LevelControl::Commands::Move::Type; + using responseType = chip::app::DataModel::NullObjectType; - return cluster.WriteAttributeOctetString(mOnSuccessCallback_89.Cancel(), mOnFailureCallback_89.Cancel(), - octetStringArgument); + chip::app::Clusters::LevelControl::Commands::Move::Type request; + request.moveMode = static_cast(1); + request.rate = 250; + request.optionMask = 1; + request.optionOverride = 1; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_6(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_6(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_89(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_89(chip::ByteSpan octetString) { NextTest(); } + void OnSuccessResponse_6() { NextTest(); } - CHIP_ERROR TestReadAttributeOctetString_90() + CHIP_ERROR TestWait2500ms_7() { return WaitForMs(2500); } + + CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_8() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOctetString(mOnSuccessCallback_90.Cancel(), mOnFailureCallback_90.Cancel()); + return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel()); } - void OnFailureResponse_90(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_90(chip::ByteSpan octetString) + void OnSuccessResponse_8(uint8_t currentLevel) { - VerifyOrReturn(CheckValueAsString("octetString", octetString, "TestValue")); + VerifyOrReturn(CheckValue("currentLevel", currentLevel, 0)); NextTest(); } - CHIP_ERROR TestWriteAttributeOctetString_91() + CHIP_ERROR TestWriteDefaultMoveRateAttributeFromDut_9() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - chip::ByteSpan octetStringArgument = - chip::ByteSpan(chip::Uint8::from_const_char("TestValueLongerThan10"), strlen("TestValueLongerThan10")); + uint8_t defaultMoveRateArgument = 20; - return cluster.WriteAttributeOctetString(mOnSuccessCallback_91.Cancel(), mOnFailureCallback_91.Cancel(), - octetStringArgument); + return cluster.WriteAttributeDefaultMoveRate(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel(), + defaultMoveRateArgument); } - void OnFailureResponse_91(uint8_t status) { NextTest(); } + void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_91(chip::ByteSpan octetString) { ThrowSuccessResponse(); } + void OnSuccessResponse_9(uint8_t defaultMoveRate) { NextTest(); } - CHIP_ERROR TestReadAttributeOctetString_92() + CHIP_ERROR TestReadsDefaultMoveRateAttributeFromDut_10() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOctetString(mOnSuccessCallback_92.Cancel(), mOnFailureCallback_92.Cancel()); + return cluster.ReadAttributeDefaultMoveRate(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); } - void OnFailureResponse_92(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_92(chip::ByteSpan octetString) + void OnSuccessResponse_10(uint8_t defaultMoveRate) { - VerifyOrReturn(CheckValueAsString("octetString", octetString, "TestValue")); + VerifyOrReturn(CheckValue("defaultMoveRate", defaultMoveRate, 20)); NextTest(); } - CHIP_ERROR TestWriteAttributeOctetString_93() + CHIP_ERROR TestSendsAMoveUpCommandAtDefaultMoveRate_11() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - chip::ByteSpan octetStringArgument = chip::ByteSpan(chip::Uint8::from_const_char(""), strlen("")); + using requestType = chip::app::Clusters::LevelControl::Commands::Move::Type; + using responseType = chip::app::DataModel::NullObjectType; - return cluster.WriteAttributeOctetString(mOnSuccessCallback_93.Cancel(), mOnFailureCallback_93.Cancel(), - octetStringArgument); + chip::app::Clusters::LevelControl::Commands::Move::Type request; + request.moveMode = static_cast(1); + request.rate = 255; + request.optionMask = 1; + request.optionOverride = 1; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_11(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_11(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_93(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_93(chip::ByteSpan octetString) { NextTest(); } + void OnSuccessResponse_11() { NextTest(); } - CHIP_ERROR TestReadAttributeLongOctetStringDefaultValue_94() + CHIP_ERROR TestWait10ms_12() { return WaitForMs(10); } + + CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_13() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::LevelControlClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeLongOctetString(mOnSuccessCallback_94.Cancel(), mOnFailureCallback_94.Cancel()); + return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel()); } - void OnFailureResponse_94(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_13(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_94(chip::ByteSpan longOctetString) + void OnSuccessResponse_13(uint8_t currentLevel) { - VerifyOrReturn(CheckValueAsString("longOctetString", longOctetString, "")); + VerifyOrReturn(CheckConstraintNotValue("currentLevel", currentLevel, 255)); NextTest(); } +}; - CHIP_ERROR TestWriteAttributeLongOctetString_95() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); +class Test_TC_MC_1_1 : public TestCommand +{ +public: + Test_TC_MC_1_1() : TestCommand("Test_TC_MC_1_1"), mTestIndex(0) {} - chip::ByteSpan longOctetStringArgument = chip::ByteSpan( - chip::Uint8::from_const_char( - "111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" - "111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" - "111111111111111111111111111111111111111111111111111111111111111111111111"), - strlen("111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" - "111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" - "111111111111111111111111111111111111111111111111111111111111111111111111111111")); + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; - return cluster.WriteAttributeLongOctetString(mOnSuccessCallback_95.Cancel(), mOnFailureCallback_95.Cancel(), - longOctetStringArgument); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_MC_1_1\n"); + } - void OnFailureResponse_95(uint8_t status) { ThrowFailureResponse(); } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_MC_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - void OnSuccessResponse_95(chip::ByteSpan longOctetString) { NextTest(); } + Wait(); - CHIP_ERROR TestReadAttributeLongOctetString_96() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, + " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); + break; + } - return cluster.ReadAttributeLongOctetString(mOnSuccessCallback_96.Cancel(), mOnFailureCallback_96.Cancel()); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_96(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 1; - void OnSuccessResponse_96(chip::ByteSpan longOctetString) + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + + static void OnFailureCallback_0(void * context, uint8_t status) { - VerifyOrReturn(CheckValueAsString( - "longOctetString", longOctetString, - "1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" - "1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" - "1111111111111111111111111111111111111111111111111111111111111111")); - NextTest(); + (static_cast(context))->OnFailureResponse_0(status); } - CHIP_ERROR TestWriteAttributeLongOctetString_97() + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - chip::ByteSpan longOctetStringArgument = chip::ByteSpan(chip::Uint8::from_const_char(""), strlen("")); - - return cluster.WriteAttributeLongOctetString(mOnSuccessCallback_97.Cancel(), mOnFailureCallback_97.Cancel(), - longOctetStringArgument); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } - void OnFailureResponse_97(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_97(chip::ByteSpan longOctetString) { NextTest(); } + // + // Tests methods + // - CHIP_ERROR TestReadAttributeCharStringDefaultValue_98() + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::RelativeHumidityMeasurementClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeCharString(mOnSuccessCallback_98.Cancel(), mOnFailureCallback_98.Cancel()); - } - - void OnFailureResponse_98(uint8_t status) { ThrowFailureResponse(); } + uint16_t clusterRevisionArgument = 1U; - void OnSuccessResponse_98(chip::ByteSpan charString) - { - VerifyOrReturn(CheckValueAsString("charString", charString, "")); - NextTest(); + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), + clusterRevisionArgument); } - CHIP_ERROR TestWriteAttributeCharString_99() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + void OnFailureResponse_0(uint8_t status) { NextTest(); } - chip::ByteSpan charStringArgument = chip::ByteSpan(chip::Uint8::from_const_char("☉T☉"), strlen("☉T☉")); + void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } +}; - return cluster.WriteAttributeCharString(mOnSuccessCallback_99.Cancel(), mOnFailureCallback_99.Cancel(), charStringArgument); - } +class Test_TC_OCC_1_1 : public TestCommand +{ +public: + Test_TC_OCC_1_1() : TestCommand("Test_TC_OCC_1_1"), mTestIndex(0) {} - void OnFailureResponse_99(uint8_t status) { ThrowFailureResponse(); } + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; - void OnSuccessResponse_99(chip::ByteSpan charString) { NextTest(); } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_OCC_1_1\n"); + } - CHIP_ERROR TestWriteAttributeCharStringValueTooLong_100() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_OCC_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - chip::ByteSpan charStringArgument = - chip::ByteSpan(chip::Uint8::from_const_char("☉TestValueLongerThan10☉"), strlen("☉TestValueLongerThan10☉")); + Wait(); - return cluster.WriteAttributeCharString(mOnSuccessCallback_100.Cancel(), mOnFailureCallback_100.Cancel(), - charStringArgument); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); + err = TestReadTheGlobalAttributeClusterRevision_0(); + break; + case 1: + ChipLogProgress(chipTool, + " ***** Test Step 1 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1(); + break; + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_100(uint8_t status) { NextTest(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 2; - void OnSuccessResponse_100(chip::ByteSpan charString) { ThrowSuccessResponse(); } + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - CHIP_ERROR TestWriteAttributeCharStringEmpty_101() + static void OnFailureCallback_0(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_0(status); + } - chip::ByteSpan charStringArgument = chip::ByteSpan(chip::Uint8::from_const_char(""), strlen("")); + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) + { + (static_cast(context))->OnSuccessResponse_0(clusterRevision); + } - return cluster.WriteAttributeCharString(mOnSuccessCallback_101.Cancel(), mOnFailureCallback_101.Cancel(), - charStringArgument); + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); } - void OnFailureResponse_101(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) + { + (static_cast(context))->OnSuccessResponse_1(clusterRevision); + } - void OnSuccessResponse_101(chip::ByteSpan charString) { NextTest(); } + // + // Tests methods + // - CHIP_ERROR TestReadAttributeLongCharStringDefaultValue_102() + CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OccupancySensingClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeLongCharString(mOnSuccessCallback_102.Cancel(), mOnFailureCallback_102.Cancel()); + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - void OnFailureResponse_102(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_102(chip::ByteSpan longCharString) + void OnSuccessResponse_0(uint16_t clusterRevision) { - VerifyOrReturn(CheckValueAsString("longCharString", longCharString, "")); + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 2U)); NextTest(); } - CHIP_ERROR TestWriteAttributeLongCharString_103() + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OccupancySensingClusterTest cluster; cluster.Associate(mDevice, 1); - chip::ByteSpan longCharStringArgument = chip::ByteSpan( - chip::Uint8::from_const_char( - "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" - "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" - "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉"), - strlen("☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" - "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" - "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉")); + uint16_t clusterRevisionArgument = 2U; - return cluster.WriteAttributeLongCharString(mOnSuccessCallback_103.Cancel(), mOnFailureCallback_103.Cancel(), - longCharStringArgument); + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), + clusterRevisionArgument); } - void OnFailureResponse_103(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { NextTest(); } - void OnSuccessResponse_103(chip::ByteSpan longCharString) { NextTest(); } + void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } +}; - CHIP_ERROR TestReadAttributeLongCharString_104() +class Test_TC_OO_1_1 : public TestCommand +{ +public: + Test_TC_OO_1_1() : TestCommand("Test_TC_OO_1_1"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + CHIP_ERROR err = CHIP_NO_ERROR; - return cluster.ReadAttributeLongCharString(mOnSuccessCallback_104.Cancel(), mOnFailureCallback_104.Cancel()); - } - - void OnFailureResponse_104(uint8_t status) { ThrowFailureResponse(); } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_OO_1_1\n"); + } - void OnSuccessResponse_104(chip::ByteSpan longCharString) - { - VerifyOrReturn(CheckValueAsString( - "longCharString", longCharString, - "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" - "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" - "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉")); - NextTest(); - } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_OO_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - CHIP_ERROR TestWriteAttributeLongCharString_105() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + Wait(); - chip::ByteSpan longCharStringArgument = chip::ByteSpan(chip::Uint8::from_const_char(""), strlen("")); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); + err = TestReadTheGlobalAttributeClusterRevision_0(); + break; + case 1: + ChipLogProgress(chipTool, + " ***** Test Step 1 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : reads back global attribute: ClusterRevision\n"); + err = TestReadsBackGlobalAttributeClusterRevision_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : read the optional global attribute: FeatureMap\n"); + err = TestReadTheOptionalGlobalAttributeFeatureMap_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : write the default values to optional global attribute: FeatureMap\n"); + err = TestWriteTheDefaultValuesToOptionalGlobalAttributeFeatureMap_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : reads back optional global attribute: FeatureMap\n"); + err = TestReadsBackOptionalGlobalAttributeFeatureMap_5(); + break; + } - return cluster.WriteAttributeLongCharString(mOnSuccessCallback_105.Cancel(), mOnFailureCallback_105.Cancel(), - longCharStringArgument); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_105(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 6; - void OnSuccessResponse_105(chip::ByteSpan longCharString) { NextTest(); } + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; - CHIP_ERROR TestReadAttributeList_106() + static void OnFailureCallback_0(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeListInt8u(mOnSuccessCallback_106.Cancel(), mOnFailureCallback_106.Cancel()); + (static_cast(context))->OnFailureResponse_0(status); } - void OnFailureResponse_106(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_106(uint16_t count, uint8_t * listInt8u) + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - VerifyOrReturn(CheckValueAsList("listInt8u", count, 4)); - NextTest(); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } - CHIP_ERROR TestReadAttributeListOctetString_107() + static void OnFailureCallback_1(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeListOctetString(mOnSuccessCallback_107.Cancel(), mOnFailureCallback_107.Cancel()); + (static_cast(context))->OnFailureResponse_1(status); } - void OnFailureResponse_107(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_107(uint16_t count, chip::ByteSpan * listOctetString) + static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) { - VerifyOrReturn(CheckValueAsList("listOctetString", count, 4)); - NextTest(); + (static_cast(context))->OnSuccessResponse_1(clusterRevision); } - CHIP_ERROR TestReadAttributeListStructOctetString_108() + static void OnFailureCallback_2(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeListStructOctetString(mOnSuccessCallback_108.Cancel(), mOnFailureCallback_108.Cancel()); + (static_cast(context))->OnFailureResponse_2(status); } - void OnFailureResponse_108(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_108(uint16_t count, _TestListStructOctet * listStructOctetString) + static void OnSuccessCallback_2(void * context, uint16_t clusterRevision) { - VerifyOrReturn(CheckValueAsList("listStructOctetString", count, 4)); - NextTest(); + (static_cast(context))->OnSuccessResponse_2(clusterRevision); } - CHIP_ERROR TestReadAttributeEpochUsDefaultValue_109() + static void OnFailureCallback_3(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeEpochUs(mOnSuccessCallback_109.Cancel(), mOnFailureCallback_109.Cancel()); + (static_cast(context))->OnFailureResponse_3(status); } - void OnFailureResponse_109(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_109(uint64_t epochUs) + static void OnSuccessCallback_3(void * context, uint32_t featureMap) { - VerifyOrReturn(CheckValue("epochUs", epochUs, 0ULL)); - NextTest(); + (static_cast(context))->OnSuccessResponse_3(featureMap); } - CHIP_ERROR TestWriteAttributeEpochUsMaxValue_110() + static void OnFailureCallback_4(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_4(status); + } - uint64_t epochUsArgument = 18446744073709551615ULL; + static void OnSuccessCallback_4(void * context, uint32_t featureMap) + { + (static_cast(context))->OnSuccessResponse_4(featureMap); + } - return cluster.WriteAttributeEpochUs(mOnSuccessCallback_110.Cancel(), mOnFailureCallback_110.Cancel(), epochUsArgument); + static void OnFailureCallback_5(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_5(status); } - void OnFailureResponse_110(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_5(void * context, uint32_t featureMap) + { + (static_cast(context))->OnSuccessResponse_5(featureMap); + } - void OnSuccessResponse_110(uint64_t epochUs) { NextTest(); } + // + // Tests methods + // - CHIP_ERROR TestReadAttributeEpochUsMaxValue_111() + CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeEpochUs(mOnSuccessCallback_111.Cancel(), mOnFailureCallback_111.Cancel()); + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - void OnFailureResponse_111(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_111(uint64_t epochUs) + void OnSuccessResponse_0(uint16_t clusterRevision) { - VerifyOrReturn(CheckValue("epochUs", epochUs, 18446744073709551615ULL)); + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 3U)); NextTest(); } - CHIP_ERROR TestWriteAttributeEpochUsMinValue_112() + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - uint64_t epochUsArgument = 0ULL; + uint16_t clusterRevisionArgument = 3U; - return cluster.WriteAttributeEpochUs(mOnSuccessCallback_112.Cancel(), mOnFailureCallback_112.Cancel(), epochUsArgument); + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), + clusterRevisionArgument); } - void OnFailureResponse_112(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { NextTest(); } - void OnSuccessResponse_112(uint64_t epochUs) { NextTest(); } + void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } - CHIP_ERROR TestReadAttributeEpochUsMinValue_113() + CHIP_ERROR TestReadsBackGlobalAttributeClusterRevision_2() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeEpochUs(mOnSuccessCallback_113.Cancel(), mOnFailureCallback_113.Cancel()); + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } - void OnFailureResponse_113(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_113(uint64_t epochUs) + void OnSuccessResponse_2(uint16_t clusterRevision) { - VerifyOrReturn(CheckValue("epochUs", epochUs, 0ULL)); + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 3U)); NextTest(); } - CHIP_ERROR TestReadAttributeEpochSDefaultValue_114() + CHIP_ERROR TestReadTheOptionalGlobalAttributeFeatureMap_3() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeEpochS(mOnSuccessCallback_114.Cancel(), mOnFailureCallback_114.Cancel()); + return cluster.ReadAttributeFeatureMap(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } - void OnFailureResponse_114(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_114(uint32_t epochS) + void OnSuccessResponse_3(uint32_t featureMap) { - VerifyOrReturn(CheckValue("epochS", epochS, 0UL)); + VerifyOrReturn(CheckValue("featureMap", featureMap, 0UL)); NextTest(); } - CHIP_ERROR TestWriteAttributeEpochSMaxValue_115() + CHIP_ERROR TestWriteTheDefaultValuesToOptionalGlobalAttributeFeatureMap_4() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - uint32_t epochSArgument = 4294967295UL; + uint32_t featureMapArgument = 0UL; - return cluster.WriteAttributeEpochS(mOnSuccessCallback_115.Cancel(), mOnFailureCallback_115.Cancel(), epochSArgument); + return cluster.WriteAttributeFeatureMap(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel(), featureMapArgument); } - void OnFailureResponse_115(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { NextTest(); } - void OnSuccessResponse_115(uint32_t epochS) { NextTest(); } + void OnSuccessResponse_4(uint32_t featureMap) { ThrowSuccessResponse(); } - CHIP_ERROR TestReadAttributeEpochSMaxValue_116() + CHIP_ERROR TestReadsBackOptionalGlobalAttributeFeatureMap_5() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeEpochS(mOnSuccessCallback_116.Cancel(), mOnFailureCallback_116.Cancel()); + return cluster.ReadAttributeFeatureMap(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); } - void OnFailureResponse_116(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_116(uint32_t epochS) + void OnSuccessResponse_5(uint32_t featureMap) { - VerifyOrReturn(CheckValue("epochS", epochS, 4294967295UL)); + VerifyOrReturn(CheckValue("featureMap", featureMap, 0UL)); NextTest(); } +}; - CHIP_ERROR TestWriteAttributeEpochSMinValue_117() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); +class Test_TC_OO_2_1 : public TestCommand +{ +public: + Test_TC_OO_2_1() : TestCommand("Test_TC_OO_2_1"), mTestIndex(0) {} - uint32_t epochSArgument = 0UL; + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; - return cluster.WriteAttributeEpochS(mOnSuccessCallback_117.Cancel(), mOnFailureCallback_117.Cancel(), epochSArgument); - } - - void OnFailureResponse_117(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_117(uint32_t epochS) { NextTest(); } - - CHIP_ERROR TestReadAttributeEpochSMinValue_118() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeEpochS(mOnSuccessCallback_118.Cancel(), mOnFailureCallback_118.Cancel()); - } - - void OnFailureResponse_118(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_118(uint32_t epochS) - { - VerifyOrReturn(CheckValue("epochS", epochS, 0UL)); - NextTest(); - } - - CHIP_ERROR TestReadAttributeUnsupported_119() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeUnsupported(mOnSuccessCallback_119.Cancel(), mOnFailureCallback_119.Cancel()); - } - - void OnFailureResponse_119(uint8_t status) - { - (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); - } - - void OnSuccessResponse_119(bool unsupported) - { - VerifyOrReturn(CheckValue("unsupported", unsupported, 0)); - NextTest(); - } - - CHIP_ERROR TestWriteattributeUnsupported_120() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - bool unsupportedArgument = 0; - - return cluster.WriteAttributeUnsupported(mOnSuccessCallback_120.Cancel(), mOnFailureCallback_120.Cancel(), - unsupportedArgument); - } - - void OnFailureResponse_120(uint8_t status) - { - (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); - } - - void OnSuccessResponse_120(bool unsupported) { NextTest(); } - - CHIP_ERROR TestSendTestCommandToUnsupportedEndpoint_121() - { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 200); - - using requestType = chip::app::Clusters::TestCluster::Commands::Test::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::TestCluster::Commands::Test::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_121(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_121(status); - }; - return cluster.InvokeCommand(request, this, success, failure); - } - - void OnFailureResponse_121(uint8_t status) { NextTest(); } - - void OnSuccessResponse_121() { ThrowSuccessResponse(); } -}; - -class TestClusterComplexTypes : public TestCommand -{ -public: - TestClusterComplexTypes() : TestCommand("TestClusterComplexTypes"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: TestClusterComplexTypes\n"); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_OO_2_1\n"); + } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TestClusterComplexTypes\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_OO_2_1\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -5688,35 +6967,52 @@ class TestClusterComplexTypes : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Send Test Command With Struct Argument and arg1.b is true\n"); - err = TestSendTestCommandWithStructArgumentAndArg1bIsTrue_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : read the mandatory attribute: OnOff\n"); + err = TestReadTheMandatoryAttributeOnOff_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Send Test Command With Struct Argument and arg1.b is false\n"); - err = TestSendTestCommandWithStructArgumentAndArg1bIsFalse_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : reads back mandatory attribute: OnOff\n"); + err = TestReadsBackMandatoryAttributeOnOff_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Send Test Command With List of INT8U and none of them is set to 0\n"); - err = TestSendTestCommandWithListOfInt8uAndNoneOfThemIsSetTo0_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : read LT attribute: GlobalSceneControl\n"); + err = TestReadLtAttributeGlobalSceneControl_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Send Test Command With List of INT8U and one of them is set to 0\n"); - err = TestSendTestCommandWithListOfInt8uAndOneOfThemIsSetTo0_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : read LT attribute: OnTime\n"); + err = TestReadLtAttributeOnTime_3(); break; case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Send Test Command With List of INT8U and get it reversed\n"); - err = TestSendTestCommandWithListOfInt8uAndGetItReversed_4(); + ChipLogProgress(chipTool, " ***** Test Step 4 : read LT attribute: OffWaitTime\n"); + err = TestReadLtAttributeOffWaitTime_4(); break; case 5: - ChipLogProgress( - chipTool, " ***** Test Step 5 : Send Test Command With List of Struct Argument and arg1.b of first item is true\n"); - err = TestSendTestCommandWithListOfStructArgumentAndArg1bOfFirstItemIsTrue_5(); + ChipLogProgress(chipTool, " ***** Test Step 5 : read LT attribute: StartUpOnOff\n"); + err = TestReadLtAttributeStartUpOnOff_5(); break; case 6: - ChipLogProgress( - chipTool, - " ***** Test Step 6 : Send Test Command With List of Struct Argument and arg1.b of first item is false\n"); - err = TestSendTestCommandWithListOfStructArgumentAndArg1bOfFirstItemIsFalse_6(); + ChipLogProgress(chipTool, " ***** Test Step 6 : write the default value to LT attribute: OnTime\n"); + err = TestWriteTheDefaultValueToLtAttributeOnTime_6(); + break; + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : write the default value to LT attribute: OffWaitTime\n"); + err = TestWriteTheDefaultValueToLtAttributeOffWaitTime_7(); + break; + case 8: + ChipLogProgress(chipTool, " ***** Test Step 8 : write the default value to LT attribute: StartUpOnOff\n"); + err = TestWriteTheDefaultValueToLtAttributeStartUpOnOff_8(); + break; + case 9: + ChipLogProgress(chipTool, " ***** Test Step 9 : reads back LT attribute: OnTime\n"); + err = TestReadsBackLtAttributeOnTime_9(); + break; + case 10: + ChipLogProgress(chipTool, " ***** Test Step 10 : reads back LT attribute: OffWaitTime\n"); + err = TestReadsBackLtAttributeOffWaitTime_10(); + break; + case 11: + ChipLogProgress(chipTool, " ***** Test Step 11 : reads back LT attribute: StartUpOnOff\n"); + err = TestReadsBackLtAttributeStartUpOnOff_11(); break; } @@ -5729,276 +7025,349 @@ class TestClusterComplexTypes : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 7; + const uint16_t mTestCount = 12; - // - // Tests methods - // + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; + chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; + chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; + chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; + chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; + chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; + chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; + chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, this }; + chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; + chip::Callback::Callback mOnSuccessCallback_11{ OnSuccessCallback_11, this }; - CHIP_ERROR TestSendTestCommandWithStructArgumentAndArg1bIsTrue_0() + static void OnFailureCallback_0(void * context, uint8_t status) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::TestCluster::Commands::TestStructArgumentRequest::Type; - using responseType = chip::app::DataModel::NullObjectType; + (static_cast(context))->OnFailureResponse_0(status); + } - chip::app::Clusters::TestCluster::Commands::TestStructArgumentRequest::Type request; + static void OnSuccessCallback_0(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_0(onOff); + } - request.arg1.a = 0; - request.arg1.b = true; - request.arg1.c = static_cast(2); - request.arg1.d = chip::ByteSpan(chip::Uint8::from_const_char("octet_string"), strlen("octet_string")); - request.arg1.e = chip::Span("char_string", strlen("char_string")); - request.arg1.f = static_cast>(1); + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + static void OnSuccessCallback_1(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_1(onOff); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnFailureCallback_2(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_2(status); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_2(void * context, bool globalSceneControl) + { + (static_cast(context))->OnSuccessResponse_2(globalSceneControl); + } - void OnSuccessResponse_0() { NextTest(); } + static void OnFailureCallback_3(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_3(status); + } - CHIP_ERROR TestSendTestCommandWithStructArgumentAndArg1bIsFalse_1() + static void OnSuccessCallback_3(void * context, uint16_t onTime) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_3(onTime); + } - using requestType = chip::app::Clusters::TestCluster::Commands::TestStructArgumentRequest::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnFailureCallback_4(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_4(status); + } - chip::app::Clusters::TestCluster::Commands::TestStructArgumentRequest::Type request; + static void OnSuccessCallback_4(void * context, uint16_t offWaitTime) + { + (static_cast(context))->OnSuccessResponse_4(offWaitTime); + } - request.arg1.a = 0; - request.arg1.b = false; - request.arg1.c = static_cast(2); - request.arg1.d = chip::ByteSpan(chip::Uint8::from_const_char("octet_string"), strlen("octet_string")); - request.arg1.e = chip::Span("char_string", strlen("char_string")); - request.arg1.f = static_cast>(1); + static void OnFailureCallback_5(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_5(status); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(); - }; + static void OnSuccessCallback_5(void * context, uint8_t startUpOnOff) + { + (static_cast(context))->OnSuccessResponse_5(startUpOnOff); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnFailureCallback_6(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_6(status); } - void OnFailureResponse_1(uint8_t status) { NextTest(); } + static void OnSuccessCallback_6(void * context, uint16_t onTime) + { + (static_cast(context))->OnSuccessResponse_6(onTime); + } - void OnSuccessResponse_1() { ThrowSuccessResponse(); } + static void OnFailureCallback_7(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_7(status); + } - CHIP_ERROR TestSendTestCommandWithListOfInt8uAndNoneOfThemIsSetTo0_2() + static void OnSuccessCallback_7(void * context, uint16_t offWaitTime) { - chip::Controller::TestClusterClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_7(offWaitTime); + } - using requestType = chip::app::Clusters::TestCluster::Commands::TestListInt8UArgumentRequest::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnFailureCallback_8(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_8(status); + } - chip::app::Clusters::TestCluster::Commands::TestListInt8UArgumentRequest::Type request; + static void OnSuccessCallback_8(void * context, uint8_t startUpOnOff) + { + (static_cast(context))->OnSuccessResponse_8(startUpOnOff); + } - uint8_t arg1List[9]; - arg1List[0] = 1; - arg1List[1] = 2; - arg1List[2] = 3; - arg1List[3] = 4; - arg1List[4] = 5; - arg1List[5] = 6; - arg1List[6] = 7; - arg1List[7] = 8; - arg1List[8] = 9; - request.arg1 = arg1List; + static void OnFailureCallback_9(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_9(status); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + static void OnSuccessCallback_9(void * context, uint16_t onTime) + { + (static_cast(context))->OnSuccessResponse_9(onTime); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnFailureCallback_10(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_10(status); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_10(void * context, uint16_t offWaitTime) + { + (static_cast(context))->OnSuccessResponse_10(offWaitTime); + } - void OnSuccessResponse_2() { NextTest(); } + static void OnFailureCallback_11(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_11(status); + } - CHIP_ERROR TestSendTestCommandWithListOfInt8uAndOneOfThemIsSetTo0_3() + static void OnSuccessCallback_11(void * context, uint8_t startUpOnOff) { - chip::Controller::TestClusterClusterTest cluster; + (static_cast(context))->OnSuccessResponse_11(startUpOnOff); + } + + // + // Tests methods + // + + CHIP_ERROR TestReadTheMandatoryAttributeOnOff_0() + { + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::TestCluster::Commands::TestListInt8UArgumentRequest::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeOnOff(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + } - chip::app::Clusters::TestCluster::Commands::TestListInt8UArgumentRequest::Type request; + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - uint8_t arg1List[10]; - arg1List[0] = 1; - arg1List[1] = 2; - arg1List[2] = 3; - arg1List[3] = 4; - arg1List[4] = 5; - arg1List[5] = 6; - arg1List[6] = 7; - arg1List[7] = 8; - arg1List[8] = 9; - arg1List[9] = 0; - request.arg1 = arg1List; + void OnSuccessResponse_0(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + CHIP_ERROR TestReadsBackMandatoryAttributeOnOff_1() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - void OnFailureResponse_3(uint8_t status) { NextTest(); } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { ThrowSuccessResponse(); } + void OnSuccessResponse_1(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } - CHIP_ERROR TestSendTestCommandWithListOfInt8uAndGetItReversed_4() + CHIP_ERROR TestReadLtAttributeGlobalSceneControl_2() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::TestCluster::Commands::TestListInt8UReverseRequest::Type; - using responseType = chip::app::Clusters::TestCluster::Commands::TestListInt8UReverseResponse::DecodableType; + return cluster.ReadAttributeGlobalSceneControl(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + } - chip::app::Clusters::TestCluster::Commands::TestListInt8UReverseRequest::Type request; + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - uint8_t arg1List[9]; - arg1List[0] = 1; - arg1List[1] = 2; - arg1List[2] = 3; - arg1List[3] = 4; - arg1List[4] = 5; - arg1List[5] = 6; - arg1List[6] = 7; - arg1List[7] = 8; - arg1List[8] = 9; - request.arg1 = arg1List; + void OnSuccessResponse_2(bool globalSceneControl) + { + VerifyOrReturn(CheckValue("globalSceneControl", globalSceneControl, 1)); + NextTest(); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(data.arg1); - }; + CHIP_ERROR TestReadLtAttributeOnTime_3() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeOnTime(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4(chip::app::DataModel::DecodableList arg1) + void OnSuccessResponse_3(uint16_t onTime) { - VerifyOrReturn(CheckValueAsList("arg1", arg1, 9, 8, 7, 6, 5, 4, 3, 2, 1)); + VerifyOrReturn(CheckValue("onTime", onTime, 0U)); NextTest(); } - CHIP_ERROR TestSendTestCommandWithListOfStructArgumentAndArg1bOfFirstItemIsTrue_5() + CHIP_ERROR TestReadLtAttributeOffWaitTime_4() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::TestCluster::Commands::TestListStructArgumentRequest::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeOffWaitTime(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + } - chip::app::Clusters::TestCluster::Commands::TestListStructArgumentRequest::Type request; + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - chip::app::Clusters::TestCluster::Structs::SimpleStruct::Type arg1List[2]; + void OnSuccessResponse_4(uint16_t offWaitTime) + { + VerifyOrReturn(CheckValue("offWaitTime", offWaitTime, 0U)); + NextTest(); + } - arg1List[0].a = 0; - arg1List[0].b = true; - arg1List[0].c = static_cast(2); - arg1List[0].d = chip::ByteSpan(chip::Uint8::from_const_char("first_octet_string"), strlen("first_octet_string")); - arg1List[0].e = chip::Span("first_char_string", strlen("first_char_string")); - arg1List[0].f = static_cast>(1); + CHIP_ERROR TestReadLtAttributeStartUpOnOff_5() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - arg1List[1].a = 1; - arg1List[1].b = true; - arg1List[1].c = static_cast(3); - arg1List[1].d = chip::ByteSpan(chip::Uint8::from_const_char("second_octet_string"), strlen("second_octet_string")); - arg1List[1].e = chip::Span("second_char_string", strlen("second_char_string")); - arg1List[1].f = static_cast>(1); + return cluster.ReadAttributeStartUpOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + } - request.arg1 = arg1List; + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_5(); - }; + void OnSuccessResponse_5(uint8_t startUpOnOff) + { + VerifyOrReturn(CheckValue("startUpOnOff", startUpOnOff, 0)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_5(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteTheDefaultValueToLtAttributeOnTime_6() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint16_t onTimeArgument = 0U; + + return cluster.WriteAttributeOnTime(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel(), onTimeArgument); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5() { NextTest(); } + void OnSuccessResponse_6(uint16_t onTime) { NextTest(); } - CHIP_ERROR TestSendTestCommandWithListOfStructArgumentAndArg1bOfFirstItemIsFalse_6() + CHIP_ERROR TestWriteTheDefaultValueToLtAttributeOffWaitTime_7() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::TestCluster::Commands::TestListStructArgumentRequest::Type; - using responseType = chip::app::DataModel::NullObjectType; + uint16_t offWaitTimeArgument = 0U; - chip::app::Clusters::TestCluster::Commands::TestListStructArgumentRequest::Type request; + return cluster.WriteAttributeOffWaitTime(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel(), offWaitTimeArgument); + } - chip::app::Clusters::TestCluster::Structs::SimpleStruct::Type arg1List[2]; + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - arg1List[0].a = 1; - arg1List[0].b = true; - arg1List[0].c = static_cast(3); - arg1List[0].d = chip::ByteSpan(chip::Uint8::from_const_char("second_octet_string"), strlen("second_octet_string")); - arg1List[0].e = chip::Span("second_char_string", strlen("second_char_string")); - arg1List[0].f = static_cast>(1); + void OnSuccessResponse_7(uint16_t offWaitTime) { NextTest(); } - arg1List[1].a = 0; - arg1List[1].b = false; - arg1List[1].c = static_cast(2); - arg1List[1].d = chip::ByteSpan(chip::Uint8::from_const_char("first_octet_string"), strlen("first_octet_string")); - arg1List[1].e = chip::Span("first_char_string", strlen("first_char_string")); - arg1List[1].f = static_cast>(1); + CHIP_ERROR TestWriteTheDefaultValueToLtAttributeStartUpOnOff_8() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); - request.arg1 = arg1List; + uint8_t startUpOnOffArgument = 0; - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_6(); - }; + return cluster.WriteAttributeStartUpOnOff(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel(), + startUpOnOffArgument); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_6(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_8(uint8_t startUpOnOff) { NextTest(); } + + CHIP_ERROR TestReadsBackLtAttributeOnTime_9() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnTime(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel()); } - void OnFailureResponse_6(uint8_t status) { NextTest(); } + void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_6() { ThrowSuccessResponse(); } + void OnSuccessResponse_9(uint16_t onTime) + { + VerifyOrReturn(CheckValue("onTime", onTime, 0U)); + NextTest(); + } + + CHIP_ERROR TestReadsBackLtAttributeOffWaitTime_10() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOffWaitTime(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); + } + + void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_10(uint16_t offWaitTime) + { + VerifyOrReturn(CheckValue("offWaitTime", offWaitTime, 0U)); + NextTest(); + } + + CHIP_ERROR TestReadsBackLtAttributeStartUpOnOff_11() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeStartUpOnOff(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel()); + } + + void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_11(uint8_t startUpOnOff) + { + VerifyOrReturn(CheckValue("startUpOnOff", startUpOnOff, 0)); + NextTest(); + } }; -class TestConstraints : public TestCommand +class Test_TC_OO_2_2 : public TestCommand { public: - TestConstraints() : TestCommand("TestConstraints"), mTestIndex(0) {} + Test_TC_OO_2_2() : TestCommand("Test_TC_OO_2_2"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -6007,12 +7376,12 @@ class TestConstraints : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TestConstraints\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_OO_2_2\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TestConstraints\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_OO_2_2\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -6026,20 +7395,60 @@ class TestConstraints : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Write attribute INT32U Value\n"); - err = TestWriteAttributeInt32uValue_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Send Off Command\n"); + err = TestSendOffCommand_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Read attribute INT32U Value MinValue Constraints\n"); - err = TestReadAttributeInt32uValueMinValueConstraints_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Read attribute INT32U Value MaxValue Constraints\n"); - err = TestReadAttributeInt32uValueMaxValueConstraints_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Send On Command\n"); + err = TestSendOnCommand_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Read attribute INT32U Value NotValue Constraints\n"); - err = TestReadAttributeInt32uValueNotValueConstraints_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Send Off Command\n"); + err = TestSendOffCommand_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); + break; + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : Send Toggle Command\n"); + err = TestSendToggleCommand_6(); + break; + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : Check on/off attribute value is true after toggle command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterToggleCommand_7(); + break; + case 8: + ChipLogProgress(chipTool, " ***** Test Step 8 : Send Toggle Command\n"); + err = TestSendToggleCommand_8(); + break; + case 9: + ChipLogProgress(chipTool, " ***** Test Step 9 : Check on/off attribute value is false after toggle command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterToggleCommand_9(); + break; + case 10: + ChipLogProgress(chipTool, " ***** Test Step 10 : Send On Command\n"); + err = TestSendOnCommand_10(); + break; + case 11: + ChipLogProgress(chipTool, " ***** Test Step 11 : Check on/off attribute value is true after on command\n"); + err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_11(); + break; + case 12: + ChipLogProgress(chipTool, " ***** Test Step 12 : Send Off Command\n"); + err = TestSendOffCommand_12(); + break; + case 13: + ChipLogProgress(chipTool, " ***** Test Step 13 : Check on/off attribute value is false after off command\n"); + err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_13(); break; } @@ -6052,128 +7461,382 @@ class TestConstraints : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 4; + const uint16_t mTestCount = 14; - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; + chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; + chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; + chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; + chip::Callback::Callback mOnSuccessCallback_11{ OnSuccessCallback_11, this }; + chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; + chip::Callback::Callback mOnSuccessCallback_13{ OnSuccessCallback_13, this }; - static void OnFailureCallback_0(void * context, uint8_t status) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_0(void * context, uint32_t int32u) + static void OnSuccessCallback_1(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_0(int32u); + (static_cast(context))->OnSuccessResponse_1(onOff); } - static void OnFailureCallback_1(void * context, uint8_t status) + static void OnFailureCallback_3(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_3(status); } - static void OnSuccessCallback_1(void * context, uint32_t int32u) + static void OnSuccessCallback_3(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_1(int32u); + (static_cast(context))->OnSuccessResponse_3(onOff); } - static void OnFailureCallback_2(void * context, uint8_t status) + static void OnFailureCallback_5(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_5(status); } - static void OnSuccessCallback_2(void * context, uint32_t int32u) + static void OnSuccessCallback_5(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_2(int32u); + (static_cast(context))->OnSuccessResponse_5(onOff); } - static void OnFailureCallback_3(void * context, uint8_t status) + static void OnFailureCallback_7(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_3(status); + (static_cast(context))->OnFailureResponse_7(status); } - static void OnSuccessCallback_3(void * context, uint32_t int32u) + static void OnSuccessCallback_7(void * context, bool onOff) { - (static_cast(context))->OnSuccessResponse_3(int32u); + (static_cast(context))->OnSuccessResponse_7(onOff); + } + + static void OnFailureCallback_9(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_9(status); + } + + static void OnSuccessCallback_9(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_9(onOff); + } + + static void OnFailureCallback_11(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_11(status); + } + + static void OnSuccessCallback_11(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_11(onOff); + } + + static void OnFailureCallback_13(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_13(status); + } + + static void OnSuccessCallback_13(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_13(onOff); } // // Tests methods // - CHIP_ERROR TestWriteAttributeInt32uValue_0() + CHIP_ERROR TestSendOffCommand_0() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - uint32_t int32uArgument = 5UL; + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; - return cluster.WriteAttributeInt32u(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), int32uArgument); + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint32_t int32u) { NextTest(); } + void OnSuccessResponse_0() { NextTest(); } - CHIP_ERROR TestReadAttributeInt32uValueMinValueConstraints_1() + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_1() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeInt32u(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint32_t int32u) + void OnSuccessResponse_1(bool onOff) { - VerifyOrReturn(CheckConstraintMinValue("int32u", int32u, 5)); + VerifyOrReturn(CheckValue("onOff", onOff, 0)); NextTest(); } - CHIP_ERROR TestReadAttributeInt32uValueMaxValueConstraints_2() + CHIP_ERROR TestSendOnCommand_2() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeInt32u(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); - } - + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint32_t int32u) + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_3() { - VerifyOrReturn(CheckConstraintMaxValue("int32u", int32u, 5)); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + } + + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); NextTest(); } - CHIP_ERROR TestReadAttributeInt32uValueNotValueConstraints_3() + CHIP_ERROR TestSendOffCommand_4() { - chip::Controller::TestClusterClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeInt32u(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_4(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_4(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3(uint32_t int32u) + void OnSuccessResponse_4() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() { - VerifyOrReturn(CheckConstraintNotValue("int32u", int32u, 6)); + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + } + + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_5(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } + + CHIP_ERROR TestSendToggleCommand_6() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Toggle::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Toggle::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_6(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_6(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_6() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterToggleCommand_7() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + } + + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_7(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } + + CHIP_ERROR TestSendToggleCommand_8() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Toggle::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Toggle::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_8(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_8(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_8() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterToggleCommand_9() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel()); + } + + void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_9(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); + NextTest(); + } + + CHIP_ERROR TestSendOnCommand_10() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::On::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_10(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_10(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_10() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_11() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel()); + } + + void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_11(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 1)); + NextTest(); + } + + CHIP_ERROR TestSendOffCommand_12() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::OnOff::Commands::Off::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_12(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_12(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_12(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_12() { NextTest(); } + + CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_13() + { + chip::Controller::OnOffClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOnOff(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel()); + } + + void OnFailureResponse_13(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_13(bool onOff) + { + VerifyOrReturn(CheckValue("onOff", onOff, 0)); NextTest(); } }; -class TestDelayCommands : public TestCommand +class Test_TC_PCC_1_1 : public TestCommand { public: - TestDelayCommands() : TestCommand("TestDelayCommands"), mTestIndex(0) {} + Test_TC_PCC_1_1() : TestCommand("Test_TC_PCC_1_1"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -6182,12 +7845,12 @@ class TestDelayCommands : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TestDelayCommands\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_PCC_1_1\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TestDelayCommands\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_PCC_1_1\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -6201,8 +7864,9 @@ class TestDelayCommands : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Wait 100ms\n"); - err = TestWait100ms_0(); + ChipLogProgress(chipTool, + " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); break; } @@ -6217,17 +7881,43 @@ class TestDelayCommands : public TestCommand std::atomic_uint16_t mTestIndex; const uint16_t mTestCount = 1; + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + + static void OnFailureCallback_0(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_0(status); + } + + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) + { + (static_cast(context))->OnSuccessResponse_0(clusterRevision); + } + // // Tests methods // - CHIP_ERROR TestWait100ms_0() { return WaitForMs(100); } -}; - -class TestDescriptorCluster : public TestCommand + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() + { + chip::Controller::PumpConfigurationAndControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint16_t clusterRevisionArgument = 3U; + + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), + clusterRevisionArgument); + } + + void OnFailureResponse_0(uint8_t status) { NextTest(); } + + void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } +}; + +class Test_TC_PCC_2_1 : public TestCommand { public: - TestDescriptorCluster() : TestCommand("TestDescriptorCluster"), mTestIndex(0) {} + Test_TC_PCC_2_1() : TestCommand("Test_TC_PCC_2_1"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -6236,12 +7926,12 @@ class TestDescriptorCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TestDescriptorCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_PCC_2_1\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TestDescriptorCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_PCC_2_1\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -6255,20 +7945,36 @@ class TestDescriptorCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute Device list\n"); - err = TestReadAttributeDeviceList_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : read the mandatory attribute: MaxPressure\n"); + err = TestReadTheMandatoryAttributeMaxPressure_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Read attribute Server list\n"); - err = TestReadAttributeServerList_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : read the mandatory attribute: EffectiveOperationMode\n"); + err = TestReadTheMandatoryAttributeEffectiveOperationMode_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Read attribute Client list\n"); - err = TestReadAttributeClientList_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : read the mandatory attribute: EffectiveControlMode\n"); + err = TestReadTheMandatoryAttributeEffectiveControlMode_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Read attribute Parts list\n"); - err = TestReadAttributePartsList_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : read the mandatory attribute: Capacity\n"); + err = TestReadTheMandatoryAttributeCapacity_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : read the mandatory attribute: MaxPressure\n"); + err = TestReadTheMandatoryAttributeMaxPressure_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : read the mandatory attribute: EffectiveOperationMode\n"); + err = TestReadTheMandatoryAttributeEffectiveOperationMode_5(); + break; + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : read the mandatory attribute: EffectiveControlMode\n"); + err = TestReadTheMandatoryAttributeEffectiveControlMode_6(); + break; + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : read the mandatory attribute: Capacity\n"); + err = TestReadTheMandatoryAttributeCapacity_7(); break; } @@ -6281,191 +7987,276 @@ class TestDescriptorCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 4; + const uint16_t mTestCount = 8; chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ - OnSuccessCallback_0, this - }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ - OnSuccessCallback_1, this - }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, + this }; chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ - OnSuccessCallback_2, this - }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, + this }; chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ - OnSuccessCallback_3, this - }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, + this }; + chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; + chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, + this }; + chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_0(void * context, uint16_t count, _DeviceType * deviceList) + static void OnSuccessCallback_0(void * context, int16_t maxPressure) { - (static_cast(context))->OnSuccessResponse_0(count, deviceList); + (static_cast(context))->OnSuccessResponse_0(maxPressure); } static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_1(void * context, uint16_t count, chip::ClusterId * serverList) + static void OnSuccessCallback_1(void * context, uint8_t effectiveOperationMode) { - (static_cast(context))->OnSuccessResponse_1(count, serverList); + (static_cast(context))->OnSuccessResponse_1(effectiveOperationMode); } static void OnFailureCallback_2(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_2(status); } - static void OnSuccessCallback_2(void * context, uint16_t count, chip::ClusterId * clientList) + static void OnSuccessCallback_2(void * context, uint8_t effectiveControlMode) { - (static_cast(context))->OnSuccessResponse_2(count, clientList); + (static_cast(context))->OnSuccessResponse_2(effectiveControlMode); } static void OnFailureCallback_3(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_3(status); + (static_cast(context))->OnFailureResponse_3(status); } - static void OnSuccessCallback_3(void * context, uint16_t count, chip::EndpointId * partsList) + static void OnSuccessCallback_3(void * context, int16_t capacity) { - (static_cast(context))->OnSuccessResponse_3(count, partsList); + (static_cast(context))->OnSuccessResponse_3(capacity); + } + + static void OnFailureCallback_4(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_4(status); + } + + static void OnSuccessCallback_4(void * context, int16_t maxPressure) + { + (static_cast(context))->OnSuccessResponse_4(maxPressure); + } + + static void OnFailureCallback_5(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_5(status); + } + + static void OnSuccessCallback_5(void * context, uint8_t effectiveOperationMode) + { + (static_cast(context))->OnSuccessResponse_5(effectiveOperationMode); + } + + static void OnFailureCallback_6(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_6(status); + } + + static void OnSuccessCallback_6(void * context, uint8_t effectiveControlMode) + { + (static_cast(context))->OnSuccessResponse_6(effectiveControlMode); + } + + static void OnFailureCallback_7(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_7(status); + } + + static void OnSuccessCallback_7(void * context, int16_t capacity) + { + (static_cast(context))->OnSuccessResponse_7(capacity); } // // Tests methods // - CHIP_ERROR TestReadAttributeDeviceList_0() + CHIP_ERROR TestReadTheMandatoryAttributeMaxPressure_0() { - chip::Controller::DescriptorClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::PumpConfigurationAndControlClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeDeviceList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + return cluster.ReadAttributeMaxPressure(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint16_t count, _DeviceType * deviceList) + void OnSuccessResponse_0(int16_t maxPressure) { - VerifyOrReturn(CheckValueAsList("deviceList", count, 1)); + VerifyOrReturn(CheckConstraintType("maxPressure", "", "int16")); NextTest(); } - CHIP_ERROR TestReadAttributeServerList_1() + CHIP_ERROR TestReadTheMandatoryAttributeEffectiveOperationMode_1() { - chip::Controller::DescriptorClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::PumpConfigurationAndControlClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeServerList(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeEffectiveOperationMode(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint16_t count, chip::ClusterId * serverList) + void OnSuccessResponse_1(uint8_t effectiveOperationMode) { - VerifyOrReturn(CheckValueAsList("serverList", count, 18)); + VerifyOrReturn(CheckConstraintType("effectiveOperationMode", "", "enum8")); NextTest(); } - CHIP_ERROR TestReadAttributeClientList_2() + CHIP_ERROR TestReadTheMandatoryAttributeEffectiveControlMode_2() { - chip::Controller::DescriptorClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::PumpConfigurationAndControlClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeClientList(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + return cluster.ReadAttributeEffectiveControlMode(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint16_t count, chip::ClusterId * clientList) + void OnSuccessResponse_2(uint8_t effectiveControlMode) { - VerifyOrReturn(CheckValueAsList("clientList", count, 0)); + VerifyOrReturn(CheckConstraintType("effectiveControlMode", "", "enum8")); NextTest(); } - CHIP_ERROR TestReadAttributePartsList_3() + CHIP_ERROR TestReadTheMandatoryAttributeCapacity_3() { - chip::Controller::DescriptorClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::PumpConfigurationAndControlClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributePartsList(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + return cluster.ReadAttributeCapacity(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3(uint16_t count, chip::EndpointId * partsList) + void OnSuccessResponse_3(int16_t capacity) { - VerifyOrReturn(CheckValueAsList("partsList", count, 2)); + VerifyOrReturn(CheckConstraintType("capacity", "", "int16")); NextTest(); } -}; -class TestSubscribe_OnOff : public TestCommand -{ -public: - TestSubscribe_OnOff() : TestCommand("TestSubscribe_OnOff"), mTestIndex(0) {} + CHIP_ERROR TestReadTheMandatoryAttributeMaxPressure_4() + { + chip::Controller::PumpConfigurationAndControlClusterTest cluster; + cluster.Associate(mDevice, 1); - /////////// TestCommand Interface ///////// - void NextTest() override + return cluster.ReadAttributeMaxPressure(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + } + + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_4(int16_t maxPressure) { - CHIP_ERROR err = CHIP_NO_ERROR; + VerifyOrReturn(CheckConstraintType("maxPressure", "", "int16")); + NextTest(); + } - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: TestSubscribe_OnOff\n"); - } + CHIP_ERROR TestReadTheMandatoryAttributeEffectiveOperationMode_5() + { + chip::Controller::PumpConfigurationAndControlClusterTest cluster; + cluster.Associate(mDevice, 1); - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: TestSubscribe_OnOff\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + return cluster.ReadAttributeEffectiveOperationMode(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + } - Wait(); + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Set OnOff Attribute to false\n"); - err = TestSetOnOffAttributeToFalse_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Report: Subscribe OnOff Attribute\n"); - err = TestReportSubscribeOnOffAttribute_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Subscribe OnOff Attribute\n"); - err = TestSubscribeOnOffAttribute_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Turn On the light to see attribute change\n"); - err = TestTurnOnTheLightToSeeAttributeChange_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Check for attribute report\n"); - err = TestCheckForAttributeReport_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Turn Off the light to see attribute change\n"); - err = TestTurnOffTheLightToSeeAttributeChange_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : Check for attribute report\n"); - err = TestCheckForAttributeReport_6(); + void OnSuccessResponse_5(uint8_t effectiveOperationMode) + { + VerifyOrReturn(CheckConstraintType("effectiveOperationMode", "", "enum8")); + NextTest(); + } + + CHIP_ERROR TestReadTheMandatoryAttributeEffectiveControlMode_6() + { + chip::Controller::PumpConfigurationAndControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeEffectiveControlMode(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); + } + + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_6(uint8_t effectiveControlMode) + { + VerifyOrReturn(CheckConstraintType("effectiveControlMode", "", "enum8")); + NextTest(); + } + + CHIP_ERROR TestReadTheMandatoryAttributeCapacity_7() + { + chip::Controller::PumpConfigurationAndControlClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeCapacity(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + } + + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_7(int16_t capacity) + { + VerifyOrReturn(CheckConstraintType("capacity", "", "int16")); + NextTest(); + } +}; + +class Test_TC_RH_1_1 : public TestCommand +{ +public: + Test_TC_RH_1_1() : TestCommand("Test_TC_RH_1_1"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; + + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_RH_1_1\n"); + } + + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_RH_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } + + Wait(); + + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, + " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); break; } @@ -6478,222 +8269,352 @@ class TestSubscribe_OnOff : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 7; + const uint16_t mTestCount = 1; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; - chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; - chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - static void OnFailureCallback_1(void * context, uint8_t status) + static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_1(void * context, bool onOff) + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - (static_cast(context))->OnSuccessResponse_1(onOff); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } - bool mReceivedReport_1 = false; + // + // Tests methods + // - static void OnFailureCallback_2(void * context, uint8_t status) + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() { - (static_cast(context))->OnFailureResponse_2(status); + chip::Controller::RelativeHumidityMeasurementClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint16_t clusterRevisionArgument = 1U; + + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), + clusterRevisionArgument); } - static void OnSuccessCallback_2(void * context, bool onOff) + void OnFailureResponse_0(uint8_t status) { NextTest(); } + + void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } +}; + +class Test_TC_TM_1_1 : public TestCommand +{ +public: + Test_TC_TM_1_1() : TestCommand("Test_TC_TM_1_1"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override { - (static_cast(context))->OnSuccessResponse_2(onOff); + CHIP_ERROR err = CHIP_NO_ERROR; + + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_TM_1_1\n"); + } + + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_TM_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } + + Wait(); + + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); + err = TestReadTheGlobalAttributeClusterRevision_0(); + break; + case 1: + ChipLogProgress(chipTool, + " ***** Test Step 1 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : reads back global attribute: ClusterRevision\n"); + err = TestReadsBackGlobalAttributeClusterRevision_2(); + break; + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - static void OnFailureCallback_4(void * context, uint8_t status) +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 3; + + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + + static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_4(void * context, bool onOff) + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - (static_cast(context))->OnSuccessResponse_4(onOff); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } - bool mReceivedReport_4 = false; + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); + } - static void OnFailureCallback_6(void * context, uint8_t status) + static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) { - (static_cast(context))->OnFailureResponse_6(status); + (static_cast(context))->OnSuccessResponse_1(clusterRevision); } - static void OnSuccessCallback_6(void * context, bool onOff) + static void OnFailureCallback_2(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_6(onOff); + (static_cast(context))->OnFailureResponse_2(status); } - bool mReceivedReport_6 = false; + static void OnSuccessCallback_2(void * context, uint16_t clusterRevision) + { + (static_cast(context))->OnSuccessResponse_2(clusterRevision); + } // // Tests methods // - CHIP_ERROR TestSetOnOffAttributeToFalse_0() + CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TemperatureMeasurementClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Off::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_0(uint16_t clusterRevision) + { + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 3U)); + NextTest(); + } - CHIP_ERROR TestReportSubscribeOnOffAttribute_1() + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TemperatureMeasurementClusterTest cluster; cluster.Associate(mDevice, 1); - ReturnErrorOnFailure(cluster.ReportAttributeOnOff(mOnSuccessCallback_1.Cancel())); - return WaitForMs(0); + uint16_t clusterRevisionArgument = 3U; + + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), + clusterRevisionArgument); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { NextTest(); } - void OnSuccessResponse_1(bool onOff) - { - VerifyOrReturn(mReceivedReport_1 == false, ChipLogError(chipTool, "Not Fatal: on report called more than once.")); - mReceivedReport_1 = true; + void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } - VerifyOrReturn(CheckValue("onOff", onOff, false)); - } - - CHIP_ERROR TestSubscribeOnOffAttribute_2() + CHIP_ERROR TestReadsBackGlobalAttributeClusterRevision_2() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TemperatureMeasurementClusterTest cluster; cluster.Associate(mDevice, 1); - uint16_t minIntervalArgument = 2; - uint16_t maxIntervalArgument = 10; - - return cluster.SubscribeAttributeOnOff(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel(), minIntervalArgument, - maxIntervalArgument); + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(bool onOff) + void OnSuccessResponse_2(uint16_t clusterRevision) { - VerifyOrReturn(mReceivedReport_1, Exit("Initial report not received!")); - + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 3U)); NextTest(); } +}; - CHIP_ERROR TestTurnOnTheLightToSeeAttributeChange_3() +class Test_TC_TM_2_1 : public TestCommand +{ +public: + Test_TC_TM_2_1() : TestCommand("Test_TC_TM_2_1"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + CHIP_ERROR err = CHIP_NO_ERROR; - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_TM_2_1\n"); + } - chip::app::Clusters::OnOff::Commands::On::Type request; + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_TM_2_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + Wait(); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : read the mandatory attribute: MeasuredValue\n"); + err = TestReadTheMandatoryAttributeMeasuredValue_0(); + break; + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 1; - void OnSuccessResponse_3() { NextTest(); } + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - CHIP_ERROR TestCheckForAttributeReport_4() + static void OnFailureCallback_0(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_0(status); + } - return cluster.ReportAttributeOnOff(mOnSuccessCallback_4.Cancel()); + static void OnSuccessCallback_0(void * context, int16_t measuredValue) + { + (static_cast(context))->OnSuccessResponse_0(measuredValue); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + // + // Tests methods + // - void OnSuccessResponse_4(bool onOff) + CHIP_ERROR TestReadTheMandatoryAttributeMeasuredValue_0() { - VerifyOrReturn(mReceivedReport_4 == false, ChipLogError(chipTool, "Not Fatal: on report called more than once.")); - mReceivedReport_4 = true; + chip::Controller::TemperatureMeasurementClusterTest cluster; + cluster.Associate(mDevice, 1); - VerifyOrReturn(CheckValue("onOff", onOff, true)); + return cluster.ReadAttributeMeasuredValue(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + } + + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_0(int16_t measuredValue) + { + VerifyOrReturn(CheckConstraintType("measuredValue", "", "int16")); NextTest(); } +}; - CHIP_ERROR TestTurnOffTheLightToSeeAttributeChange_5() +class Test_TC_TSTAT_1_1 : public TestCommand +{ +public: + Test_TC_TSTAT_1_1() : TestCommand("Test_TC_TSTAT_1_1"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + CHIP_ERROR err = CHIP_NO_ERROR; - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_TSTAT_1_1\n"); + } - chip::app::Clusters::OnOff::Commands::Off::Type request; + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_TSTAT_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_5(); - }; + Wait(); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_5(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, + " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); + break; + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 1; - void OnSuccessResponse_5() { NextTest(); } + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - CHIP_ERROR TestCheckForAttributeReport_6() + static void OnFailureCallback_0(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_0(status); + } - return cluster.ReportAttributeOnOff(mOnSuccessCallback_6.Cancel()); + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) + { + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + // + // Tests methods + // - void OnSuccessResponse_6(bool onOff) + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() { - VerifyOrReturn(mReceivedReport_6 == false, ChipLogError(chipTool, "Not Fatal: on report called more than once.")); - mReceivedReport_6 = true; + chip::Controller::ThermostatClusterTest cluster; + cluster.Associate(mDevice, 1); - VerifyOrReturn(CheckValue("onOff", onOff, false)); - NextTest(); + uint16_t clusterRevisionArgument = 5U; + + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), + clusterRevisionArgument); } + + void OnFailureResponse_0(uint8_t status) { NextTest(); } + + void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } }; -class Test_TC_OO_1_1 : public TestCommand +class Test_TC_TSUIC_1_1 : public TestCommand { public: - Test_TC_OO_1_1() : TestCommand("Test_TC_OO_1_1"), mTestIndex(0) {} + Test_TC_TSUIC_1_1() : TestCommand("Test_TC_TSUIC_1_1"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -6702,12 +8623,12 @@ class Test_TC_OO_1_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_OO_1_1\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_TSUIC_1_1\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_OO_1_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_TSUIC_1_1\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -6721,29 +8642,9 @@ class Test_TC_OO_1_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); - err = TestReadTheGlobalAttributeClusterRevision_0(); - break; - case 1: ChipLogProgress(chipTool, - " ***** Test Step 1 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : reads back global attribute: ClusterRevision\n"); - err = TestReadsBackGlobalAttributeClusterRevision_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : read the optional global attribute: FeatureMap\n"); - err = TestReadTheOptionalGlobalAttributeFeatureMap_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : write the default values to optional global attribute: FeatureMap\n"); - err = TestWriteTheDefaultValuesToOptionalGlobalAttributeFeatureMap_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : reads back optional global attribute: FeatureMap\n"); - err = TestReadsBackOptionalGlobalAttributeFeatureMap_5(); + " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); break; } @@ -6756,183 +8657,45 @@ class Test_TC_OO_1_1 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 6; + const uint16_t mTestCount = 1; chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); } static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } - static void OnFailureCallback_1(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_1(status); - } + // + // Tests methods + // - static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() { - (static_cast(context))->OnSuccessResponse_1(clusterRevision); + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint16_t clusterRevisionArgument = 2U; + + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), + clusterRevisionArgument); } - static void OnFailureCallback_2(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_2(status); - } - - static void OnSuccessCallback_2(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_2(clusterRevision); - } - - static void OnFailureCallback_3(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_3(status); - } - - static void OnSuccessCallback_3(void * context, uint32_t featureMap) - { - (static_cast(context))->OnSuccessResponse_3(featureMap); - } - - static void OnFailureCallback_4(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_4(status); - } - - static void OnSuccessCallback_4(void * context, uint32_t featureMap) - { - (static_cast(context))->OnSuccessResponse_4(featureMap); - } - - static void OnFailureCallback_5(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_5(status); - } - - static void OnSuccessCallback_5(void * context, uint32_t featureMap) - { - (static_cast(context))->OnSuccessResponse_5(featureMap); - } - - // - // Tests methods - // - - CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); - } - - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0(uint16_t clusterRevision) - { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 3U)); - NextTest(); - } - - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t clusterRevisionArgument = 3U; - - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), - clusterRevisionArgument); - } - - void OnFailureResponse_1(uint8_t status) { NextTest(); } - - void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } - - CHIP_ERROR TestReadsBackGlobalAttributeClusterRevision_2() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); - } - - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_2(uint16_t clusterRevision) - { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 3U)); - NextTest(); - } - - CHIP_ERROR TestReadTheOptionalGlobalAttributeFeatureMap_3() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeFeatureMap(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); - } - - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_3(uint32_t featureMap) - { - VerifyOrReturn(CheckValue("featureMap", featureMap, 0UL)); - NextTest(); - } - - CHIP_ERROR TestWriteTheDefaultValuesToOptionalGlobalAttributeFeatureMap_4() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint32_t featureMapArgument = 0UL; - - return cluster.WriteAttributeFeatureMap(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel(), featureMapArgument); - } - - void OnFailureResponse_4(uint8_t status) { NextTest(); } - - void OnSuccessResponse_4(uint32_t featureMap) { ThrowSuccessResponse(); } - - CHIP_ERROR TestReadsBackOptionalGlobalAttributeFeatureMap_5() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeFeatureMap(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); - } - - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { NextTest(); } - void OnSuccessResponse_5(uint32_t featureMap) - { - VerifyOrReturn(CheckValue("featureMap", featureMap, 0UL)); - NextTest(); - } + void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } }; -class Test_TC_OO_2_1 : public TestCommand +class Test_TC_TSUIC_2_1 : public TestCommand { public: - Test_TC_OO_2_1() : TestCommand("Test_TC_OO_2_1"), mTestIndex(0) {} + Test_TC_TSUIC_2_1() : TestCommand("Test_TC_TSUIC_2_1"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -6941,12 +8704,12 @@ class Test_TC_OO_2_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_OO_2_1\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_TSUIC_2_1\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_OO_2_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_TSUIC_2_1\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -6960,52 +8723,64 @@ class Test_TC_OO_2_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the mandatory attribute: OnOff\n"); - err = TestReadTheMandatoryAttributeOnOff_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : read the mandatory attribute: TemperatureDisplayMode\n"); + err = TestReadTheMandatoryAttributeTemperatureDisplayMode_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : reads back mandatory attribute: OnOff\n"); - err = TestReadsBackMandatoryAttributeOnOff_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : read the mandatory attribute: TemperatureDisplayMode\n"); + err = TestReadTheMandatoryAttributeTemperatureDisplayMode_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : read LT attribute: GlobalSceneControl\n"); - err = TestReadLtAttributeGlobalSceneControl_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : write to the mandatory attribute: TemperatureDisplayMode\n"); + err = TestWriteToTheMandatoryAttributeTemperatureDisplayMode_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : read LT attribute: OnTime\n"); - err = TestReadLtAttributeOnTime_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : read the mandatory attribute: TemperatureDisplayMode\n"); + err = TestReadTheMandatoryAttributeTemperatureDisplayMode_3(); break; case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : read LT attribute: OffWaitTime\n"); - err = TestReadLtAttributeOffWaitTime_4(); + ChipLogProgress(chipTool, " ***** Test Step 4 : read the mandatory attribute: TemperatureDisplayMode\n"); + err = TestReadTheMandatoryAttributeTemperatureDisplayMode_4(); break; case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : read LT attribute: StartUpOnOff\n"); - err = TestReadLtAttributeStartUpOnOff_5(); + ChipLogProgress(chipTool, " ***** Test Step 5 : read the mandatory attribute: KeypadLockout\n"); + err = TestReadTheMandatoryAttributeKeypadLockout_5(); break; case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : write the default value to LT attribute: OnTime\n"); - err = TestWriteTheDefaultValueToLtAttributeOnTime_6(); + ChipLogProgress(chipTool, " ***** Test Step 6 : read the mandatory attribute: KeypadLockout\n"); + err = TestReadTheMandatoryAttributeKeypadLockout_6(); break; case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : write the default value to LT attribute: OffWaitTime\n"); - err = TestWriteTheDefaultValueToLtAttributeOffWaitTime_7(); + ChipLogProgress(chipTool, " ***** Test Step 7 : write to the mandatory attribute: KeypadLockout\n"); + err = TestWriteToTheMandatoryAttributeKeypadLockout_7(); break; case 8: - ChipLogProgress(chipTool, " ***** Test Step 8 : write the default value to LT attribute: StartUpOnOff\n"); - err = TestWriteTheDefaultValueToLtAttributeStartUpOnOff_8(); + ChipLogProgress(chipTool, " ***** Test Step 8 : read the mandatory attribute: KeypadLockout\n"); + err = TestReadTheMandatoryAttributeKeypadLockout_8(); break; case 9: - ChipLogProgress(chipTool, " ***** Test Step 9 : reads back LT attribute: OnTime\n"); - err = TestReadsBackLtAttributeOnTime_9(); + ChipLogProgress(chipTool, " ***** Test Step 9 : read the mandatory attribute: KeypadLockout\n"); + err = TestReadTheMandatoryAttributeKeypadLockout_9(); break; case 10: - ChipLogProgress(chipTool, " ***** Test Step 10 : reads back LT attribute: OffWaitTime\n"); - err = TestReadsBackLtAttributeOffWaitTime_10(); + ChipLogProgress(chipTool, " ***** Test Step 10 : read the optional attribute: ScheduleProgrammingVisibility\n"); + err = TestReadTheOptionalAttributeScheduleProgrammingVisibility_10(); break; case 11: - ChipLogProgress(chipTool, " ***** Test Step 11 : reads back LT attribute: StartUpOnOff\n"); - err = TestReadsBackLtAttributeStartUpOnOff_11(); + ChipLogProgress(chipTool, " ***** Test Step 11 : read the optional attribute: ScheduleProgrammingVisibility\n"); + err = TestReadTheOptionalAttributeScheduleProgrammingVisibility_11(); + break; + case 12: + ChipLogProgress(chipTool, " ***** Test Step 12 : write to the mandatory attribute: ScheduleProgrammingVisibility\n"); + err = TestWriteToTheMandatoryAttributeScheduleProgrammingVisibility_12(); + break; + case 13: + ChipLogProgress(chipTool, " ***** Test Step 13 : read the optional attribute: ScheduleProgrammingVisibility\n"); + err = TestReadTheOptionalAttributeScheduleProgrammingVisibility_13(); + break; + case 14: + ChipLogProgress(chipTool, " ***** Test Step 14 : read the optional attribute: ScheduleProgrammingVisibility\n"); + err = TestReadTheOptionalAttributeScheduleProgrammingVisibility_14(); break; } @@ -7018,366 +8793,467 @@ class Test_TC_OO_2_1 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 12; + const uint16_t mTestCount = 15; chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, + this }; chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, + this }; chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, + this }; chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, + this }; chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, + this }; chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; - chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; - chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; + chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; - chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; + chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; - chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, this }; + chip::Callback::Callback mOnSuccessCallback_10{ + OnSuccessCallback_10, this + }; chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; - chip::Callback::Callback mOnSuccessCallback_11{ OnSuccessCallback_11, this }; + chip::Callback::Callback mOnSuccessCallback_11{ + OnSuccessCallback_11, this + }; + chip::Callback::Callback mOnFailureCallback_12{ OnFailureCallback_12, this }; + chip::Callback::Callback mOnSuccessCallback_12{ + OnSuccessCallback_12, this + }; + chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; + chip::Callback::Callback mOnSuccessCallback_13{ + OnSuccessCallback_13, this + }; + chip::Callback::Callback mOnFailureCallback_14{ OnFailureCallback_14, this }; + chip::Callback::Callback mOnSuccessCallback_14{ + OnSuccessCallback_14, this + }; static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_0(void * context, bool onOff) + static void OnSuccessCallback_0(void * context, uint8_t temperatureDisplayMode) { - (static_cast(context))->OnSuccessResponse_0(onOff); + (static_cast(context))->OnSuccessResponse_0(temperatureDisplayMode); } static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_1(void * context, bool onOff) + static void OnSuccessCallback_1(void * context, uint8_t temperatureDisplayMode) { - (static_cast(context))->OnSuccessResponse_1(onOff); + (static_cast(context))->OnSuccessResponse_1(temperatureDisplayMode); } static void OnFailureCallback_2(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_2(status); } - static void OnSuccessCallback_2(void * context, bool globalSceneControl) + static void OnSuccessCallback_2(void * context, uint8_t temperatureDisplayMode) { - (static_cast(context))->OnSuccessResponse_2(globalSceneControl); + (static_cast(context))->OnSuccessResponse_2(temperatureDisplayMode); } static void OnFailureCallback_3(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_3(status); + (static_cast(context))->OnFailureResponse_3(status); } - static void OnSuccessCallback_3(void * context, uint16_t onTime) + static void OnSuccessCallback_3(void * context, uint8_t temperatureDisplayMode) { - (static_cast(context))->OnSuccessResponse_3(onTime); + (static_cast(context))->OnSuccessResponse_3(temperatureDisplayMode); } static void OnFailureCallback_4(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_4(status); } - static void OnSuccessCallback_4(void * context, uint16_t offWaitTime) + static void OnSuccessCallback_4(void * context, uint8_t temperatureDisplayMode) { - (static_cast(context))->OnSuccessResponse_4(offWaitTime); + (static_cast(context))->OnSuccessResponse_4(temperatureDisplayMode); } static void OnFailureCallback_5(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_5(status); + (static_cast(context))->OnFailureResponse_5(status); } - static void OnSuccessCallback_5(void * context, uint8_t startUpOnOff) + static void OnSuccessCallback_5(void * context, uint8_t keypadLockout) { - (static_cast(context))->OnSuccessResponse_5(startUpOnOff); + (static_cast(context))->OnSuccessResponse_5(keypadLockout); } static void OnFailureCallback_6(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_6(status); + (static_cast(context))->OnFailureResponse_6(status); } - static void OnSuccessCallback_6(void * context, uint16_t onTime) + static void OnSuccessCallback_6(void * context, uint8_t keypadLockout) { - (static_cast(context))->OnSuccessResponse_6(onTime); + (static_cast(context))->OnSuccessResponse_6(keypadLockout); } static void OnFailureCallback_7(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_7(status); + (static_cast(context))->OnFailureResponse_7(status); } - static void OnSuccessCallback_7(void * context, uint16_t offWaitTime) + static void OnSuccessCallback_7(void * context, uint8_t keypadLockout) { - (static_cast(context))->OnSuccessResponse_7(offWaitTime); + (static_cast(context))->OnSuccessResponse_7(keypadLockout); } static void OnFailureCallback_8(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_8(status); + (static_cast(context))->OnFailureResponse_8(status); } - static void OnSuccessCallback_8(void * context, uint8_t startUpOnOff) + static void OnSuccessCallback_8(void * context, uint8_t keypadLockout) { - (static_cast(context))->OnSuccessResponse_8(startUpOnOff); + (static_cast(context))->OnSuccessResponse_8(keypadLockout); } static void OnFailureCallback_9(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_9(status); + (static_cast(context))->OnFailureResponse_9(status); } - static void OnSuccessCallback_9(void * context, uint16_t onTime) + static void OnSuccessCallback_9(void * context, uint8_t keypadLockout) { - (static_cast(context))->OnSuccessResponse_9(onTime); + (static_cast(context))->OnSuccessResponse_9(keypadLockout); } static void OnFailureCallback_10(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_10(status); + (static_cast(context))->OnFailureResponse_10(status); } - static void OnSuccessCallback_10(void * context, uint16_t offWaitTime) + static void OnSuccessCallback_10(void * context, uint8_t scheduleProgrammingVisibility) { - (static_cast(context))->OnSuccessResponse_10(offWaitTime); + (static_cast(context))->OnSuccessResponse_10(scheduleProgrammingVisibility); } static void OnFailureCallback_11(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_11(status); + (static_cast(context))->OnFailureResponse_11(status); } - static void OnSuccessCallback_11(void * context, uint8_t startUpOnOff) + static void OnSuccessCallback_11(void * context, uint8_t scheduleProgrammingVisibility) { - (static_cast(context))->OnSuccessResponse_11(startUpOnOff); + (static_cast(context))->OnSuccessResponse_11(scheduleProgrammingVisibility); + } + + static void OnFailureCallback_12(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_12(status); + } + + static void OnSuccessCallback_12(void * context, uint8_t scheduleProgrammingVisibility) + { + (static_cast(context))->OnSuccessResponse_12(scheduleProgrammingVisibility); + } + + static void OnFailureCallback_13(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_13(status); + } + + static void OnSuccessCallback_13(void * context, uint8_t scheduleProgrammingVisibility) + { + (static_cast(context))->OnSuccessResponse_13(scheduleProgrammingVisibility); + } + + static void OnFailureCallback_14(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_14(status); + } + + static void OnSuccessCallback_14(void * context, uint8_t scheduleProgrammingVisibility) + { + (static_cast(context))->OnSuccessResponse_14(scheduleProgrammingVisibility); } // // Tests methods // - CHIP_ERROR TestReadTheMandatoryAttributeOnOff_0() + CHIP_ERROR TestReadTheMandatoryAttributeTemperatureDisplayMode_0() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + return cluster.ReadAttributeTemperatureDisplayMode(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(bool onOff) + void OnSuccessResponse_0(uint8_t temperatureDisplayMode) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("temperatureDisplayMode", temperatureDisplayMode, 0)); NextTest(); } - CHIP_ERROR TestReadsBackMandatoryAttributeOnOff_1() + CHIP_ERROR TestReadTheMandatoryAttributeTemperatureDisplayMode_1() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeTemperatureDisplayMode(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_1(uint8_t temperatureDisplayMode) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckConstraintType("temperatureDisplayMode", "", "enum8")); NextTest(); } - CHIP_ERROR TestReadLtAttributeGlobalSceneControl_2() + CHIP_ERROR TestWriteToTheMandatoryAttributeTemperatureDisplayMode_2() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeGlobalSceneControl(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + uint8_t temperatureDisplayModeArgument = 0; + + return cluster.WriteAttributeTemperatureDisplayMode(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel(), + temperatureDisplayModeArgument); } void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(bool globalSceneControl) - { - VerifyOrReturn(CheckValue("globalSceneControl", globalSceneControl, 1)); - NextTest(); - } + void OnSuccessResponse_2(uint8_t temperatureDisplayMode) { NextTest(); } - CHIP_ERROR TestReadLtAttributeOnTime_3() + CHIP_ERROR TestReadTheMandatoryAttributeTemperatureDisplayMode_3() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnTime(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + return cluster.ReadAttributeTemperatureDisplayMode(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3(uint16_t onTime) + void OnSuccessResponse_3(uint8_t temperatureDisplayMode) { - VerifyOrReturn(CheckValue("onTime", onTime, 0U)); + VerifyOrReturn(CheckValue("temperatureDisplayMode", temperatureDisplayMode, 0)); NextTest(); } - CHIP_ERROR TestReadLtAttributeOffWaitTime_4() + CHIP_ERROR TestReadTheMandatoryAttributeTemperatureDisplayMode_4() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOffWaitTime(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + return cluster.ReadAttributeTemperatureDisplayMode(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); } void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4(uint16_t offWaitTime) + void OnSuccessResponse_4(uint8_t temperatureDisplayMode) { - VerifyOrReturn(CheckValue("offWaitTime", offWaitTime, 0U)); + VerifyOrReturn(CheckConstraintType("temperatureDisplayMode", "", "enum8")); NextTest(); } - CHIP_ERROR TestReadLtAttributeStartUpOnOff_5() + CHIP_ERROR TestReadTheMandatoryAttributeKeypadLockout_5() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeStartUpOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + return cluster.ReadAttributeKeypadLockout(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); } void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5(uint8_t startUpOnOff) + void OnSuccessResponse_5(uint8_t keypadLockout) { - VerifyOrReturn(CheckValue("startUpOnOff", startUpOnOff, 0)); + VerifyOrReturn(CheckValue("keypadLockout", keypadLockout, 0)); NextTest(); } - CHIP_ERROR TestWriteTheDefaultValueToLtAttributeOnTime_6() + CHIP_ERROR TestReadTheMandatoryAttributeKeypadLockout_6() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - uint16_t onTimeArgument = 0U; - - return cluster.WriteAttributeOnTime(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel(), onTimeArgument); + return cluster.ReadAttributeKeypadLockout(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); } void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_6(uint16_t onTime) { NextTest(); } + void OnSuccessResponse_6(uint8_t keypadLockout) + { + VerifyOrReturn(CheckConstraintType("keypadLockout", "", "enum8")); + NextTest(); + } - CHIP_ERROR TestWriteTheDefaultValueToLtAttributeOffWaitTime_7() + CHIP_ERROR TestWriteToTheMandatoryAttributeKeypadLockout_7() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - uint16_t offWaitTimeArgument = 0U; + uint8_t keypadLockoutArgument = 0; - return cluster.WriteAttributeOffWaitTime(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel(), offWaitTimeArgument); + return cluster.WriteAttributeKeypadLockout(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel(), + keypadLockoutArgument); } void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_7(uint16_t offWaitTime) { NextTest(); } + void OnSuccessResponse_7(uint8_t keypadLockout) { NextTest(); } - CHIP_ERROR TestWriteTheDefaultValueToLtAttributeStartUpOnOff_8() + CHIP_ERROR TestReadTheMandatoryAttributeKeypadLockout_8() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - uint8_t startUpOnOffArgument = 0; - - return cluster.WriteAttributeStartUpOnOff(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel(), - startUpOnOffArgument); + return cluster.ReadAttributeKeypadLockout(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel()); } void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_8(uint8_t startUpOnOff) { NextTest(); } + void OnSuccessResponse_8(uint8_t keypadLockout) + { + VerifyOrReturn(CheckValue("keypadLockout", keypadLockout, 0)); + NextTest(); + } - CHIP_ERROR TestReadsBackLtAttributeOnTime_9() + CHIP_ERROR TestReadTheMandatoryAttributeKeypadLockout_9() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnTime(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel()); + return cluster.ReadAttributeKeypadLockout(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel()); } void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_9(uint16_t onTime) + void OnSuccessResponse_9(uint8_t keypadLockout) { - VerifyOrReturn(CheckValue("onTime", onTime, 0U)); + VerifyOrReturn(CheckConstraintType("keypadLockout", "", "enum8")); NextTest(); } - CHIP_ERROR TestReadsBackLtAttributeOffWaitTime_10() + CHIP_ERROR TestReadTheOptionalAttributeScheduleProgrammingVisibility_10() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOffWaitTime(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); + return cluster.ReadAttributeScheduleProgrammingVisibility(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); } void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_10(uint16_t offWaitTime) + void OnSuccessResponse_10(uint8_t scheduleProgrammingVisibility) { - VerifyOrReturn(CheckValue("offWaitTime", offWaitTime, 0U)); + VerifyOrReturn(CheckValue("scheduleProgrammingVisibility", scheduleProgrammingVisibility, 0)); NextTest(); } - CHIP_ERROR TestReadsBackLtAttributeStartUpOnOff_11() + CHIP_ERROR TestReadTheOptionalAttributeScheduleProgrammingVisibility_11() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeStartUpOnOff(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel()); + return cluster.ReadAttributeScheduleProgrammingVisibility(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel()); } void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_11(uint8_t startUpOnOff) + void OnSuccessResponse_11(uint8_t scheduleProgrammingVisibility) { - VerifyOrReturn(CheckValue("startUpOnOff", startUpOnOff, 0)); + VerifyOrReturn(CheckConstraintType("scheduleProgrammingVisibility", "", "enum8")); NextTest(); } -}; - -class Test_TC_OO_2_2 : public TestCommand -{ -public: - Test_TC_OO_2_2() : TestCommand("Test_TC_OO_2_2"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestWriteToTheMandatoryAttributeScheduleProgrammingVisibility_12() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; + cluster.Associate(mDevice, 1); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_OO_2_2\n"); - } + uint8_t scheduleProgrammingVisibilityArgument = 0; - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_OO_2_2\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + return cluster.WriteAttributeScheduleProgrammingVisibility(mOnSuccessCallback_12.Cancel(), mOnFailureCallback_12.Cancel(), + scheduleProgrammingVisibilityArgument); + } + + void OnFailureResponse_12(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_12(uint8_t scheduleProgrammingVisibility) { NextTest(); } + + CHIP_ERROR TestReadTheOptionalAttributeScheduleProgrammingVisibility_13() + { + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeScheduleProgrammingVisibility(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel()); + } + + void OnFailureResponse_13(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_13(uint8_t scheduleProgrammingVisibility) + { + VerifyOrReturn(CheckValue("scheduleProgrammingVisibility", scheduleProgrammingVisibility, 0)); + NextTest(); + } + + CHIP_ERROR TestReadTheOptionalAttributeScheduleProgrammingVisibility_14() + { + chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeScheduleProgrammingVisibility(mOnSuccessCallback_14.Cancel(), mOnFailureCallback_14.Cancel()); + } + + void OnFailureResponse_14(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_14(uint8_t scheduleProgrammingVisibility) + { + VerifyOrReturn(CheckConstraintType("scheduleProgrammingVisibility", "", "enum8")); + NextTest(); + } +}; + +class Test_TC_DIAGTH_1_1 : public TestCommand +{ +public: + Test_TC_DIAGTH_1_1() : TestCommand("Test_TC_DIAGTH_1_1"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; + + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_DIAGTH_1_1\n"); + } + + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_DIAGTH_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } Wait(); @@ -7388,60 +9264,17 @@ class Test_TC_OO_2_2 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Send Off Command\n"); - err = TestSendOffCommand_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); + err = TestReadTheGlobalAttributeClusterRevision_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_1(); + ChipLogProgress(chipTool, + " ***** Test Step 1 : write the default values to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Send On Command\n"); - err = TestSendOnCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Send Off Command\n"); - err = TestSendOffCommand_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : Send Toggle Command\n"); - err = TestSendToggleCommand_6(); - break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : Check on/off attribute value is true after toggle command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterToggleCommand_7(); - break; - case 8: - ChipLogProgress(chipTool, " ***** Test Step 8 : Send Toggle Command\n"); - err = TestSendToggleCommand_8(); - break; - case 9: - ChipLogProgress(chipTool, " ***** Test Step 9 : Check on/off attribute value is false after toggle command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterToggleCommand_9(); - break; - case 10: - ChipLogProgress(chipTool, " ***** Test Step 10 : Send On Command\n"); - err = TestSendOnCommand_10(); - break; - case 11: - ChipLogProgress(chipTool, " ***** Test Step 11 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_11(); - break; - case 12: - ChipLogProgress(chipTool, " ***** Test Step 12 : Send Off Command\n"); - err = TestSendOffCommand_12(); - break; - case 13: - ChipLogProgress(chipTool, " ***** Test Step 13 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_13(); + ChipLogProgress(chipTool, " ***** Test Step 2 : reads back global attribute: ClusterRevision\n"); + err = TestReadsBackGlobalAttributeClusterRevision_2(); break; } @@ -7454,401 +9287,265 @@ class Test_TC_OO_2_2 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 14; + const uint16_t mTestCount = 3; + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; - chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; - chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; - chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; - chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; - chip::Callback::Callback mOnSuccessCallback_11{ OnSuccessCallback_11, this }; - chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; - chip::Callback::Callback mOnSuccessCallback_13{ OnSuccessCallback_13, this }; - - static void OnFailureCallback_1(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_1(status); - } - - static void OnSuccessCallback_1(void * context, bool onOff) - { - (static_cast(context))->OnSuccessResponse_1(onOff); - } - - static void OnFailureCallback_3(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_3(status); - } + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - static void OnSuccessCallback_3(void * context, bool onOff) + static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_3(onOff); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnFailureCallback_5(void * context, uint8_t status) + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - (static_cast(context))->OnFailureResponse_5(status); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } - static void OnSuccessCallback_5(void * context, bool onOff) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_5(onOff); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnFailureCallback_7(void * context, uint8_t status) + static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) { - (static_cast(context))->OnFailureResponse_7(status); + (static_cast(context))->OnSuccessResponse_1(clusterRevision); } - static void OnSuccessCallback_7(void * context, bool onOff) + static void OnFailureCallback_2(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_7(onOff); + (static_cast(context))->OnFailureResponse_2(status); } - static void OnFailureCallback_9(void * context, uint8_t status) + static void OnSuccessCallback_2(void * context, uint16_t clusterRevision) { - (static_cast(context))->OnFailureResponse_9(status); + (static_cast(context))->OnSuccessResponse_2(clusterRevision); } - static void OnSuccessCallback_9(void * context, bool onOff) - { - (static_cast(context))->OnSuccessResponse_9(onOff); - } + // + // Tests methods + // - static void OnFailureCallback_11(void * context, uint8_t status) + CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() { - (static_cast(context))->OnFailureResponse_11(status); - } + chip::Controller::ThreadNetworkDiagnosticsClusterTest cluster; + cluster.Associate(mDevice, 0); - static void OnSuccessCallback_11(void * context, bool onOff) - { - (static_cast(context))->OnSuccessResponse_11(onOff); + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - static void OnFailureCallback_13(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_13(status); - } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_13(void * context, bool onOff) + void OnSuccessResponse_0(uint16_t clusterRevision) { - (static_cast(context))->OnSuccessResponse_13(onOff); + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 1U)); + NextTest(); } - // - // Tests methods - // - - CHIP_ERROR TestSendOffCommand_0() + CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1() { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Off::Type request; + chip::Controller::ThreadNetworkDiagnosticsClusterTest cluster; + cluster.Associate(mDevice, 0); - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + uint16_t clusterRevisionArgument = 1U; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), + clusterRevisionArgument); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { NextTest(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_1() + CHIP_ERROR TestReadsBackGlobalAttributeClusterRevision_2() { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::ThreadNetworkDiagnosticsClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_2(uint16_t clusterRevision) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 1U)); NextTest(); } +}; - CHIP_ERROR TestSendOnCommand_2() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::On::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); - } - - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_2() { NextTest(); } - - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_3() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOnOff(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); - } - - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } +class Test_TC_WNCV_1_1 : public TestCommand +{ +public: + Test_TC_WNCV_1_1() : TestCommand("Test_TC_WNCV_1_1"), mTestIndex(0) {} - void OnSuccessResponse_3(bool onOff) + /////////// TestCommand Interface ///////// + void NextTest() override { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); - NextTest(); - } + CHIP_ERROR err = CHIP_NO_ERROR; - CHIP_ERROR TestSendOffCommand_4() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_WNCV_1_1\n"); + } - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_WNCV_1_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - chip::app::Clusters::OnOff::Commands::Off::Type request; + Wait(); - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); - }; + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); + err = TestReadTheGlobalAttributeClusterRevision_0(); + break; + case 1: + ChipLogProgress(chipTool, + " ***** Test Step 1 : write the default value to mandatory global attribute: ClusterRevision\n"); + err = TestWriteTheDefaultValueToMandatoryGlobalAttributeClusterRevision_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : reads back global attribute: ClusterRevision\n"); + err = TestReadsBackGlobalAttributeClusterRevision_2(); + break; + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 3; - void OnSuccessResponse_4() { NextTest(); } + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() + static void OnFailureCallback_0(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + (static_cast(context))->OnFailureResponse_0(status); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_5(bool onOff) + static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); - NextTest(); + (static_cast(context))->OnSuccessResponse_0(clusterRevision); } - CHIP_ERROR TestSendToggleCommand_6() + static void OnFailureCallback_1(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::OnOff::Commands::Toggle::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Toggle::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_6(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_6(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + (static_cast(context))->OnFailureResponse_1(status); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_6() { NextTest(); } - - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterToggleCommand_7() + static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOnOff(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + (static_cast(context))->OnSuccessResponse_1(clusterRevision); } - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_7(bool onOff) + static void OnFailureCallback_2(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); - NextTest(); + (static_cast(context))->OnFailureResponse_2(status); } - CHIP_ERROR TestSendToggleCommand_8() + static void OnSuccessCallback_2(void * context, uint16_t clusterRevision) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::OnOff::Commands::Toggle::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Toggle::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_8(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_8(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + (static_cast(context))->OnSuccessResponse_2(clusterRevision); } - void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_8() { NextTest(); } + // + // Tests methods + // - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterToggleCommand_9() + CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::WindowCoveringClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel()); + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_9(bool onOff) + void OnSuccessResponse_0(uint16_t clusterRevision) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 5U)); NextTest(); } - CHIP_ERROR TestSendOnCommand_10() + CHIP_ERROR TestWriteTheDefaultValueToMandatoryGlobalAttributeClusterRevision_1() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::WindowCoveringClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::On::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_10(); - }; + uint16_t clusterRevisionArgument = 5U; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_10(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), + clusterRevisionArgument); } - void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { NextTest(); } - void OnSuccessResponse_10() { NextTest(); } + void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_11() + CHIP_ERROR TestReadsBackGlobalAttributeClusterRevision_2() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::WindowCoveringClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel()); + return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } - void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_11(bool onOff) + void OnSuccessResponse_2(uint16_t clusterRevision) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 5U)); NextTest(); } +}; - CHIP_ERROR TestSendOffCommand_12() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); +class Test_TC_WNCV_2_1 : public TestCommand +{ +public: + Test_TC_WNCV_2_1() : TestCommand("Test_TC_WNCV_2_1"), mTestIndex(0) {} - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; - chip::app::Clusters::OnOff::Commands::Off::Type request; + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_WNCV_2_1\n"); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_12(); - }; + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_WNCV_2_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_12(status); - }; - return cluster.InvokeCommand(request, this, success, failure); - } - - void OnFailureResponse_12(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_12() { NextTest(); } - - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_13() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOnOff(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel()); - } - - void OnFailureResponse_13(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_13(bool onOff) - { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); - NextTest(); - } -}; - -class Test_TC_DM_1_1 : public TestCommand -{ -public: - Test_TC_DM_1_1() : TestCommand("Test_TC_DM_1_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_DM_1_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_DM_1_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); + Wait(); // Ensure we increment mTestIndex before we start running the relevant // command. That way if we lose the timeslice after we send the message @@ -7857,76 +9554,48 @@ class Test_TC_DM_1_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Query Interaction Model Version\n"); - err = TestQueryInteractionModelVersion_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : read the RO mandatory attribute default: Type\n"); + err = TestReadTheRoMandatoryAttributeDefaultType_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Query Vendor Name\n"); - err = TestQueryVendorName_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : reads back the RO mandatory attribute: Type\n"); + err = TestReadsBackTheRoMandatoryAttributeType_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Query VendorID\n"); - err = TestQueryVendorID_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : read the RO mandatory attribute default: ConfigStatus\n"); + err = TestReadTheRoMandatoryAttributeDefaultConfigStatus_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Query Product Name\n"); - err = TestQueryProductName_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : reads back the RO mandatory attribute: ConfigStatus\n"); + err = TestReadsBackTheRoMandatoryAttributeConfigStatus_3(); break; case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Query ProductID\n"); - err = TestQueryProductID_4(); + ChipLogProgress(chipTool, " ***** Test Step 4 : read the RO mandatory attribute default: OperationalStatus\n"); + err = TestReadTheRoMandatoryAttributeDefaultOperationalStatus_4(); break; case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Query User Label\n"); - err = TestQueryUserLabel_5(); + ChipLogProgress(chipTool, " ***** Test Step 5 : reads back the RO mandatory attribute: OperationalStatus\n"); + err = TestReadsBackTheRoMandatoryAttributeOperationalStatus_5(); break; case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : Query User Location\n"); - err = TestQueryUserLocation_6(); + ChipLogProgress(chipTool, " ***** Test Step 6 : read the RO mandatory attribute default: EndProductType\n"); + err = TestReadTheRoMandatoryAttributeDefaultEndProductType_6(); break; case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : Query HardwareVersion\n"); - err = TestQueryHardwareVersion_7(); + ChipLogProgress(chipTool, " ***** Test Step 7 : reads back the RO mandatory attribute: EndProductType\n"); + err = TestReadsBackTheRoMandatoryAttributeEndProductType_7(); break; case 8: - ChipLogProgress(chipTool, " ***** Test Step 8 : Query HardwareVersionString\n"); - err = TestQueryHardwareVersionString_8(); + ChipLogProgress(chipTool, " ***** Test Step 8 : read the RW mandatory attribute default: Mode\n"); + err = TestReadTheRwMandatoryAttributeDefaultMode_8(); break; case 9: - ChipLogProgress(chipTool, " ***** Test Step 9 : Query SoftwareVersion\n"); - err = TestQuerySoftwareVersion_9(); + ChipLogProgress(chipTool, " ***** Test Step 9 : write a value into the RW mandatory attribute:: Mode\n"); + err = TestWriteAValueIntoTheRwMandatoryAttributeMode_9(); break; case 10: - ChipLogProgress(chipTool, " ***** Test Step 10 : Query SoftwareVersionString\n"); - err = TestQuerySoftwareVersionString_10(); - break; - case 11: - ChipLogProgress(chipTool, " ***** Test Step 11 : Query ManufacturingDate\n"); - err = TestQueryManufacturingDate_11(); - break; - case 12: - ChipLogProgress(chipTool, " ***** Test Step 12 : Query PartNumber\n"); - err = TestQueryPartNumber_12(); - break; - case 13: - ChipLogProgress(chipTool, " ***** Test Step 13 : Query ProductURL\n"); - err = TestQueryProductURL_13(); - break; - case 14: - ChipLogProgress(chipTool, " ***** Test Step 14 : Query ProductLabel\n"); - err = TestQueryProductLabel_14(); - break; - case 15: - ChipLogProgress(chipTool, " ***** Test Step 15 : Query SerialNumber\n"); - err = TestQuerySerialNumber_15(); - break; - case 16: - ChipLogProgress(chipTool, " ***** Test Step 16 : Query LocalConfigDisabled\n"); - err = TestQueryLocalConfigDisabled_16(); - break; - case 17: - ChipLogProgress(chipTool, " ***** Test Step 17 : Query Reachable\n"); - err = TestQueryReachable_17(); + ChipLogProgress(chipTool, " ***** Test Step 10 : reads back the RW mandatory attribute: Mode\n"); + err = TestReadsBackTheRwMandatoryAttributeMode_10(); break; } @@ -7939,574 +9608,461 @@ class Test_TC_DM_1_1 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 18; + const uint16_t mTestCount = 11; chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, - this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, - this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; - chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; - chip::Callback::Callback mOnSuccessCallback_8{ - OnSuccessCallback_8, this - }; + chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; - chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; + chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; - chip::Callback::Callback mOnSuccessCallback_10{ - OnSuccessCallback_10, this - }; - chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; - chip::Callback::Callback mOnSuccessCallback_11{ - OnSuccessCallback_11, this - }; - chip::Callback::Callback mOnFailureCallback_12{ OnFailureCallback_12, this }; - chip::Callback::Callback mOnSuccessCallback_12{ OnSuccessCallback_12, - this }; - chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; - chip::Callback::Callback mOnSuccessCallback_13{ OnSuccessCallback_13, - this }; - chip::Callback::Callback mOnFailureCallback_14{ OnFailureCallback_14, this }; - chip::Callback::Callback mOnSuccessCallback_14{ OnSuccessCallback_14, - this }; - chip::Callback::Callback mOnFailureCallback_15{ OnFailureCallback_15, this }; - chip::Callback::Callback mOnSuccessCallback_15{ OnSuccessCallback_15, - this }; - chip::Callback::Callback mOnFailureCallback_16{ OnFailureCallback_16, this }; - chip::Callback::Callback mOnSuccessCallback_16{ OnSuccessCallback_16, - this }; - chip::Callback::Callback mOnFailureCallback_17{ OnFailureCallback_17, this }; - chip::Callback::Callback mOnSuccessCallback_17{ OnSuccessCallback_17, this }; + chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, this }; static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_0(void * context, uint16_t interactionModelVersion) + static void OnSuccessCallback_0(void * context, uint8_t type) { - (static_cast(context))->OnSuccessResponse_0(interactionModelVersion); + (static_cast(context))->OnSuccessResponse_0(type); } static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_1(void * context, chip::ByteSpan vendorName) + static void OnSuccessCallback_1(void * context, uint8_t type) { - (static_cast(context))->OnSuccessResponse_1(vendorName); + (static_cast(context))->OnSuccessResponse_1(type); } static void OnFailureCallback_2(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_2(status); } - static void OnSuccessCallback_2(void * context, uint16_t vendorID) + static void OnSuccessCallback_2(void * context, uint8_t configStatus) { - (static_cast(context))->OnSuccessResponse_2(vendorID); + (static_cast(context))->OnSuccessResponse_2(configStatus); } static void OnFailureCallback_3(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_3(status); + (static_cast(context))->OnFailureResponse_3(status); } - static void OnSuccessCallback_3(void * context, chip::ByteSpan productName) + static void OnSuccessCallback_3(void * context, uint8_t configStatus) { - (static_cast(context))->OnSuccessResponse_3(productName); + (static_cast(context))->OnSuccessResponse_3(configStatus); } static void OnFailureCallback_4(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_4(status); } - static void OnSuccessCallback_4(void * context, uint16_t productID) + static void OnSuccessCallback_4(void * context, uint8_t operationalStatus) { - (static_cast(context))->OnSuccessResponse_4(productID); + (static_cast(context))->OnSuccessResponse_4(operationalStatus); } static void OnFailureCallback_5(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_5(status); + (static_cast(context))->OnFailureResponse_5(status); } - static void OnSuccessCallback_5(void * context, chip::ByteSpan userLabel) + static void OnSuccessCallback_5(void * context, uint8_t operationalStatus) { - (static_cast(context))->OnSuccessResponse_5(userLabel); + (static_cast(context))->OnSuccessResponse_5(operationalStatus); } static void OnFailureCallback_6(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_6(status); + (static_cast(context))->OnFailureResponse_6(status); } - static void OnSuccessCallback_6(void * context, chip::ByteSpan location) + static void OnSuccessCallback_6(void * context, uint8_t endProductType) { - (static_cast(context))->OnSuccessResponse_6(location); + (static_cast(context))->OnSuccessResponse_6(endProductType); } static void OnFailureCallback_7(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_7(status); + (static_cast(context))->OnFailureResponse_7(status); } - static void OnSuccessCallback_7(void * context, uint16_t hardwareVersion) + static void OnSuccessCallback_7(void * context, uint8_t endProductType) { - (static_cast(context))->OnSuccessResponse_7(hardwareVersion); + (static_cast(context))->OnSuccessResponse_7(endProductType); } static void OnFailureCallback_8(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_8(status); + (static_cast(context))->OnFailureResponse_8(status); } - static void OnSuccessCallback_8(void * context, chip::ByteSpan hardwareVersionString) + static void OnSuccessCallback_8(void * context, uint8_t mode) { - (static_cast(context))->OnSuccessResponse_8(hardwareVersionString); + (static_cast(context))->OnSuccessResponse_8(mode); } static void OnFailureCallback_9(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_9(status); + (static_cast(context))->OnFailureResponse_9(status); } - static void OnSuccessCallback_9(void * context, uint32_t softwareVersion) + static void OnSuccessCallback_9(void * context, uint8_t mode) { - (static_cast(context))->OnSuccessResponse_9(softwareVersion); + (static_cast(context))->OnSuccessResponse_9(mode); } static void OnFailureCallback_10(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_10(status); + (static_cast(context))->OnFailureResponse_10(status); } - static void OnSuccessCallback_10(void * context, chip::ByteSpan softwareVersionString) + static void OnSuccessCallback_10(void * context, uint8_t mode) { - (static_cast(context))->OnSuccessResponse_10(softwareVersionString); + (static_cast(context))->OnSuccessResponse_10(mode); } - static void OnFailureCallback_11(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_11(status); - } + // + // Tests methods + // - static void OnSuccessCallback_11(void * context, chip::ByteSpan manufacturingDate) + CHIP_ERROR TestReadTheRoMandatoryAttributeDefaultType_0() { - (static_cast(context))->OnSuccessResponse_11(manufacturingDate); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeType(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - static void OnFailureCallback_12(void * context, uint8_t status) + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_0(uint8_t type) { - (static_cast(context))->OnFailureResponse_12(status); + VerifyOrReturn(CheckValue("type", type, 0)); + NextTest(); } - static void OnSuccessCallback_12(void * context, chip::ByteSpan partNumber) - { - (static_cast(context))->OnSuccessResponse_12(partNumber); - } - - static void OnFailureCallback_13(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_13(status); - } - - static void OnSuccessCallback_13(void * context, chip::ByteSpan productURL) - { - (static_cast(context))->OnSuccessResponse_13(productURL); - } - - static void OnFailureCallback_14(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_14(status); - } - - static void OnSuccessCallback_14(void * context, chip::ByteSpan productLabel) - { - (static_cast(context))->OnSuccessResponse_14(productLabel); - } - - static void OnFailureCallback_15(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_15(status); - } - - static void OnSuccessCallback_15(void * context, chip::ByteSpan serialNumber) - { - (static_cast(context))->OnSuccessResponse_15(serialNumber); - } - - static void OnFailureCallback_16(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_16(status); - } - - static void OnSuccessCallback_16(void * context, bool localConfigDisabled) - { - (static_cast(context))->OnSuccessResponse_16(localConfigDisabled); - } - - static void OnFailureCallback_17(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_17(status); - } - - static void OnSuccessCallback_17(void * context, bool reachable) - { - (static_cast(context))->OnSuccessResponse_17(reachable); - } - - // - // Tests methods - // - - CHIP_ERROR TestQueryInteractionModelVersion_0() - { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); - - return cluster.ReadAttributeInteractionModelVersion(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); - } - - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0(uint16_t interactionModelVersion) - { - VerifyOrReturn(CheckConstraintType("interactionModelVersion", "", "uint16")); - NextTest(); - } - - CHIP_ERROR TestQueryVendorName_1() + CHIP_ERROR TestReadsBackTheRoMandatoryAttributeType_1() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeVendorName(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeType(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(chip::ByteSpan vendorName) + void OnSuccessResponse_1(uint8_t type) { - VerifyOrReturn(CheckConstraintType("vendorName", "", "string")); - VerifyOrReturn(CheckConstraintMaxLength("vendorName", vendorName.size(), 32)); + VerifyOrReturn(CheckValue("type", type, 0)); NextTest(); } - CHIP_ERROR TestQueryVendorID_2() + CHIP_ERROR TestReadTheRoMandatoryAttributeDefaultConfigStatus_2() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeVendorID(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + return cluster.ReadAttributeConfigStatus(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint16_t vendorID) + void OnSuccessResponse_2(uint8_t configStatus) { - VerifyOrReturn(CheckConstraintType("vendorID", "", "uint16")); + VerifyOrReturn(CheckValue("configStatus", configStatus, 3)); NextTest(); } - CHIP_ERROR TestQueryProductName_3() + CHIP_ERROR TestReadsBackTheRoMandatoryAttributeConfigStatus_3() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeProductName(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + return cluster.ReadAttributeConfigStatus(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3(chip::ByteSpan productName) + void OnSuccessResponse_3(uint8_t configStatus) { - VerifyOrReturn(CheckConstraintType("productName", "", "string")); - VerifyOrReturn(CheckConstraintMaxLength("productName", productName.size(), 32)); + VerifyOrReturn(CheckValue("configStatus", configStatus, 3)); NextTest(); } - CHIP_ERROR TestQueryProductID_4() + CHIP_ERROR TestReadTheRoMandatoryAttributeDefaultOperationalStatus_4() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeProductID(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + return cluster.ReadAttributeOperationalStatus(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); } void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4(uint16_t productID) + void OnSuccessResponse_4(uint8_t operationalStatus) { - VerifyOrReturn(CheckConstraintType("productID", "", "uint16")); + VerifyOrReturn(CheckValue("operationalStatus", operationalStatus, 0)); NextTest(); } - CHIP_ERROR TestQueryUserLabel_5() + CHIP_ERROR TestReadsBackTheRoMandatoryAttributeOperationalStatus_5() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeUserLabel(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + return cluster.ReadAttributeOperationalStatus(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); } void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5(chip::ByteSpan userLabel) + void OnSuccessResponse_5(uint8_t operationalStatus) { - VerifyOrReturn(CheckConstraintType("userLabel", "", "string")); - VerifyOrReturn(CheckConstraintMaxLength("userLabel", userLabel.size(), 32)); + VerifyOrReturn(CheckValue("operationalStatus", operationalStatus, 0)); NextTest(); } - CHIP_ERROR TestQueryUserLocation_6() + CHIP_ERROR TestReadTheRoMandatoryAttributeDefaultEndProductType_6() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeLocation(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); + return cluster.ReadAttributeEndProductType(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); } void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_6(chip::ByteSpan location) + void OnSuccessResponse_6(uint8_t endProductType) { - VerifyOrReturn(CheckConstraintType("location", "", "string")); - VerifyOrReturn(CheckConstraintFormat("location", "", "ISO 3166-1 alpha-2")); - VerifyOrReturn(CheckConstraintMaxLength("location", location.size(), 2)); + VerifyOrReturn(CheckValue("endProductType", endProductType, 0)); NextTest(); } - CHIP_ERROR TestQueryHardwareVersion_7() + CHIP_ERROR TestReadsBackTheRoMandatoryAttributeEndProductType_7() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeHardwareVersion(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + return cluster.ReadAttributeEndProductType(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); } void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_7(uint16_t hardwareVersion) + void OnSuccessResponse_7(uint8_t endProductType) { - VerifyOrReturn(CheckConstraintType("hardwareVersion", "", "uint16")); + VerifyOrReturn(CheckValue("endProductType", endProductType, 0)); NextTest(); } - CHIP_ERROR TestQueryHardwareVersionString_8() + CHIP_ERROR TestReadTheRwMandatoryAttributeDefaultMode_8() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeHardwareVersionString(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel()); + return cluster.ReadAttributeMode(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel()); } void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_8(chip::ByteSpan hardwareVersionString) + void OnSuccessResponse_8(uint8_t mode) { - VerifyOrReturn(CheckConstraintType("hardwareVersionString", "", "string")); - VerifyOrReturn(CheckConstraintMinLength("hardwareVersionString", hardwareVersionString.size(), 1)); - VerifyOrReturn(CheckConstraintMaxLength("hardwareVersionString", hardwareVersionString.size(), 64)); + VerifyOrReturn(CheckValue("mode", mode, 0)); NextTest(); } - CHIP_ERROR TestQuerySoftwareVersion_9() + CHIP_ERROR TestWriteAValueIntoTheRwMandatoryAttributeMode_9() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeSoftwareVersion(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel()); + uint8_t modeArgument = 7; + + return cluster.WriteAttributeMode(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel(), modeArgument); } void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_9(uint32_t softwareVersion) - { - VerifyOrReturn(CheckConstraintType("softwareVersion", "", "uint32")); - NextTest(); - } + void OnSuccessResponse_9(uint8_t mode) { NextTest(); } - CHIP_ERROR TestQuerySoftwareVersionString_10() + CHIP_ERROR TestReadsBackTheRwMandatoryAttributeMode_10() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeSoftwareVersionString(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); + return cluster.ReadAttributeMode(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); } void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_10(chip::ByteSpan softwareVersionString) + void OnSuccessResponse_10(uint8_t mode) { - VerifyOrReturn(CheckConstraintType("softwareVersionString", "", "string")); - VerifyOrReturn(CheckConstraintFormat("softwareVersionString", "", "ASCII")); - VerifyOrReturn(CheckConstraintMinLength("softwareVersionString", softwareVersionString.size(), 1)); - VerifyOrReturn(CheckConstraintMaxLength("softwareVersionString", softwareVersionString.size(), 64)); + VerifyOrReturn(CheckValue("mode", mode, 7)); NextTest(); } +}; - CHIP_ERROR TestQueryManufacturingDate_11() - { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); - - return cluster.ReadAttributeManufacturingDate(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel()); - } - - void OnFailureResponse_11(uint8_t status) - { - (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); - } +class Test_TC_WNCV_3_1 : public TestCommand +{ +public: + Test_TC_WNCV_3_1() : TestCommand("Test_TC_WNCV_3_1"), mTestIndex(0) {} - void OnSuccessResponse_11(chip::ByteSpan manufacturingDate) + /////////// TestCommand Interface ///////// + void NextTest() override { - VerifyOrReturn(CheckConstraintType("manufacturingDate", "", "string")); - VerifyOrReturn(CheckConstraintFormat("manufacturingDate", "", "ISO 8601")); - VerifyOrReturn(CheckConstraintMinLength("manufacturingDate", manufacturingDate.size(), 8)); - VerifyOrReturn(CheckConstraintMaxLength("manufacturingDate", manufacturingDate.size(), 16)); - NextTest(); - } + CHIP_ERROR err = CHIP_NO_ERROR; - CHIP_ERROR TestQueryPartNumber_12() - { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: Test_TC_WNCV_3_1\n"); + } - return cluster.ReadAttributePartNumber(mOnSuccessCallback_12.Cancel(), mOnFailureCallback_12.Cancel()); - } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_WNCV_3_1\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - void OnFailureResponse_12(uint8_t status) - { - (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); - } + Wait(); - void OnSuccessResponse_12(chip::ByteSpan partNumber) - { - VerifyOrReturn(CheckConstraintType("partNumber", "", "string")); - VerifyOrReturn(CheckConstraintMaxLength("partNumber", partNumber.size(), 32)); - NextTest(); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : 1a: TH adjusts the the DUT to a non-open position\n"); + err = Test1aThAdjustsTheTheDutToANonOpenPosition_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : 2a: TH sends UpOrOpen command to DUT\n"); + err = Test2aThSendsUpOrOpenCommandToDut_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : 3a: TH reads OperationalStatus attribute from DUT\n"); + err = Test3aThReadsOperationalStatusAttributeFromDut_2(); + break; + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - CHIP_ERROR TestQueryProductURL_13() - { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 3; - return cluster.ReadAttributeProductURL(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel()); - } + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - void OnFailureResponse_13(uint8_t status) + static void OnFailureCallback_2(void * context, uint8_t status) { - (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); + (static_cast(context))->OnFailureResponse_2(status); } - void OnSuccessResponse_13(chip::ByteSpan productURL) + static void OnSuccessCallback_2(void * context, uint8_t operationalStatus) { - VerifyOrReturn(CheckConstraintType("productURL", "", "string")); - VerifyOrReturn(CheckConstraintFormat("productURL", "", "RFC3986")); - VerifyOrReturn(CheckConstraintMaxLength("productURL", productURL.size(), 256)); - NextTest(); + (static_cast(context))->OnSuccessResponse_2(operationalStatus); } - CHIP_ERROR TestQueryProductLabel_14() + // + // Tests methods + // + + CHIP_ERROR Test1aThAdjustsTheTheDutToANonOpenPosition_0() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeProductLabel(mOnSuccessCallback_14.Cancel(), mOnFailureCallback_14.Cancel()); - } + using requestType = chip::app::Clusters::WindowCovering::Commands::DownOrClose::Type; + using responseType = chip::app::DataModel::NullObjectType; - void OnFailureResponse_14(uint8_t status) - { - (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); - } + chip::app::Clusters::WindowCovering::Commands::DownOrClose::Type request; - void OnSuccessResponse_14(chip::ByteSpan productLabel) - { - VerifyOrReturn(CheckConstraintType("productLabel", "", "string")); - VerifyOrReturn(CheckConstraintMaxLength("productLabel", productLabel.size(), 64)); - NextTest(); + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - CHIP_ERROR TestQuerySerialNumber_15() - { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - return cluster.ReadAttributeSerialNumber(mOnSuccessCallback_15.Cancel(), mOnFailureCallback_15.Cancel()); - } + void OnSuccessResponse_0() { NextTest(); } - void OnFailureResponse_15(uint8_t status) + CHIP_ERROR Test2aThSendsUpOrOpenCommandToDut_1() { - (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); - } + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - void OnSuccessResponse_15(chip::ByteSpan serialNumber) - { - VerifyOrReturn(CheckConstraintType("serialNumber", "", "string")); - VerifyOrReturn(CheckConstraintMaxLength("serialNumber", serialNumber.size(), 32)); - NextTest(); - } + using requestType = chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type; + using responseType = chip::app::DataModel::NullObjectType; - CHIP_ERROR TestQueryLocalConfigDisabled_16() - { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type request; - return cluster.ReadAttributeLocalConfigDisabled(mOnSuccessCallback_16.Cancel(), mOnFailureCallback_16.Cancel()); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_1(); + }; - void OnFailureResponse_16(uint8_t status) - { - (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_1(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnSuccessResponse_16(bool localConfigDisabled) - { - VerifyOrReturn(CheckConstraintType("localConfigDisabled", "", "boolean")); - NextTest(); - } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestQueryReachable_17() + void OnSuccessResponse_1() { NextTest(); } + + CHIP_ERROR Test3aThReadsOperationalStatusAttributeFromDut_2() { - chip::Controller::BasicClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeReachable(mOnSuccessCallback_17.Cancel(), mOnFailureCallback_17.Cancel()); + return cluster.ReadAttributeOperationalStatus(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } - void OnFailureResponse_17(uint8_t status) - { - (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); - } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_17(bool reachable) + void OnSuccessResponse_2(uint8_t operationalStatus) { - VerifyOrReturn(CheckConstraintType("reachable", "", "boolean")); + VerifyOrReturn(CheckValue("operationalStatus", operationalStatus, 0)); NextTest(); } }; -class Test_TC_DM_3_1 : public TestCommand +class Test_TC_WNCV_3_2 : public TestCommand { public: - Test_TC_DM_3_1() : TestCommand("Test_TC_DM_3_1"), mTestIndex(0) {} + Test_TC_WNCV_3_2() : TestCommand("Test_TC_WNCV_3_2"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -8515,12 +10071,12 @@ class Test_TC_DM_3_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_DM_3_1\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_WNCV_3_2\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_DM_3_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_WNCV_3_2\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -8533,6 +10089,18 @@ class Test_TC_DM_3_1 : public TestCommand // incorrect mTestIndex value observed when we get the response. switch (mTestIndex++) { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : 1a: TH adjusts the the DUT to a non-closed position\n"); + err = Test1aThAdjustsTheTheDutToANonClosedPosition_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : 2a: TH sends DownOrClose command to DUT\n"); + err = Test2aThSendsDownOrCloseCommandToDut_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : 3a: TH reads OperationalStatus attribute from DUT\n"); + err = Test3aThReadsOperationalStatusAttributeFromDut_2(); + break; } if (CHIP_NO_ERROR != err) @@ -8544,17 +10112,94 @@ class Test_TC_DM_3_1 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 0; + const uint16_t mTestCount = 3; + + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + + static void OnFailureCallback_2(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_2(status); + } + + static void OnSuccessCallback_2(void * context, uint8_t operationalStatus) + { + (static_cast(context))->OnSuccessResponse_2(operationalStatus); + } // // Tests methods // + + CHIP_ERROR Test1aThAdjustsTheTheDutToANonClosedPosition_0() + { + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR Test2aThSendsDownOrCloseCommandToDut_1() + { + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::WindowCovering::Commands::DownOrClose::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::WindowCovering::Commands::DownOrClose::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_1(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_1(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1() { NextTest(); } + + CHIP_ERROR Test3aThReadsOperationalStatusAttributeFromDut_2() + { + chip::Controller::WindowCoveringClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOperationalStatus(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + } + + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_2(uint8_t operationalStatus) + { + VerifyOrReturn(CheckValue("operationalStatus", operationalStatus, 0)); + NextTest(); + } }; -class Test_TC_WNCV_1_1 : public TestCommand +class Test_TC_WNCV_3_3 : public TestCommand { public: - Test_TC_WNCV_1_1() : TestCommand("Test_TC_WNCV_1_1"), mTestIndex(0) {} + Test_TC_WNCV_3_3() : TestCommand("Test_TC_WNCV_3_3"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -8563,12 +10208,12 @@ class Test_TC_WNCV_1_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_WNCV_1_1\n"); + ChipLogProgress(chipTool, " **** Test Start: Test_TC_WNCV_3_3\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_WNCV_1_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: Test_TC_WNCV_3_3\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -8582,17 +10227,16 @@ class Test_TC_WNCV_1_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); - err = TestReadTheGlobalAttributeClusterRevision_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : 1a: TH adjusts the the DUT to a non-open position\n"); + err = Test1aThAdjustsTheTheDutToANonOpenPosition_0(); break; case 1: - ChipLogProgress(chipTool, - " ***** Test Step 1 : write the default value to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValueToMandatoryGlobalAttributeClusterRevision_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : 2a: TH sends StopMotion command to DUT\n"); + err = Test2aThSendsStopMotionCommandToDut_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : reads back global attribute: ClusterRevision\n"); - err = TestReadsBackGlobalAttributeClusterRevision_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : 2b: TH reads OperationalStatus attribute from DUT\n"); + err = Test2bThReadsOperationalStatusAttributeFromDut_2(); break; } @@ -8607,99 +10251,92 @@ class Test_TC_WNCV_1_1 : public TestCommand std::atomic_uint16_t mTestIndex; const uint16_t mTestCount = 3; - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } - - static void OnFailureCallback_1(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_1(status); - } - - static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_1(clusterRevision); - } + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; static void OnFailureCallback_2(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_2(status); } - static void OnSuccessCallback_2(void * context, uint16_t clusterRevision) + static void OnSuccessCallback_2(void * context, uint8_t operationalStatus) { - (static_cast(context))->OnSuccessResponse_2(clusterRevision); + (static_cast(context))->OnSuccessResponse_2(operationalStatus); } // // Tests methods // - CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() + CHIP_ERROR Test1aThAdjustsTheTheDutToANonOpenPosition_0() { chip::Controller::WindowCoveringClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + using requestType = chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint16_t clusterRevision) - { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 5U)); - NextTest(); - } + void OnSuccessResponse_0() { NextTest(); } - CHIP_ERROR TestWriteTheDefaultValueToMandatoryGlobalAttributeClusterRevision_1() + CHIP_ERROR Test2aThSendsStopMotionCommandToDut_1() { chip::Controller::WindowCoveringClusterTest cluster; cluster.Associate(mDevice, 1); - uint16_t clusterRevisionArgument = 5U; + using requestType = chip::app::Clusters::WindowCovering::Commands::StopMotion::Type; + using responseType = chip::app::DataModel::NullObjectType; - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), - clusterRevisionArgument); + chip::app::Clusters::WindowCovering::Commands::StopMotion::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_1(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_1(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_1(uint8_t status) { NextTest(); } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } + void OnSuccessResponse_1() { NextTest(); } - CHIP_ERROR TestReadsBackGlobalAttributeClusterRevision_2() + CHIP_ERROR Test2bThReadsOperationalStatusAttributeFromDut_2() { chip::Controller::WindowCoveringClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + return cluster.ReadAttributeOperationalStatus(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint16_t clusterRevision) + void OnSuccessResponse_2(uint8_t operationalStatus) { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 5U)); + VerifyOrReturn(CheckValue("operationalStatus", operationalStatus, 0)); NextTest(); } }; -class Test_TC_WNCV_2_1 : public TestCommand +class TV_TargetNavigatorCluster : public TestCommand { public: - Test_TC_WNCV_2_1() : TestCommand("Test_TC_WNCV_2_1"), mTestIndex(0) {} + TV_TargetNavigatorCluster() : TestCommand("TV_TargetNavigatorCluster"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -8708,12 +10345,12 @@ class Test_TC_WNCV_2_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_WNCV_2_1\n"); + ChipLogProgress(chipTool, " **** Test Start: TV_TargetNavigatorCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_WNCV_2_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: TV_TargetNavigatorCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -8727,48 +10364,12 @@ class Test_TC_WNCV_2_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the RO mandatory attribute default: Type\n"); - err = TestReadTheRoMandatoryAttributeDefaultType_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute Target Navigator list\n"); + err = TestReadAttributeTargetNavigatorList_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : reads back the RO mandatory attribute: Type\n"); - err = TestReadsBackTheRoMandatoryAttributeType_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : read the RO mandatory attribute default: ConfigStatus\n"); - err = TestReadTheRoMandatoryAttributeDefaultConfigStatus_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : reads back the RO mandatory attribute: ConfigStatus\n"); - err = TestReadsBackTheRoMandatoryAttributeConfigStatus_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : read the RO mandatory attribute default: OperationalStatus\n"); - err = TestReadTheRoMandatoryAttributeDefaultOperationalStatus_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : reads back the RO mandatory attribute: OperationalStatus\n"); - err = TestReadsBackTheRoMandatoryAttributeOperationalStatus_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : read the RO mandatory attribute default: EndProductType\n"); - err = TestReadTheRoMandatoryAttributeDefaultEndProductType_6(); - break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : reads back the RO mandatory attribute: EndProductType\n"); - err = TestReadsBackTheRoMandatoryAttributeEndProductType_7(); - break; - case 8: - ChipLogProgress(chipTool, " ***** Test Step 8 : read the RW mandatory attribute default: Mode\n"); - err = TestReadTheRwMandatoryAttributeDefaultMode_8(); - break; - case 9: - ChipLogProgress(chipTool, " ***** Test Step 9 : write a value into the RW mandatory attribute:: Mode\n"); - err = TestWriteAValueIntoTheRwMandatoryAttributeMode_9(); - break; - case 10: - ChipLogProgress(chipTool, " ***** Test Step 10 : reads back the RW mandatory attribute: Mode\n"); - err = TestReadsBackTheRwMandatoryAttributeMode_10(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Navigate Target Command\n"); + err = TestNavigateTargetCommand_1(); break; } @@ -8781,324 +10382,397 @@ class Test_TC_WNCV_2_1 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 11; + const uint16_t mTestCount = 2; chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; - chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; - chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; - chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; - chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; - chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; - chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; - chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; - chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; - chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, this }; + chip::Callback::Callback + mOnSuccessCallback_0{ OnSuccessCallback_0, this }; static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint8_t type) - { - (static_cast(context))->OnSuccessResponse_0(type); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnFailureCallback_1(void * context, uint8_t status) + static void OnSuccessCallback_0(void * context, uint16_t count, _NavigateTargetTargetInfo * targetNavigatorList) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnSuccessResponse_0(count, targetNavigatorList); } - static void OnSuccessCallback_1(void * context, uint8_t type) - { - (static_cast(context))->OnSuccessResponse_1(type); - } + // + // Tests methods + // - static void OnFailureCallback_2(void * context, uint8_t status) + CHIP_ERROR TestReadAttributeTargetNavigatorList_0() { - (static_cast(context))->OnFailureResponse_2(status); - } + chip::Controller::TargetNavigatorClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_2(void * context, uint8_t configStatus) - { - (static_cast(context))->OnSuccessResponse_2(configStatus); + return cluster.ReadAttributeTargetNavigatorList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - static void OnFailureCallback_3(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_3(status); - } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_3(void * context, uint8_t configStatus) + void OnSuccessResponse_0(uint16_t count, _NavigateTargetTargetInfo * targetNavigatorList) { - (static_cast(context))->OnSuccessResponse_3(configStatus); + VerifyOrReturn(CheckValueAsList("targetNavigatorList", count, 2)); + NextTest(); } - static void OnFailureCallback_4(void * context, uint8_t status) + CHIP_ERROR TestNavigateTargetCommand_1() { - (static_cast(context))->OnFailureResponse_4(status); - } + chip::Controller::TargetNavigatorClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_4(void * context, uint8_t operationalStatus) - { - (static_cast(context))->OnSuccessResponse_4(operationalStatus); - } + using requestType = chip::app::Clusters::TargetNavigator::Commands::NavigateTarget::Type; + using responseType = chip::app::Clusters::TargetNavigator::Commands::NavigateTargetResponse::DecodableType; - static void OnFailureCallback_5(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_5(status); - } + chip::app::Clusters::TargetNavigator::Commands::NavigateTarget::Type request; + request.target = 1; + request.data = chip::Span("1", strlen("1")); - static void OnSuccessCallback_5(void * context, uint8_t operationalStatus) - { - (static_cast(context))->OnSuccessResponse_5(operationalStatus); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context)) + ->OnSuccessResponse_1(data.status, + chip::ByteSpan(reinterpret_cast(data.data.data()), data.data.size())); + }; - static void OnFailureCallback_6(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_6(status); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_1(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_6(void * context, uint8_t endProductType) - { - (static_cast(context))->OnSuccessResponse_6(endProductType); - } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_7(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_7(status); - } + void OnSuccessResponse_1(uint8_t status, chip::ByteSpan data) { NextTest(); } +}; - static void OnSuccessCallback_7(void * context, uint8_t endProductType) - { - (static_cast(context))->OnSuccessResponse_7(endProductType); - } +class TV_AudioOutputCluster : public TestCommand +{ +public: + TV_AudioOutputCluster() : TestCommand("TV_AudioOutputCluster"), mTestIndex(0) {} - static void OnFailureCallback_8(void * context, uint8_t status) + /////////// TestCommand Interface ///////// + void NextTest() override { - (static_cast(context))->OnFailureResponse_8(status); - } + CHIP_ERROR err = CHIP_NO_ERROR; - static void OnSuccessCallback_8(void * context, uint8_t mode) - { - (static_cast(context))->OnSuccessResponse_8(mode); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: TV_AudioOutputCluster\n"); + } - static void OnFailureCallback_9(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_9(status); - } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: TV_AudioOutputCluster\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - static void OnSuccessCallback_9(void * context, uint8_t mode) - { - (static_cast(context))->OnSuccessResponse_9(mode); + Wait(); + + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute Audio Output list\n"); + err = TestReadAttributeAudioOutputList_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Select Output Command\n"); + err = TestSelectOutputCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Rename Output Command\n"); + err = TestRenameOutputCommand_2(); + break; + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - static void OnFailureCallback_10(void * context, uint8_t status) +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 3; + + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ + OnSuccessCallback_0, this + }; + + static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_10(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_10(void * context, uint8_t mode) + static void OnSuccessCallback_0(void * context, uint16_t count, _AudioOutputInfo * audioOutputList) { - (static_cast(context))->OnSuccessResponse_10(mode); + (static_cast(context))->OnSuccessResponse_0(count, audioOutputList); } // // Tests methods // - CHIP_ERROR TestReadTheRoMandatoryAttributeDefaultType_0() + CHIP_ERROR TestReadAttributeAudioOutputList_0() { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::AudioOutputClusterTest cluster; + cluster.Associate(mDevice, 2); - return cluster.ReadAttributeType(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + return cluster.ReadAttributeAudioOutputList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint8_t type) + void OnSuccessResponse_0(uint16_t count, _AudioOutputInfo * audioOutputList) { - VerifyOrReturn(CheckValue("type", type, 0)); + VerifyOrReturn(CheckValueAsList("audioOutputList", count, 3)); NextTest(); } - CHIP_ERROR TestReadsBackTheRoMandatoryAttributeType_1() + CHIP_ERROR TestSelectOutputCommand_1() { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::AudioOutputClusterTest cluster; + cluster.Associate(mDevice, 2); - return cluster.ReadAttributeType(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + using requestType = chip::app::Clusters::AudioOutput::Commands::SelectOutput::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::AudioOutput::Commands::SelectOutput::Type request; + request.index = 1; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_1(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_1(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint8_t type) - { - VerifyOrReturn(CheckValue("type", type, 0)); - NextTest(); - } + void OnSuccessResponse_1() { NextTest(); } - CHIP_ERROR TestReadTheRoMandatoryAttributeDefaultConfigStatus_2() + CHIP_ERROR TestRenameOutputCommand_2() { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::AudioOutputClusterTest cluster; + cluster.Associate(mDevice, 2); - return cluster.ReadAttributeConfigStatus(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + using requestType = chip::app::Clusters::AudioOutput::Commands::RenameOutput::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::AudioOutput::Commands::RenameOutput::Type request; + request.index = 1; + request.name = chip::Span("exampleName", strlen("exampleName")); + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint8_t configStatus) - { - VerifyOrReturn(CheckValue("configStatus", configStatus, 3)); - NextTest(); - } + void OnSuccessResponse_2() { NextTest(); } +}; - CHIP_ERROR TestReadsBackTheRoMandatoryAttributeConfigStatus_3() +class TV_ApplicationLauncherCluster : public TestCommand +{ +public: + TV_ApplicationLauncherCluster() : TestCommand("TV_ApplicationLauncherCluster"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); + CHIP_ERROR err = CHIP_NO_ERROR; - return cluster.ReadAttributeConfigStatus(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); - } + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: TV_ApplicationLauncherCluster\n"); + } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: TV_ApplicationLauncherCluster\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - void OnSuccessResponse_3(uint8_t configStatus) - { - VerifyOrReturn(CheckValue("configStatus", configStatus, 3)); - NextTest(); - } + Wait(); - CHIP_ERROR TestReadTheRoMandatoryAttributeDefaultOperationalStatus_4() - { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute Application Launcher list\n"); + err = TestReadAttributeApplicationLauncherList_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Launch App Command\n"); + err = TestLaunchAppCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Read attribute catalog vendor id\n"); + err = TestReadAttributeCatalogVendorId_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Read attribute application id\n"); + err = TestReadAttributeApplicationId_3(); + break; + } - return cluster.ReadAttributeOperationalStatus(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 4; - void OnSuccessResponse_4(uint8_t operationalStatus) + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ + OnSuccessCallback_0, this + }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + + static void OnFailureCallback_0(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("operationalStatus", operationalStatus, 0)); - NextTest(); + (static_cast(context))->OnFailureResponse_0(status); } - CHIP_ERROR TestReadsBackTheRoMandatoryAttributeOperationalStatus_5() + static void OnSuccessCallback_0(void * context, uint16_t count, uint16_t * applicationLauncherList) { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOperationalStatus(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + (static_cast(context))->OnSuccessResponse_0(count, applicationLauncherList); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_5(uint8_t operationalStatus) + static void OnFailureCallback_2(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("operationalStatus", operationalStatus, 0)); - NextTest(); + (static_cast(context))->OnFailureResponse_2(status); } - CHIP_ERROR TestReadTheRoMandatoryAttributeDefaultEndProductType_6() + static void OnSuccessCallback_2(void * context, uint8_t catalogVendorId) { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeEndProductType(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); + (static_cast(context))->OnSuccessResponse_2(catalogVendorId); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_6(uint8_t endProductType) + static void OnFailureCallback_3(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("endProductType", endProductType, 0)); - NextTest(); + (static_cast(context))->OnFailureResponse_3(status); } - CHIP_ERROR TestReadsBackTheRoMandatoryAttributeEndProductType_7() + static void OnSuccessCallback_3(void * context, uint8_t applicationId) { - chip::Controller::WindowCoveringClusterTest cluster; + (static_cast(context))->OnSuccessResponse_3(applicationId); + } + + // + // Tests methods + // + + CHIP_ERROR TestReadAttributeApplicationLauncherList_0() + { + chip::Controller::ApplicationLauncherClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeEndProductType(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + return cluster.ReadAttributeApplicationLauncherList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_7(uint8_t endProductType) + void OnSuccessResponse_0(uint16_t count, uint16_t * applicationLauncherList) { - VerifyOrReturn(CheckValue("endProductType", endProductType, 0)); + VerifyOrReturn(CheckValueAsList("applicationLauncherList", count, 2)); NextTest(); } - CHIP_ERROR TestReadTheRwMandatoryAttributeDefaultMode_8() + CHIP_ERROR TestLaunchAppCommand_1() { - chip::Controller::WindowCoveringClusterTest cluster; + chip::Controller::ApplicationLauncherClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeMode(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel()); - } + using requestType = chip::app::Clusters::ApplicationLauncher::Commands::LaunchApp::Type; + using responseType = chip::app::Clusters::ApplicationLauncher::Commands::LaunchAppResponse::DecodableType; - void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } + chip::app::Clusters::ApplicationLauncher::Commands::LaunchApp::Type request; + request.data = chip::Span("exampleData", strlen("exampleData")); + request.catalogVendorId = 1U; + request.applicationId = chip::Span("appId", strlen("appId")); - void OnSuccessResponse_8(uint8_t mode) - { - VerifyOrReturn(CheckValue("mode", mode, 0)); - NextTest(); + auto success = [](void * context, const responseType & data) { + (static_cast(context)) + ->OnSuccessResponse_1(data.status, + chip::ByteSpan(reinterpret_cast(data.data.data()), data.data.size())); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_1(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - CHIP_ERROR TestWriteAValueIntoTheRwMandatoryAttributeMode_9() + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(uint8_t status, chip::ByteSpan data) { NextTest(); } + + CHIP_ERROR TestReadAttributeCatalogVendorId_2() { - chip::Controller::WindowCoveringClusterTest cluster; + chip::Controller::ApplicationLauncherClusterTest cluster; cluster.Associate(mDevice, 1); - uint8_t modeArgument = 7; - - return cluster.WriteAttributeMode(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel(), modeArgument); + return cluster.ReadAttributeCatalogVendorId(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } - void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_9(uint8_t mode) { NextTest(); } + void OnSuccessResponse_2(uint8_t catalogVendorId) + { + VerifyOrReturn(CheckValue("catalogVendorId", catalogVendorId, 0)); + NextTest(); + } - CHIP_ERROR TestReadsBackTheRwMandatoryAttributeMode_10() + CHIP_ERROR TestReadAttributeApplicationId_3() { - chip::Controller::WindowCoveringClusterTest cluster; + chip::Controller::ApplicationLauncherClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeMode(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); + return cluster.ReadAttributeApplicationId(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } - void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_10(uint8_t mode) + void OnSuccessResponse_3(uint8_t applicationId) { - VerifyOrReturn(CheckValue("mode", mode, 7)); + VerifyOrReturn(CheckValue("applicationId", applicationId, 0)); NextTest(); } }; -class Test_TC_WNCV_3_1 : public TestCommand +class TV_KeypadInputCluster : public TestCommand { public: - Test_TC_WNCV_3_1() : TestCommand("Test_TC_WNCV_3_1"), mTestIndex(0) {} + TV_KeypadInputCluster() : TestCommand("TV_KeypadInputCluster"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -9107,12 +10781,12 @@ class Test_TC_WNCV_3_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_WNCV_3_1\n"); + ChipLogProgress(chipTool, " **** Test Start: TV_KeypadInputCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_WNCV_3_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: TV_KeypadInputCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -9126,16 +10800,8 @@ class Test_TC_WNCV_3_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : 1a: TH adjusts the the DUT to a non-open position\n"); - err = Test1aThAdjustsTheTheDutToANonOpenPosition_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : 2a: TH sends UpOrOpen command to DUT\n"); - err = Test2aThSendsUpOrOpenCommandToDut_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : 3a: TH reads OperationalStatus attribute from DUT\n"); - err = Test3aThReadsOperationalStatusAttributeFromDut_2(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Send Key Command\n"); + err = TestSendKeyCommand_0(); break; } @@ -9148,94 +10814,42 @@ class Test_TC_WNCV_3_1 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 3; - - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - - static void OnFailureCallback_2(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_2(status); - } - - static void OnSuccessCallback_2(void * context, uint8_t operationalStatus) - { - (static_cast(context))->OnSuccessResponse_2(operationalStatus); - } + const uint16_t mTestCount = 1; // // Tests methods // - CHIP_ERROR Test1aThAdjustsTheTheDutToANonOpenPosition_0() + CHIP_ERROR TestSendKeyCommand_0() { - chip::Controller::WindowCoveringClusterTest cluster; + chip::Controller::KeypadInputClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::WindowCovering::Commands::DownOrClose::Type; - using responseType = chip::app::DataModel::NullObjectType; + using requestType = chip::app::Clusters::KeypadInput::Commands::SendKey::Type; + using responseType = chip::app::Clusters::KeypadInput::Commands::SendKeyResponse::DecodableType; - chip::app::Clusters::WindowCovering::Commands::DownOrClose::Type request; + chip::app::Clusters::KeypadInput::Commands::SendKey::Type request; + request.keyCode = static_cast(3); auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); + (static_cast(context))->OnSuccessResponse_0(data.status); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); }; return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } - - CHIP_ERROR Test2aThSendsUpOrOpenCommandToDut_1() - { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); - }; - return cluster.InvokeCommand(request, this, success, failure); - } - - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_1() { NextTest(); } - - CHIP_ERROR Test3aThReadsOperationalStatusAttributeFromDut_2() - { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOperationalStatus(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); - } - - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_2(uint8_t operationalStatus) - { - VerifyOrReturn(CheckValue("operationalStatus", operationalStatus, 0)); - NextTest(); - } + void OnSuccessResponse_0(uint8_t status) { NextTest(); } }; -class Test_TC_WNCV_3_2 : public TestCommand +class TV_AccountLoginCluster : public TestCommand { public: - Test_TC_WNCV_3_2() : TestCommand("Test_TC_WNCV_3_2"), mTestIndex(0) {} + TV_AccountLoginCluster() : TestCommand("TV_AccountLoginCluster"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -9244,12 +10858,12 @@ class Test_TC_WNCV_3_2 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_WNCV_3_2\n"); + ChipLogProgress(chipTool, " **** Test Start: TV_AccountLoginCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_WNCV_3_2\n"); + ChipLogProgress(chipTool, " **** Test Complete: TV_AccountLoginCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -9263,16 +10877,12 @@ class Test_TC_WNCV_3_2 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : 1a: TH adjusts the the DUT to a non-closed position\n"); - err = Test1aThAdjustsTheTheDutToANonClosedPosition_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Get Setup PIN Command\n"); + err = TestGetSetupPinCommand_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : 2a: TH sends DownOrClose command to DUT\n"); - err = Test2aThSendsDownOrCloseCommandToDut_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : 3a: TH reads OperationalStatus attribute from DUT\n"); - err = Test3aThReadsOperationalStatusAttributeFromDut_2(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Login Command\n"); + err = TestLoginCommand_1(); break; } @@ -9285,65 +10895,57 @@ class Test_TC_WNCV_3_2 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 3; - - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - - static void OnFailureCallback_2(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_2(status); - } - - static void OnSuccessCallback_2(void * context, uint8_t operationalStatus) - { - (static_cast(context))->OnSuccessResponse_2(operationalStatus); - } + const uint16_t mTestCount = 2; // // Tests methods // - CHIP_ERROR Test1aThAdjustsTheTheDutToANonClosedPosition_0() + CHIP_ERROR TestGetSetupPinCommand_0() { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::AccountLoginClusterTest cluster; + cluster.Associate(mDevice, 3); - using requestType = chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type; - using responseType = chip::app::DataModel::NullObjectType; + using requestType = chip::app::Clusters::AccountLogin::Commands::GetSetupPIN::Type; + using responseType = chip::app::Clusters::AccountLogin::Commands::GetSetupPINResponse::DecodableType; - chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type request; + chip::app::Clusters::AccountLogin::Commands::GetSetupPIN::Type request; + request.tempAccountIdentifier = chip::Span("asdf", strlen("asdf")); auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); + (static_cast(context)) + ->OnSuccessResponse_0( + chip::ByteSpan(reinterpret_cast(data.setupPIN.data()), data.setupPIN.size())); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_0(status); }; return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_0(chip::ByteSpan setupPIN) { NextTest(); } - CHIP_ERROR Test2aThSendsDownOrCloseCommandToDut_1() + CHIP_ERROR TestLoginCommand_1() { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::AccountLoginClusterTest cluster; + cluster.Associate(mDevice, 3); - using requestType = chip::app::Clusters::WindowCovering::Commands::DownOrClose::Type; + using requestType = chip::app::Clusters::AccountLogin::Commands::Login::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::WindowCovering::Commands::DownOrClose::Type request; + chip::app::Clusters::AccountLogin::Commands::Login::Type request; + request.tempAccountIdentifier = chip::Span("asdf", strlen("asdf")); + request.setupPIN = chip::Span("tempPin123", strlen("tempPin123")); auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(); + (static_cast(context))->OnSuccessResponse_1(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_1(status); }; return cluster.InvokeCommand(request, this, success, failure); } @@ -9351,42 +10953,26 @@ class Test_TC_WNCV_3_2 : public TestCommand void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } void OnSuccessResponse_1() { NextTest(); } +}; - CHIP_ERROR Test3aThReadsOperationalStatusAttributeFromDut_2() +class TV_WakeOnLanCluster : public TestCommand +{ +public: + TV_WakeOnLanCluster() : TestCommand("TV_WakeOnLanCluster"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOperationalStatus(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); - } - - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_2(uint8_t operationalStatus) - { - VerifyOrReturn(CheckValue("operationalStatus", operationalStatus, 0)); - NextTest(); - } -}; - -class Test_TC_WNCV_3_3 : public TestCommand -{ -public: - Test_TC_WNCV_3_3() : TestCommand("Test_TC_WNCV_3_3"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; + CHIP_ERROR err = CHIP_NO_ERROR; if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_WNCV_3_3\n"); + ChipLogProgress(chipTool, " **** Test Start: TV_WakeOnLanCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_WNCV_3_3\n"); + ChipLogProgress(chipTool, " **** Test Complete: TV_WakeOnLanCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -9400,16 +10986,8 @@ class Test_TC_WNCV_3_3 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : 1a: TH adjusts the the DUT to a non-open position\n"); - err = Test1aThAdjustsTheTheDutToANonOpenPosition_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : 2a: TH sends StopMotion command to DUT\n"); - err = Test2aThSendsStopMotionCommandToDut_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : 2b: TH reads OperationalStatus attribute from DUT\n"); - err = Test2bThReadsOperationalStatusAttributeFromDut_2(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Read mac address\n"); + err = TestReadMacAddress_0(); break; } @@ -9422,94 +11000,48 @@ class Test_TC_WNCV_3_3 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 3; + const uint16_t mTestCount = 1; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ + OnSuccessCallback_0, this + }; - static void OnFailureCallback_2(void * context, uint8_t status) + static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_2(void * context, uint8_t operationalStatus) + static void OnSuccessCallback_0(void * context, chip::ByteSpan wakeOnLanMacAddress) { - (static_cast(context))->OnSuccessResponse_2(operationalStatus); + (static_cast(context))->OnSuccessResponse_0(wakeOnLanMacAddress); } // // Tests methods // - CHIP_ERROR Test1aThAdjustsTheTheDutToANonOpenPosition_0() + CHIP_ERROR TestReadMacAddress_0() { - chip::Controller::WindowCoveringClusterTest cluster; + chip::Controller::WakeOnLanClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::WindowCovering::Commands::UpOrOpen::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeWakeOnLanMacAddress(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } - - CHIP_ERROR Test2aThSendsStopMotionCommandToDut_1() - { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::WindowCovering::Commands::StopMotion::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::WindowCovering::Commands::StopMotion::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); - }; - return cluster.InvokeCommand(request, this, success, failure); - } - - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_1() { NextTest(); } - - CHIP_ERROR Test2bThReadsOperationalStatusAttributeFromDut_2() - { - chip::Controller::WindowCoveringClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOperationalStatus(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); - } - - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_2(uint8_t operationalStatus) + void OnSuccessResponse_0(chip::ByteSpan wakeOnLanMacAddress) { - VerifyOrReturn(CheckValue("operationalStatus", operationalStatus, 0)); + VerifyOrReturn(CheckValueAsString("wakeOnLanMacAddress", wakeOnLanMacAddress, "00:00:00:00:00")); NextTest(); } }; -class Test_TC_BI_1_1 : public TestCommand +class TV_ApplicationBasicCluster : public TestCommand { public: - Test_TC_BI_1_1() : TestCommand("Test_TC_BI_1_1"), mTestIndex(0) {} + TV_ApplicationBasicCluster() : TestCommand("TV_ApplicationBasicCluster"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -9518,12 +11050,12 @@ class Test_TC_BI_1_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_BI_1_1\n"); + ChipLogProgress(chipTool, " **** Test Start: TV_ApplicationBasicCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_BI_1_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: TV_ApplicationBasicCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -9537,17 +11069,20 @@ class Test_TC_BI_1_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); - err = TestReadTheGlobalAttributeClusterRevision_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Change Status Command\n"); + err = TestChangeStatusCommand_0(); break; case 1: - ChipLogProgress(chipTool, - " ***** Test Step 1 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Read attribute vendor id\n"); + err = TestReadAttributeVendorId_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : reads back global attribute: ClusterRevision\n"); - err = TestReadsBackGlobalAttributeClusterRevision_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Read attribute product id\n"); + err = TestReadAttributeProductId_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Read attribute catalog vendor id\n"); + err = TestReadAttributeCatalogVendorId_3(); break; } @@ -9560,101 +11095,127 @@ class Test_TC_BI_1_1 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 3; + const uint16_t mTestCount = 4; - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; - static void OnFailureCallback_0(void * context, uint8_t status) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) + static void OnSuccessCallback_1(void * context, uint16_t vendorId) { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); + (static_cast(context))->OnSuccessResponse_1(vendorId); } - static void OnFailureCallback_1(void * context, uint8_t status) + static void OnFailureCallback_2(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_2(status); } - static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) + static void OnSuccessCallback_2(void * context, uint16_t productId) { - (static_cast(context))->OnSuccessResponse_1(clusterRevision); + (static_cast(context))->OnSuccessResponse_2(productId); } - static void OnFailureCallback_2(void * context, uint8_t status) + static void OnFailureCallback_3(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_3(status); } - static void OnSuccessCallback_2(void * context, uint16_t clusterRevision) + static void OnSuccessCallback_3(void * context, uint16_t catalogVendorId) { - (static_cast(context))->OnSuccessResponse_2(clusterRevision); + (static_cast(context))->OnSuccessResponse_3(catalogVendorId); } // // Tests methods // - CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() + CHIP_ERROR TestChangeStatusCommand_0() { - chip::Controller::BinaryInputBasicClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::ApplicationBasicClusterTest cluster; + cluster.Associate(mDevice, 3); - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + using requestType = chip::app::Clusters::ApplicationBasic::Commands::ChangeStatus::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::ApplicationBasic::Commands::ChangeStatus::Type request; + request.status = static_cast(1); + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint16_t clusterRevision) + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestReadAttributeVendorId_1() { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 1U)); - NextTest(); + chip::Controller::ApplicationBasicClusterTest cluster; + cluster.Associate(mDevice, 3); + + return cluster.ReadAttributeVendorId(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1() + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_1(uint16_t vendorId) { - chip::Controller::BinaryInputBasicClusterTest cluster; - cluster.Associate(mDevice, 1); + VerifyOrReturn(CheckValue("vendorId", vendorId, 1U)); + NextTest(); + } - uint16_t clusterRevisionArgument = 1U; + CHIP_ERROR TestReadAttributeProductId_2() + { + chip::Controller::ApplicationBasicClusterTest cluster; + cluster.Associate(mDevice, 3); - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), - clusterRevisionArgument); + return cluster.ReadAttributeProductId(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } - void OnFailureResponse_1(uint8_t status) { NextTest(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } + void OnSuccessResponse_2(uint16_t productId) + { + VerifyOrReturn(CheckValue("productId", productId, 1U)); + NextTest(); + } - CHIP_ERROR TestReadsBackGlobalAttributeClusterRevision_2() + CHIP_ERROR TestReadAttributeCatalogVendorId_3() { - chip::Controller::BinaryInputBasicClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::ApplicationBasicClusterTest cluster; + cluster.Associate(mDevice, 3); - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + return cluster.ReadAttributeCatalogVendorId(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint16_t clusterRevision) + void OnSuccessResponse_3(uint16_t catalogVendorId) { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 1U)); + VerifyOrReturn(CheckValue("catalogVendorId", catalogVendorId, 1U)); NextTest(); } }; -class Test_TC_FLW_1_1 : public TestCommand +class TV_MediaPlaybackCluster : public TestCommand { public: - Test_TC_FLW_1_1() : TestCommand("Test_TC_FLW_1_1"), mTestIndex(0) {} + TV_MediaPlaybackCluster() : TestCommand("TV_MediaPlaybackCluster"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -9663,12 +11224,12 @@ class Test_TC_FLW_1_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_FLW_1_1\n"); + ChipLogProgress(chipTool, " **** Test Start: TV_MediaPlaybackCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_FLW_1_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: TV_MediaPlaybackCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -9682,12 +11243,51 @@ class Test_TC_FLW_1_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, - " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Media Playback Play Command\n"); + err = TestMediaPlaybackPlayCommand_0(); break; - } - + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Media Playback Pause Command\n"); + err = TestMediaPlaybackPauseCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Media Playback Stop Command\n"); + err = TestMediaPlaybackStopCommand_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Media Playback Start Over Command\n"); + err = TestMediaPlaybackStartOverCommand_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Media Playback Previous Command\n"); + err = TestMediaPlaybackPreviousCommand_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Media Playback Next Command\n"); + err = TestMediaPlaybackNextCommand_5(); + break; + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : Media Playback Rewind Command\n"); + err = TestMediaPlaybackRewindCommand_6(); + break; + case 7: + ChipLogProgress(chipTool, " ***** Test Step 7 : Media Playback Fast Forward Command\n"); + err = TestMediaPlaybackFastForwardCommand_7(); + break; + case 8: + ChipLogProgress(chipTool, " ***** Test Step 8 : Media Playback Skip Forward Command\n"); + err = TestMediaPlaybackSkipForwardCommand_8(); + break; + case 9: + ChipLogProgress(chipTool, " ***** Test Step 9 : Media Playback Skip Backward Command\n"); + err = TestMediaPlaybackSkipBackwardCommand_9(); + break; + case 10: + ChipLogProgress(chipTool, " ***** Test Step 10 : Media Playback Seek Command\n"); + err = TestMediaPlaybackSeekCommand_10(); + break; + } + if (CHIP_NO_ERROR != err) { ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); @@ -9697,303 +11297,328 @@ class Test_TC_FLW_1_1 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } + const uint16_t mTestCount = 11; // // Tests methods // - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() + CHIP_ERROR TestMediaPlaybackPlayCommand_0() { - chip::Controller::FlowMeasurementClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); - uint16_t clusterRevisionArgument = 2U; + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaPlay::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaPlayResponse::DecodableType; - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), - clusterRevisionArgument); - } + chip::app::Clusters::MediaPlayback::Commands::MediaPlay::Type request; - void OnFailureResponse_0(uint8_t status) { NextTest(); } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(data.mediaPlaybackStatus); + }; - void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } -}; + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } -class Test_TC_TM_1_1 : public TestCommand -{ -public: - Test_TC_TM_1_1() : TestCommand("Test_TC_TM_1_1"), mTestIndex(0) {} + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - /////////// TestCommand Interface ///////// - void NextTest() override + void OnSuccessResponse_0(uint8_t mediaPlaybackStatus) { - CHIP_ERROR err = CHIP_NO_ERROR; + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + NextTest(); + } - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_TM_1_1\n"); - } + CHIP_ERROR TestMediaPlaybackPauseCommand_1() + { + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_TM_1_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaPause::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaPauseResponse::DecodableType; - Wait(); + chip::app::Clusters::MediaPlayback::Commands::MediaPause::Type request; - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); - err = TestReadTheGlobalAttributeClusterRevision_0(); - break; - case 1: - ChipLogProgress(chipTool, - " ***** Test Step 1 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : reads back global attribute: ClusterRevision\n"); - err = TestReadsBackGlobalAttributeClusterRevision_2(); - break; - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_1(data.mediaPlaybackStatus); + }; - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_1(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 3; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_0(void * context, uint8_t status) + void OnSuccessResponse_1(uint8_t mediaPlaybackStatus) { - (static_cast(context))->OnFailureResponse_0(status); + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + NextTest(); } - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) + CHIP_ERROR TestMediaPlaybackStopCommand_2() { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); - static void OnFailureCallback_1(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_1(status); - } + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaStop::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaStopResponse::DecodableType; - static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_1(clusterRevision); + chip::app::Clusters::MediaPlayback::Commands::MediaStop::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(data.mediaPlaybackStatus); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnFailureCallback_2(void * context, uint8_t status) + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_2(uint8_t mediaPlaybackStatus) { - (static_cast(context))->OnFailureResponse_2(status); + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + NextTest(); } - static void OnSuccessCallback_2(void * context, uint16_t clusterRevision) + CHIP_ERROR TestMediaPlaybackStartOverCommand_3() { - (static_cast(context))->OnSuccessResponse_2(clusterRevision); - } + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); - // - // Tests methods - // + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaStartOver::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaStartOverResponse::DecodableType; - CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() - { - chip::Controller::TemperatureMeasurementClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::app::Clusters::MediaPlayback::Commands::MediaStartOver::Type request; - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(data.mediaPlaybackStatus); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint16_t clusterRevision) + void OnSuccessResponse_3(uint8_t mediaPlaybackStatus) { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 3U)); + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); NextTest(); } - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1() + CHIP_ERROR TestMediaPlaybackPreviousCommand_4() { - chip::Controller::TemperatureMeasurementClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t clusterRevisionArgument = 3U; - - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), - clusterRevisionArgument); - } + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); - void OnFailureResponse_1(uint8_t status) { NextTest(); } + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaPrevious::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaPreviousResponse::DecodableType; - void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } + chip::app::Clusters::MediaPlayback::Commands::MediaPrevious::Type request; - CHIP_ERROR TestReadsBackGlobalAttributeClusterRevision_2() - { - chip::Controller::TemperatureMeasurementClusterTest cluster; - cluster.Associate(mDevice, 1); + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_4(data.mediaPlaybackStatus); + }; - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_4(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2(uint16_t clusterRevision) + void OnSuccessResponse_4(uint8_t mediaPlaybackStatus) { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 3U)); + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); NextTest(); } -}; - -class Test_TC_OCC_1_1 : public TestCommand -{ -public: - Test_TC_OCC_1_1() : TestCommand("Test_TC_OCC_1_1"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestMediaPlaybackNextCommand_5() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_OCC_1_1\n"); - } + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaNext::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaNextResponse::DecodableType; - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_OCC_1_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + chip::app::Clusters::MediaPlayback::Commands::MediaNext::Type request; - Wait(); + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_5(data.mediaPlaybackStatus); + }; - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); - err = TestReadTheGlobalAttributeClusterRevision_0(); - break; - case 1: - ChipLogProgress(chipTool, - " ***** Test Step 1 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1(); - break; - } + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_5(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_5(uint8_t mediaPlaybackStatus) + { + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + NextTest(); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 2; + CHIP_ERROR TestMediaPlaybackRewindCommand_6() + { + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaRewind::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaRewindResponse::DecodableType; - static void OnFailureCallback_0(void * context, uint8_t status) + chip::app::Clusters::MediaPlayback::Commands::MediaRewind::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_6(data.mediaPlaybackStatus); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_6(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_6(uint8_t mediaPlaybackStatus) { - (static_cast(context))->OnFailureResponse_0(status); + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + NextTest(); } - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) + CHIP_ERROR TestMediaPlaybackFastForwardCommand_7() { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); + + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaFastForward::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaFastForwardResponse::DecodableType; + + chip::app::Clusters::MediaPlayback::Commands::MediaFastForward::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_7(data.mediaPlaybackStatus); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_7(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnFailureCallback_1(void * context, uint8_t status) + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_7(uint8_t mediaPlaybackStatus) { - (static_cast(context))->OnFailureResponse_1(status); + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + NextTest(); } - static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) + CHIP_ERROR TestMediaPlaybackSkipForwardCommand_8() { - (static_cast(context))->OnSuccessResponse_1(clusterRevision); + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); + + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaSkipForward::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaSkipForwardResponse::DecodableType; + + chip::app::Clusters::MediaPlayback::Commands::MediaSkipForward::Type request; + request.deltaPositionMilliseconds = 100ULL; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_8(data.mediaPlaybackStatus); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_8(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - // - // Tests methods - // + void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() + void OnSuccessResponse_8(uint8_t mediaPlaybackStatus) { - chip::Controller::OccupancySensingClusterTest cluster; - cluster.Associate(mDevice, 1); + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + NextTest(); + } - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + CHIP_ERROR TestMediaPlaybackSkipBackwardCommand_9() + { + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); + + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaSkipBackward::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaSkipBackwardResponse::DecodableType; + + chip::app::Clusters::MediaPlayback::Commands::MediaSkipBackward::Type request; + request.deltaPositionMilliseconds = 100ULL; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_9(data.mediaPlaybackStatus); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_9(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint16_t clusterRevision) + void OnSuccessResponse_9(uint8_t mediaPlaybackStatus) { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 2U)); + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); NextTest(); } - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1() + CHIP_ERROR TestMediaPlaybackSeekCommand_10() { - chip::Controller::OccupancySensingClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::MediaPlaybackClusterTest cluster; + cluster.Associate(mDevice, 3); - uint16_t clusterRevisionArgument = 2U; + using requestType = chip::app::Clusters::MediaPlayback::Commands::MediaSeek::Type; + using responseType = chip::app::Clusters::MediaPlayback::Commands::MediaSeekResponse::DecodableType; - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), - clusterRevisionArgument); + chip::app::Clusters::MediaPlayback::Commands::MediaSeek::Type request; + request.position = 100ULL; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_10(data.mediaPlaybackStatus); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_10(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_1(uint8_t status) { NextTest(); } + void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } + void OnSuccessResponse_10(uint8_t mediaPlaybackStatus) + { + VerifyOrReturn(CheckValue("mediaPlaybackStatus", mediaPlaybackStatus, 0)); + NextTest(); + } }; -class TestOperationalCredentialsCluster : public TestCommand +class TV_TvChannelCluster : public TestCommand { public: - TestOperationalCredentialsCluster() : TestCommand("TestOperationalCredentialsCluster"), mTestIndex(0) {} + TV_TvChannelCluster() : TestCommand("TV_TvChannelCluster"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -10002,12 +11627,12 @@ class TestOperationalCredentialsCluster : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: TestOperationalCredentialsCluster\n"); + ChipLogProgress(chipTool, " **** Test Start: TV_TvChannelCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: TestOperationalCredentialsCluster\n"); + ChipLogProgress(chipTool, " **** Test Complete: TV_TvChannelCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -10021,12 +11646,16 @@ class TestOperationalCredentialsCluster : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Read number of supported fabrics\n"); - err = TestReadNumberOfSupportedFabrics_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute TV Channel list\n"); + err = TestReadAttributeTvChannelList_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Read number of commissioned fabrics\n"); - err = TestReadNumberOfCommissionedFabrics_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Change Channel By Number Command\n"); + err = TestChangeChannelByNumberCommand_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Skip Channel Command\n"); + err = TestSkipChannelCommand_2(); break; } @@ -10039,77 +11668,99 @@ class TestOperationalCredentialsCluster : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 2; + const uint16_t mTestCount = 3; chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, - this }; + chip::Callback::Callback mOnSuccessCallback_0{ + OnSuccessCallback_0, this + }; static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint8_t supportedFabrics) - { - (static_cast(context))->OnSuccessResponse_0(supportedFabrics); - } - - static void OnFailureCallback_1(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_1(void * context, uint8_t commissionedFabrics) + static void OnSuccessCallback_0(void * context, uint16_t count, _TvChannelInfo * tvChannelList) { - (static_cast(context))->OnSuccessResponse_1(commissionedFabrics); + (static_cast(context))->OnSuccessResponse_0(count, tvChannelList); } // // Tests methods // - CHIP_ERROR TestReadNumberOfSupportedFabrics_0() + CHIP_ERROR TestReadAttributeTvChannelList_0() { - chip::Controller::OperationalCredentialsClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::TvChannelClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeSupportedFabrics(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + return cluster.ReadAttributeTvChannelList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint8_t supportedFabrics) + void OnSuccessResponse_0(uint16_t count, _TvChannelInfo * tvChannelList) { - VerifyOrReturn(CheckConstraintType("supportedFabrics", "", "uint8")); - VerifyOrReturn(CheckConstraintMinValue("supportedFabrics", supportedFabrics, 4)); + VerifyOrReturn(CheckValueAsList("tvChannelList", count, 2)); NextTest(); } - CHIP_ERROR TestReadNumberOfCommissionedFabrics_1() + CHIP_ERROR TestChangeChannelByNumberCommand_1() { - chip::Controller::OperationalCredentialsClusterTest cluster; - cluster.Associate(mDevice, 0); + chip::Controller::TvChannelClusterTest cluster; + cluster.Associate(mDevice, 1); - return cluster.ReadAttributeCommissionedFabrics(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + using requestType = chip::app::Clusters::TvChannel::Commands::ChangeChannelByNumber::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::TvChannel::Commands::ChangeChannelByNumber::Type request; + request.majorNumber = 1U; + request.minorNumber = 2U; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_1(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_1(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(uint8_t commissionedFabrics) + void OnSuccessResponse_1() { NextTest(); } + + CHIP_ERROR TestSkipChannelCommand_2() { - VerifyOrReturn(CheckConstraintType("commissionedFabrics", "", "uint8")); - VerifyOrReturn(CheckConstraintMinValue("commissionedFabrics", commissionedFabrics, 1)); - NextTest(); + chip::Controller::TvChannelClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::TvChannel::Commands::SkipChannel::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::TvChannel::Commands::SkipChannel::Type request; + request.count = 1U; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } + + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_2() { NextTest(); } }; -class Test_TC_LVL_1_1 : public TestCommand +class TV_LowPowerCluster : public TestCommand { public: - Test_TC_LVL_1_1() : TestCommand("Test_TC_LVL_1_1"), mTestIndex(0) {} + TV_LowPowerCluster() : TestCommand("TV_LowPowerCluster"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -10118,12 +11769,12 @@ class Test_TC_LVL_1_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_LVL_1_1\n"); + ChipLogProgress(chipTool, " **** Test Start: TV_LowPowerCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_LVL_1_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: TV_LowPowerCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -10137,9 +11788,8 @@ class Test_TC_LVL_1_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, - " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Sleep Input Status Command\n"); + err = TestSleepInputStatusCommand_0(); break; } @@ -10154,43 +11804,39 @@ class Test_TC_LVL_1_1 : public TestCommand std::atomic_uint16_t mTestIndex; const uint16_t mTestCount = 1; - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } - // // Tests methods // - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() + CHIP_ERROR TestSleepInputStatusCommand_0() { - chip::Controller::LevelControlClusterTest cluster; + chip::Controller::LowPowerClusterTest cluster; cluster.Associate(mDevice, 1); - uint16_t clusterRevisionArgument = 4U; + using requestType = chip::app::Clusters::LowPower::Commands::Sleep::Type; + using responseType = chip::app::DataModel::NullObjectType; - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), - clusterRevisionArgument); + chip::app::Clusters::LowPower::Commands::Sleep::Type request; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_0(uint8_t status) { NextTest(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } + void OnSuccessResponse_0() { NextTest(); } }; -class Test_TC_LVL_2_1 : public TestCommand +class TV_MediaInputCluster : public TestCommand { public: - Test_TC_LVL_2_1() : TestCommand("Test_TC_LVL_2_1"), mTestIndex(0) {} + TV_MediaInputCluster() : TestCommand("TV_MediaInputCluster"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -10199,12 +11845,12 @@ class Test_TC_LVL_2_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_LVL_2_1\n"); + ChipLogProgress(chipTool, " **** Test Start: TV_MediaInputCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_LVL_2_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: TV_MediaInputCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -10218,56 +11864,28 @@ class Test_TC_LVL_2_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : reads current Level attribute from DUT\n"); - err = TestReadsCurrentLevelAttributeFromDut_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute media input list\n"); + err = TestReadAttributeMediaInputList_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : sends a Move to level command\n"); - err = TestSendsAMoveToLevelCommand_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Select Input Command\n"); + err = TestSelectInputCommand_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Wait 10ms\n"); - err = TestWait10ms_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Read current input list\n"); + err = TestReadCurrentInputList_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : reads current Level attribute from DUT\n"); - err = TestReadsCurrentLevelAttributeFromDut_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Hide Input Status Command\n"); + err = TestHideInputStatusCommand_3(); break; case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : sends a Move to level command\n"); - err = TestSendsAMoveToLevelCommand_4(); + ChipLogProgress(chipTool, " ***** Test Step 4 : Show Input Status Command\n"); + err = TestShowInputStatusCommand_4(); break; case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Wait 100ms\n"); - err = TestWait100ms_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : reads current Level attribute from DUT\n"); - err = TestReadsCurrentLevelAttributeFromDut_6(); - break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : reads On Off Transition Time attribute from DUT\n"); - err = TestReadsOnOffTransitionTimeAttributeFromDut_7(); - break; - case 8: - ChipLogProgress(chipTool, " ***** Test Step 8 : sends a Move to level command\n"); - err = TestSendsAMoveToLevelCommand_8(); - break; - case 9: - ChipLogProgress(chipTool, " ***** Test Step 9 : Wait 1ms\n"); - err = TestWait1ms_9(); - break; - case 10: - ChipLogProgress(chipTool, " ***** Test Step 10 : reads current Level attribute from DUT\n"); - err = TestReadsCurrentLevelAttributeFromDut_10(); - break; - case 11: - ChipLogProgress(chipTool, " ***** Test Step 11 : Reset level to 0\n"); - err = TestResetLevelTo0_11(); - break; - case 12: - ChipLogProgress(chipTool, " ***** Test Step 12 : Wait 10ms\n"); - err = TestWait10ms_12(); + ChipLogProgress(chipTool, " ***** Test Step 5 : Rename Input Command\n"); + err = TestRenameInputCommand_5(); break; } @@ -10280,110 +11898,72 @@ class Test_TC_LVL_2_1 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 13; + const uint16_t mTestCount = 6; chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; - chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; - chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; - chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, - this }; - chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; - chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, this }; + chip::Callback::Callback mOnSuccessCallback_0{ + OnSuccessCallback_0, this + }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint8_t currentLevel) - { - (static_cast(context))->OnSuccessResponse_0(currentLevel); - } - - static void OnFailureCallback_3(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_3(status); - } - - static void OnSuccessCallback_3(void * context, uint8_t currentLevel) - { - (static_cast(context))->OnSuccessResponse_3(currentLevel); - } - - static void OnFailureCallback_6(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_6(status); - } - - static void OnSuccessCallback_6(void * context, uint8_t currentLevel) - { - (static_cast(context))->OnSuccessResponse_6(currentLevel); - } - - static void OnFailureCallback_7(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_7(status); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnSuccessCallback_7(void * context, uint16_t onOffTransitionTime) + static void OnSuccessCallback_0(void * context, uint16_t count, _MediaInputInfo * mediaInputList) { - (static_cast(context))->OnSuccessResponse_7(onOffTransitionTime); + (static_cast(context))->OnSuccessResponse_0(count, mediaInputList); } - static void OnFailureCallback_10(void * context, uint8_t status) + static void OnFailureCallback_2(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_10(status); + (static_cast(context))->OnFailureResponse_2(status); } - static void OnSuccessCallback_10(void * context, uint8_t currentLevel) + static void OnSuccessCallback_2(void * context, uint8_t currentMediaInput) { - (static_cast(context))->OnSuccessResponse_10(currentLevel); + (static_cast(context))->OnSuccessResponse_2(currentMediaInput); } // // Tests methods // - CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_0() + CHIP_ERROR TestReadAttributeMediaInputList_0() { - chip::Controller::LevelControlClusterTest cluster; + chip::Controller::MediaInputClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + return cluster.ReadAttributeMediaInputList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0(uint8_t currentLevel) + void OnSuccessResponse_0(uint16_t count, _MediaInputInfo * mediaInputList) { - VerifyOrReturn(CheckValue("currentLevel", currentLevel, 0)); + VerifyOrReturn(CheckValueAsList("mediaInputList", count, 2)); NextTest(); } - CHIP_ERROR TestSendsAMoveToLevelCommand_1() + CHIP_ERROR TestSelectInputCommand_1() { - chip::Controller::LevelControlClusterTest cluster; + chip::Controller::MediaInputClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type; + using requestType = chip::app::Clusters::MediaInput::Commands::SelectInput::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type request; - request.level = 64; - request.transitionTime = 0U; - request.optionMask = 1; - request.optionOverride = 1; + chip::app::Clusters::MediaInput::Commands::SelectInput::Type request; + request.index = 1; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_1(); + (static_cast(context))->OnSuccessResponse_1(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_1(status); }; return cluster.InvokeCommand(request, this, success, failure); } @@ -10392,167 +11972,101 @@ class Test_TC_LVL_2_1 : public TestCommand void OnSuccessResponse_1() { NextTest(); } - CHIP_ERROR TestWait10ms_2() { return WaitForMs(10); } - - CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_3() + CHIP_ERROR TestReadCurrentInputList_2() { - chip::Controller::LevelControlClusterTest cluster; + chip::Controller::MediaInputClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + return cluster.ReadAttributeCurrentMediaInput(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3(uint8_t currentLevel) + void OnSuccessResponse_2(uint8_t currentMediaInput) { - VerifyOrReturn(CheckValue("currentLevel", currentLevel, 64)); + VerifyOrReturn(CheckValue("currentMediaInput", currentMediaInput, 1)); NextTest(); } - CHIP_ERROR TestSendsAMoveToLevelCommand_4() + CHIP_ERROR TestHideInputStatusCommand_3() { - chip::Controller::LevelControlClusterTest cluster; + chip::Controller::MediaInputClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type; + using requestType = chip::app::Clusters::MediaInput::Commands::HideInputStatus::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type request; - request.level = 128; - request.transitionTime = 1U; - request.optionMask = 1; - request.optionOverride = 1; + chip::app::Clusters::MediaInput::Commands::HideInputStatus::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); + (static_cast(context))->OnSuccessResponse_3(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_3(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_4() { NextTest(); } - - CHIP_ERROR TestWait100ms_5() { return WaitForMs(100); } - - CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_6() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); - } - - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_6(uint8_t currentLevel) - { - VerifyOrReturn(CheckValue("currentLevel", currentLevel, 128)); - NextTest(); - } - - CHIP_ERROR TestReadsOnOffTransitionTimeAttributeFromDut_7() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOnOffTransitionTime(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); - } - - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_7(uint16_t onOffTransitionTime) - { - VerifyOrReturn(CheckValue("onOffTransitionTime", onOffTransitionTime, 0U)); - NextTest(); - } + void OnSuccessResponse_3() { NextTest(); } - CHIP_ERROR TestSendsAMoveToLevelCommand_8() + CHIP_ERROR TestShowInputStatusCommand_4() { - chip::Controller::LevelControlClusterTest cluster; + chip::Controller::MediaInputClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type; + using requestType = chip::app::Clusters::MediaInput::Commands::ShowInputStatus::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type request; - request.level = 254; - request.transitionTime = 65535U; - request.optionMask = 1; - request.optionOverride = 1; + chip::app::Clusters::MediaInput::Commands::ShowInputStatus::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_8(); + (static_cast(context))->OnSuccessResponse_4(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_8(status); + (static_cast(context))->OnFailureResponse_4(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_8() { NextTest(); } - - CHIP_ERROR TestWait1ms_9() { return WaitForMs(1); } - - CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_10() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); - } - - void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_10(uint8_t currentLevel) - { - VerifyOrReturn(CheckValue("currentLevel", currentLevel, 254)); - NextTest(); - } + void OnSuccessResponse_4() { NextTest(); } - CHIP_ERROR TestResetLevelTo0_11() + CHIP_ERROR TestRenameInputCommand_5() { - chip::Controller::LevelControlClusterTest cluster; + chip::Controller::MediaInputClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type; + using requestType = chip::app::Clusters::MediaInput::Commands::RenameInput::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::LevelControl::Commands::MoveToLevel::Type request; - request.level = 0; - request.transitionTime = 0U; - request.optionMask = 1; - request.optionOverride = 1; + chip::app::Clusters::MediaInput::Commands::RenameInput::Type request; + request.index = 1; + request.name = chip::Span("newName", strlen("newName")); auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_11(); + (static_cast(context))->OnSuccessResponse_5(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_11(status); + (static_cast(context))->OnFailureResponse_5(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_11() { NextTest(); } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestWait10ms_12() { return WaitForMs(10); } + void OnSuccessResponse_5() { NextTest(); } }; -class Test_TC_LVL_3_1 : public TestCommand +class TestCluster : public TestCommand { public: - Test_TC_LVL_3_1() : TestCommand("Test_TC_LVL_3_1"), mTestIndex(0) {} + TestCluster() : TestCommand("TestCluster"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -10561,12 +12075,12 @@ class Test_TC_LVL_3_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_LVL_3_1\n"); + ChipLogProgress(chipTool, " **** Test Start: TestCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_LVL_3_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: TestCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -10580,5541 +12094,3885 @@ class Test_TC_LVL_3_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : reads current level attribute from DUT\n"); - err = TestReadsCurrentLevelAttributeFromDut_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Send Test Command\n"); + err = TestSendTestCommand_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : reads max level attribute from DUT\n"); - err = TestReadsMaxLevelAttributeFromDut_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Send Test Not Handled Command\n"); + err = TestSendTestNotHandledCommand_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : sends a Move up command\n"); - err = TestSendsAMoveUpCommand_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Send Test Specific Command\n"); + err = TestSendTestSpecificCommand_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Wait 2500ms\n"); - err = TestWait2500ms_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Send Test Add Arguments Command\n"); + err = TestSendTestAddArgumentsCommand_3(); break; case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : reads current level attribute from DUT\n"); - err = TestReadsCurrentLevelAttributeFromDut_4(); + ChipLogProgress(chipTool, " ***** Test Step 4 : Send failing Test Add Arguments Command\n"); + err = TestSendFailingTestAddArgumentsCommand_4(); break; case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : reads min level attribute from DUT\n"); - err = TestReadsMinLevelAttributeFromDut_5(); + ChipLogProgress(chipTool, " ***** Test Step 5 : Read attribute BOOLEAN Default Value\n"); + err = TestReadAttributeBooleanDefaultValue_5(); break; case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : sends a Move down command\n"); - err = TestSendsAMoveDownCommand_6(); + ChipLogProgress(chipTool, " ***** Test Step 6 : Write attribute BOOLEAN True\n"); + err = TestWriteAttributeBooleanTrue_6(); break; case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : Wait 2500ms\n"); - err = TestWait2500ms_7(); + ChipLogProgress(chipTool, " ***** Test Step 7 : Read attribute BOOLEAN True\n"); + err = TestReadAttributeBooleanTrue_7(); break; case 8: - ChipLogProgress(chipTool, " ***** Test Step 8 : reads current level attribute from DUT\n"); - err = TestReadsCurrentLevelAttributeFromDut_8(); + ChipLogProgress(chipTool, " ***** Test Step 8 : Write attribute BOOLEAN False\n"); + err = TestWriteAttributeBooleanFalse_8(); break; case 9: - ChipLogProgress(chipTool, " ***** Test Step 9 : Write default move rate attribute from DUT\n"); - err = TestWriteDefaultMoveRateAttributeFromDut_9(); + ChipLogProgress(chipTool, " ***** Test Step 9 : Read attribute BOOLEAN False\n"); + err = TestReadAttributeBooleanFalse_9(); break; case 10: - ChipLogProgress(chipTool, " ***** Test Step 10 : reads default move rate attribute from DUT\n"); - err = TestReadsDefaultMoveRateAttributeFromDut_10(); + ChipLogProgress(chipTool, " ***** Test Step 10 : Read attribute BITMAP8 Default Value\n"); + err = TestReadAttributeBitmap8DefaultValue_10(); break; case 11: - ChipLogProgress(chipTool, " ***** Test Step 11 : sends a Move up command at default move rate\n"); - err = TestSendsAMoveUpCommandAtDefaultMoveRate_11(); + ChipLogProgress(chipTool, " ***** Test Step 11 : Write attribute BITMAP8 Max Value\n"); + err = TestWriteAttributeBitmap8MaxValue_11(); break; case 12: - ChipLogProgress(chipTool, " ***** Test Step 12 : Wait 10ms\n"); - err = TestWait10ms_12(); + ChipLogProgress(chipTool, " ***** Test Step 12 : Read attribute BITMAP8 Max Value\n"); + err = TestReadAttributeBitmap8MaxValue_12(); break; case 13: - ChipLogProgress(chipTool, " ***** Test Step 13 : reads current level attribute from DUT\n"); - err = TestReadsCurrentLevelAttributeFromDut_13(); + ChipLogProgress(chipTool, " ***** Test Step 13 : Write attribute BITMAP8 Min Value\n"); + err = TestWriteAttributeBitmap8MinValue_13(); break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 14; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; - chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; - chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; - chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; - chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; - chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; - chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, this }; - chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; - chip::Callback::Callback mOnSuccessCallback_13{ OnSuccessCallback_13, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint8_t currentLevel) - { - (static_cast(context))->OnSuccessResponse_0(currentLevel); - } - - static void OnFailureCallback_1(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_1(status); - } - - static void OnSuccessCallback_1(void * context, uint8_t maxLevel) - { - (static_cast(context))->OnSuccessResponse_1(maxLevel); - } - - static void OnFailureCallback_4(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_4(status); - } - - static void OnSuccessCallback_4(void * context, uint8_t currentLevel) - { - (static_cast(context))->OnSuccessResponse_4(currentLevel); - } - - static void OnFailureCallback_5(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_5(status); - } - - static void OnSuccessCallback_5(void * context, uint8_t minLevel) - { - (static_cast(context))->OnSuccessResponse_5(minLevel); - } - - static void OnFailureCallback_8(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_8(status); - } - - static void OnSuccessCallback_8(void * context, uint8_t currentLevel) - { - (static_cast(context))->OnSuccessResponse_8(currentLevel); - } - - static void OnFailureCallback_9(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_9(status); - } - - static void OnSuccessCallback_9(void * context, uint8_t defaultMoveRate) - { - (static_cast(context))->OnSuccessResponse_9(defaultMoveRate); - } - - static void OnFailureCallback_10(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_10(status); - } - - static void OnSuccessCallback_10(void * context, uint8_t defaultMoveRate) - { - (static_cast(context))->OnSuccessResponse_10(defaultMoveRate); - } - - static void OnFailureCallback_13(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_13(status); - } - - static void OnSuccessCallback_13(void * context, uint8_t currentLevel) - { - (static_cast(context))->OnSuccessResponse_13(currentLevel); - } - - // - // Tests methods - // - - CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_0() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); - } - - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0(uint8_t currentLevel) - { - VerifyOrReturn(CheckValue("currentLevel", currentLevel, 0)); - NextTest(); - } - - CHIP_ERROR TestReadsMaxLevelAttributeFromDut_1() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeMaxLevel(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); - } - - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_1(uint8_t maxLevel) - { - VerifyOrReturn(CheckValue("maxLevel", maxLevel, 255)); - NextTest(); - } - - CHIP_ERROR TestSendsAMoveUpCommand_2() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::LevelControl::Commands::Move::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::LevelControl::Commands::Move::Type request; - request.moveMode = static_cast(0); - request.rate = 200; - request.optionMask = 1; - request.optionOverride = 1; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); - } - - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_2() { NextTest(); } - - CHIP_ERROR TestWait2500ms_3() { return WaitForMs(2500); } - - CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_4() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); - } - - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_4(uint8_t currentLevel) - { - VerifyOrReturn(CheckValue("currentLevel", currentLevel, 255)); - NextTest(); - } - - CHIP_ERROR TestReadsMinLevelAttributeFromDut_5() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeMinLevel(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); - } - - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_5(uint8_t minLevel) - { - VerifyOrReturn(CheckValue("minLevel", minLevel, 0)); - NextTest(); - } - - CHIP_ERROR TestSendsAMoveDownCommand_6() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::LevelControl::Commands::Move::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::LevelControl::Commands::Move::Type request; - request.moveMode = static_cast(1); - request.rate = 250; - request.optionMask = 1; - request.optionOverride = 1; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_6(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_6(status); - }; - return cluster.InvokeCommand(request, this, success, failure); - } - - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_6() { NextTest(); } - - CHIP_ERROR TestWait2500ms_7() { return WaitForMs(2500); } - - CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_8() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel()); - } - - void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_8(uint8_t currentLevel) - { - VerifyOrReturn(CheckValue("currentLevel", currentLevel, 0)); - NextTest(); - } - - CHIP_ERROR TestWriteDefaultMoveRateAttributeFromDut_9() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint8_t defaultMoveRateArgument = 20; - - return cluster.WriteAttributeDefaultMoveRate(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel(), - defaultMoveRateArgument); - } - - void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_9(uint8_t defaultMoveRate) { NextTest(); } - - CHIP_ERROR TestReadsDefaultMoveRateAttributeFromDut_10() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeDefaultMoveRate(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); - } - - void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_10(uint8_t defaultMoveRate) - { - VerifyOrReturn(CheckValue("defaultMoveRate", defaultMoveRate, 20)); - NextTest(); - } - - CHIP_ERROR TestSendsAMoveUpCommandAtDefaultMoveRate_11() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::LevelControl::Commands::Move::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::LevelControl::Commands::Move::Type request; - request.moveMode = static_cast(1); - request.rate = 255; - request.optionMask = 1; - request.optionOverride = 1; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_11(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_11(status); - }; - return cluster.InvokeCommand(request, this, success, failure); - } - - void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_11() { NextTest(); } - - CHIP_ERROR TestWait10ms_12() { return WaitForMs(10); } - - CHIP_ERROR TestReadsCurrentLevelAttributeFromDut_13() - { - chip::Controller::LevelControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeCurrentLevel(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel()); - } - - void OnFailureResponse_13(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_13(uint8_t currentLevel) - { - VerifyOrReturn(CheckConstraintNotValue("currentLevel", currentLevel, 255)); - NextTest(); - } -}; - -class Test_TC_CC_1_1 : public TestCommand -{ -public: - Test_TC_CC_1_1() : TestCommand("Test_TC_CC_1_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_1_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_1_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, - " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } - - // - // Tests methods - // - - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() - { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t clusterRevisionArgument = 4U; - - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), - clusterRevisionArgument); - } - - void OnFailureResponse_0(uint8_t status) { NextTest(); } - - void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } -}; - -class Test_TC_RH_1_1 : public TestCommand -{ -public: - Test_TC_RH_1_1() : TestCommand("Test_TC_RH_1_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_RH_1_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_RH_1_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, - " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } - - // - // Tests methods - // - - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() - { - chip::Controller::RelativeHumidityMeasurementClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t clusterRevisionArgument = 1U; - - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), - clusterRevisionArgument); - } - - void OnFailureResponse_0(uint8_t status) { NextTest(); } - - void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } -}; - -class Test_TC_MC_1_1 : public TestCommand -{ -public: - Test_TC_MC_1_1() : TestCommand("Test_TC_MC_1_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_MC_1_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_MC_1_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, - " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } - - // - // Tests methods - // - - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() - { - chip::Controller::RelativeHumidityMeasurementClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t clusterRevisionArgument = 1U; - - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), - clusterRevisionArgument); - } - - void OnFailureResponse_0(uint8_t status) { NextTest(); } - - void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } -}; - -class Test_TC_TSTAT_1_1 : public TestCommand -{ -public: - Test_TC_TSTAT_1_1() : TestCommand("Test_TC_TSTAT_1_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_TSTAT_1_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_TSTAT_1_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, - " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } - - // - // Tests methods - // - - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() - { - chip::Controller::ThermostatClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t clusterRevisionArgument = 5U; - - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), - clusterRevisionArgument); - } - - void OnFailureResponse_0(uint8_t status) { NextTest(); } - - void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } -}; - -class Test_TC_PCC_1_1 : public TestCommand -{ -public: - Test_TC_PCC_1_1() : TestCommand("Test_TC_PCC_1_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_PCC_1_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_PCC_1_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, - " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } - - // - // Tests methods - // - - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() - { - chip::Controller::PumpConfigurationAndControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t clusterRevisionArgument = 3U; - - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), - clusterRevisionArgument); - } - - void OnFailureResponse_0(uint8_t status) { NextTest(); } - - void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } -}; - -class Test_TC_TSUIC_1_1 : public TestCommand -{ -public: - Test_TC_TSUIC_1_1() : TestCommand("Test_TC_TSUIC_1_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_TSUIC_1_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_TSUIC_1_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, - " ***** Test Step 0 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } - - // - // Tests methods - // - - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_0() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint16_t clusterRevisionArgument = 2U; - - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), - clusterRevisionArgument); - } - - void OnFailureResponse_0(uint8_t status) { NextTest(); } - - void OnSuccessResponse_0(uint16_t clusterRevision) { ThrowSuccessResponse(); } -}; - -class Test_TC_DIAGTH_1_1 : public TestCommand -{ -public: - Test_TC_DIAGTH_1_1() : TestCommand("Test_TC_DIAGTH_1_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_DIAGTH_1_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_DIAGTH_1_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the global attribute: ClusterRevision\n"); - err = TestReadTheGlobalAttributeClusterRevision_0(); - break; - case 1: - ChipLogProgress(chipTool, - " ***** Test Step 1 : write the default values to mandatory global attribute: ClusterRevision\n"); - err = TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : reads back global attribute: ClusterRevision\n"); - err = TestReadsBackGlobalAttributeClusterRevision_2(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 3; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_0(clusterRevision); - } - - static void OnFailureCallback_1(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_1(status); - } - - static void OnSuccessCallback_1(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_1(clusterRevision); - } - - static void OnFailureCallback_2(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_2(status); - } - - static void OnSuccessCallback_2(void * context, uint16_t clusterRevision) - { - (static_cast(context))->OnSuccessResponse_2(clusterRevision); - } - - // - // Tests methods - // - - CHIP_ERROR TestReadTheGlobalAttributeClusterRevision_0() - { - chip::Controller::ThreadNetworkDiagnosticsClusterTest cluster; - cluster.Associate(mDevice, 0); - - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); - } - - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0(uint16_t clusterRevision) - { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 1U)); - NextTest(); - } - - CHIP_ERROR TestWriteTheDefaultValuesToMandatoryGlobalAttributeClusterRevision_1() - { - chip::Controller::ThreadNetworkDiagnosticsClusterTest cluster; - cluster.Associate(mDevice, 0); - - uint16_t clusterRevisionArgument = 1U; - - return cluster.WriteAttributeClusterRevision(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel(), - clusterRevisionArgument); - } - - void OnFailureResponse_1(uint8_t status) { NextTest(); } - - void OnSuccessResponse_1(uint16_t clusterRevision) { ThrowSuccessResponse(); } - - CHIP_ERROR TestReadsBackGlobalAttributeClusterRevision_2() - { - chip::Controller::ThreadNetworkDiagnosticsClusterTest cluster; - cluster.Associate(mDevice, 0); - - return cluster.ReadAttributeClusterRevision(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); - } - - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_2(uint16_t clusterRevision) - { - VerifyOrReturn(CheckValue("clusterRevision", clusterRevision, 1U)); - NextTest(); - } -}; - -class Test_TC_TM_2_1 : public TestCommand -{ -public: - Test_TC_TM_2_1() : TestCommand("Test_TC_TM_2_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_TM_2_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_TM_2_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the mandatory attribute: MeasuredValue\n"); - err = TestReadTheMandatoryAttributeMeasuredValue_0(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 1; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, int16_t measuredValue) - { - (static_cast(context))->OnSuccessResponse_0(measuredValue); - } - - // - // Tests methods - // - - CHIP_ERROR TestReadTheMandatoryAttributeMeasuredValue_0() - { - chip::Controller::TemperatureMeasurementClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeMeasuredValue(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); - } - - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0(int16_t measuredValue) - { - VerifyOrReturn(CheckConstraintType("measuredValue", "", "int16")); - NextTest(); - } -}; - -class Test_TC_TSUIC_2_1 : public TestCommand -{ -public: - Test_TC_TSUIC_2_1() : TestCommand("Test_TC_TSUIC_2_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override - { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_TSUIC_2_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_TSUIC_2_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the mandatory attribute: TemperatureDisplayMode\n"); - err = TestReadTheMandatoryAttributeTemperatureDisplayMode_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : read the mandatory attribute: TemperatureDisplayMode\n"); - err = TestReadTheMandatoryAttributeTemperatureDisplayMode_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : write to the mandatory attribute: TemperatureDisplayMode\n"); - err = TestWriteToTheMandatoryAttributeTemperatureDisplayMode_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : read the mandatory attribute: TemperatureDisplayMode\n"); - err = TestReadTheMandatoryAttributeTemperatureDisplayMode_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : read the mandatory attribute: TemperatureDisplayMode\n"); - err = TestReadTheMandatoryAttributeTemperatureDisplayMode_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : read the mandatory attribute: KeypadLockout\n"); - err = TestReadTheMandatoryAttributeKeypadLockout_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : read the mandatory attribute: KeypadLockout\n"); - err = TestReadTheMandatoryAttributeKeypadLockout_6(); - break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : write to the mandatory attribute: KeypadLockout\n"); - err = TestWriteToTheMandatoryAttributeKeypadLockout_7(); - break; - case 8: - ChipLogProgress(chipTool, " ***** Test Step 8 : read the mandatory attribute: KeypadLockout\n"); - err = TestReadTheMandatoryAttributeKeypadLockout_8(); - break; - case 9: - ChipLogProgress(chipTool, " ***** Test Step 9 : read the mandatory attribute: KeypadLockout\n"); - err = TestReadTheMandatoryAttributeKeypadLockout_9(); - break; - case 10: - ChipLogProgress(chipTool, " ***** Test Step 10 : read the optional attribute: ScheduleProgrammingVisibility\n"); - err = TestReadTheOptionalAttributeScheduleProgrammingVisibility_10(); - break; - case 11: - ChipLogProgress(chipTool, " ***** Test Step 11 : read the optional attribute: ScheduleProgrammingVisibility\n"); - err = TestReadTheOptionalAttributeScheduleProgrammingVisibility_11(); - break; - case 12: - ChipLogProgress(chipTool, " ***** Test Step 12 : write to the mandatory attribute: ScheduleProgrammingVisibility\n"); - err = TestWriteToTheMandatoryAttributeScheduleProgrammingVisibility_12(); - break; - case 13: - ChipLogProgress(chipTool, " ***** Test Step 13 : read the optional attribute: ScheduleProgrammingVisibility\n"); - err = TestReadTheOptionalAttributeScheduleProgrammingVisibility_13(); - break; - case 14: - ChipLogProgress(chipTool, " ***** Test Step 14 : read the optional attribute: ScheduleProgrammingVisibility\n"); - err = TestReadTheOptionalAttributeScheduleProgrammingVisibility_14(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 15; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, - this }; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, - this }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, - this }; - chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, - this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, - this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; - chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; - chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; - chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; - chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; - chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; - chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; - chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; - chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; - chip::Callback::Callback mOnSuccessCallback_10{ - OnSuccessCallback_10, this - }; - chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; - chip::Callback::Callback mOnSuccessCallback_11{ - OnSuccessCallback_11, this - }; - chip::Callback::Callback mOnFailureCallback_12{ OnFailureCallback_12, this }; - chip::Callback::Callback mOnSuccessCallback_12{ - OnSuccessCallback_12, this - }; - chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; - chip::Callback::Callback mOnSuccessCallback_13{ - OnSuccessCallback_13, this - }; - chip::Callback::Callback mOnFailureCallback_14{ OnFailureCallback_14, this }; - chip::Callback::Callback mOnSuccessCallback_14{ - OnSuccessCallback_14, this - }; - - static void OnFailureCallback_0(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_0(status); - } - - static void OnSuccessCallback_0(void * context, uint8_t temperatureDisplayMode) - { - (static_cast(context))->OnSuccessResponse_0(temperatureDisplayMode); - } - - static void OnFailureCallback_1(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_1(status); - } - - static void OnSuccessCallback_1(void * context, uint8_t temperatureDisplayMode) - { - (static_cast(context))->OnSuccessResponse_1(temperatureDisplayMode); - } - - static void OnFailureCallback_2(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_2(status); - } - - static void OnSuccessCallback_2(void * context, uint8_t temperatureDisplayMode) - { - (static_cast(context))->OnSuccessResponse_2(temperatureDisplayMode); - } - - static void OnFailureCallback_3(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_3(status); - } - - static void OnSuccessCallback_3(void * context, uint8_t temperatureDisplayMode) - { - (static_cast(context))->OnSuccessResponse_3(temperatureDisplayMode); - } - - static void OnFailureCallback_4(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_4(status); - } - - static void OnSuccessCallback_4(void * context, uint8_t temperatureDisplayMode) - { - (static_cast(context))->OnSuccessResponse_4(temperatureDisplayMode); - } - - static void OnFailureCallback_5(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_5(status); - } - - static void OnSuccessCallback_5(void * context, uint8_t keypadLockout) - { - (static_cast(context))->OnSuccessResponse_5(keypadLockout); - } - - static void OnFailureCallback_6(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_6(status); - } - - static void OnSuccessCallback_6(void * context, uint8_t keypadLockout) - { - (static_cast(context))->OnSuccessResponse_6(keypadLockout); - } - - static void OnFailureCallback_7(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_7(status); - } - - static void OnSuccessCallback_7(void * context, uint8_t keypadLockout) - { - (static_cast(context))->OnSuccessResponse_7(keypadLockout); - } - - static void OnFailureCallback_8(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_8(status); - } - - static void OnSuccessCallback_8(void * context, uint8_t keypadLockout) - { - (static_cast(context))->OnSuccessResponse_8(keypadLockout); - } - - static void OnFailureCallback_9(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_9(status); - } - - static void OnSuccessCallback_9(void * context, uint8_t keypadLockout) - { - (static_cast(context))->OnSuccessResponse_9(keypadLockout); - } - - static void OnFailureCallback_10(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_10(status); - } - - static void OnSuccessCallback_10(void * context, uint8_t scheduleProgrammingVisibility) - { - (static_cast(context))->OnSuccessResponse_10(scheduleProgrammingVisibility); - } - - static void OnFailureCallback_11(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_11(status); - } - - static void OnSuccessCallback_11(void * context, uint8_t scheduleProgrammingVisibility) - { - (static_cast(context))->OnSuccessResponse_11(scheduleProgrammingVisibility); - } - - static void OnFailureCallback_12(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_12(status); - } - - static void OnSuccessCallback_12(void * context, uint8_t scheduleProgrammingVisibility) - { - (static_cast(context))->OnSuccessResponse_12(scheduleProgrammingVisibility); - } - - static void OnFailureCallback_13(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_13(status); - } - - static void OnSuccessCallback_13(void * context, uint8_t scheduleProgrammingVisibility) - { - (static_cast(context))->OnSuccessResponse_13(scheduleProgrammingVisibility); - } - - static void OnFailureCallback_14(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_14(status); - } - - static void OnSuccessCallback_14(void * context, uint8_t scheduleProgrammingVisibility) - { - (static_cast(context))->OnSuccessResponse_14(scheduleProgrammingVisibility); - } - - // - // Tests methods - // - - CHIP_ERROR TestReadTheMandatoryAttributeTemperatureDisplayMode_0() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeTemperatureDisplayMode(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); - } - - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0(uint8_t temperatureDisplayMode) - { - VerifyOrReturn(CheckValue("temperatureDisplayMode", temperatureDisplayMode, 0)); - NextTest(); - } - - CHIP_ERROR TestReadTheMandatoryAttributeTemperatureDisplayMode_1() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeTemperatureDisplayMode(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); - } - - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_1(uint8_t temperatureDisplayMode) - { - VerifyOrReturn(CheckConstraintType("temperatureDisplayMode", "", "enum8")); - NextTest(); - } - - CHIP_ERROR TestWriteToTheMandatoryAttributeTemperatureDisplayMode_2() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint8_t temperatureDisplayModeArgument = 0; - - return cluster.WriteAttributeTemperatureDisplayMode(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel(), - temperatureDisplayModeArgument); - } - - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_2(uint8_t temperatureDisplayMode) { NextTest(); } - - CHIP_ERROR TestReadTheMandatoryAttributeTemperatureDisplayMode_3() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeTemperatureDisplayMode(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); - } - - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_3(uint8_t temperatureDisplayMode) - { - VerifyOrReturn(CheckValue("temperatureDisplayMode", temperatureDisplayMode, 0)); - NextTest(); - } - - CHIP_ERROR TestReadTheMandatoryAttributeTemperatureDisplayMode_4() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeTemperatureDisplayMode(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); - } - - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_4(uint8_t temperatureDisplayMode) - { - VerifyOrReturn(CheckConstraintType("temperatureDisplayMode", "", "enum8")); - NextTest(); - } - - CHIP_ERROR TestReadTheMandatoryAttributeKeypadLockout_5() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeKeypadLockout(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); - } - - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_5(uint8_t keypadLockout) - { - VerifyOrReturn(CheckValue("keypadLockout", keypadLockout, 0)); - NextTest(); - } - - CHIP_ERROR TestReadTheMandatoryAttributeKeypadLockout_6() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeKeypadLockout(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); - } - - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_6(uint8_t keypadLockout) - { - VerifyOrReturn(CheckConstraintType("keypadLockout", "", "enum8")); - NextTest(); - } - - CHIP_ERROR TestWriteToTheMandatoryAttributeKeypadLockout_7() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint8_t keypadLockoutArgument = 0; - - return cluster.WriteAttributeKeypadLockout(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel(), - keypadLockoutArgument); - } - - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_7(uint8_t keypadLockout) { NextTest(); } - - CHIP_ERROR TestReadTheMandatoryAttributeKeypadLockout_8() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeKeypadLockout(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel()); - } - - void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_8(uint8_t keypadLockout) - { - VerifyOrReturn(CheckValue("keypadLockout", keypadLockout, 0)); - NextTest(); - } - - CHIP_ERROR TestReadTheMandatoryAttributeKeypadLockout_9() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeKeypadLockout(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel()); - } - - void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_9(uint8_t keypadLockout) - { - VerifyOrReturn(CheckConstraintType("keypadLockout", "", "enum8")); - NextTest(); - } - - CHIP_ERROR TestReadTheOptionalAttributeScheduleProgrammingVisibility_10() - { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); + case 14: + ChipLogProgress(chipTool, " ***** Test Step 14 : Read attribute BITMAP8 Min Value\n"); + err = TestReadAttributeBitmap8MinValue_14(); + break; + case 15: + ChipLogProgress(chipTool, " ***** Test Step 15 : Read attribute BITMAP16 Default Value\n"); + err = TestReadAttributeBitmap16DefaultValue_15(); + break; + case 16: + ChipLogProgress(chipTool, " ***** Test Step 16 : Write attribute BITMAP16 Max Value\n"); + err = TestWriteAttributeBitmap16MaxValue_16(); + break; + case 17: + ChipLogProgress(chipTool, " ***** Test Step 17 : Read attribute BITMAP16 Max Value\n"); + err = TestReadAttributeBitmap16MaxValue_17(); + break; + case 18: + ChipLogProgress(chipTool, " ***** Test Step 18 : Write attribute BITMAP16 Min Value\n"); + err = TestWriteAttributeBitmap16MinValue_18(); + break; + case 19: + ChipLogProgress(chipTool, " ***** Test Step 19 : Read attribute BITMAP16 Min Value\n"); + err = TestReadAttributeBitmap16MinValue_19(); + break; + case 20: + ChipLogProgress(chipTool, " ***** Test Step 20 : Read attribute BITMAP32 Default Value\n"); + err = TestReadAttributeBitmap32DefaultValue_20(); + break; + case 21: + ChipLogProgress(chipTool, " ***** Test Step 21 : Write attribute BITMAP32 Max Value\n"); + err = TestWriteAttributeBitmap32MaxValue_21(); + break; + case 22: + ChipLogProgress(chipTool, " ***** Test Step 22 : Read attribute BITMAP32 Max Value\n"); + err = TestReadAttributeBitmap32MaxValue_22(); + break; + case 23: + ChipLogProgress(chipTool, " ***** Test Step 23 : Write attribute BITMAP32 Min Value\n"); + err = TestWriteAttributeBitmap32MinValue_23(); + break; + case 24: + ChipLogProgress(chipTool, " ***** Test Step 24 : Read attribute BITMAP32 Min Value\n"); + err = TestReadAttributeBitmap32MinValue_24(); + break; + case 25: + ChipLogProgress(chipTool, " ***** Test Step 25 : Read attribute BITMAP64 Default Value\n"); + err = TestReadAttributeBitmap64DefaultValue_25(); + break; + case 26: + ChipLogProgress(chipTool, " ***** Test Step 26 : Write attribute BITMAP64 Max Value\n"); + err = TestWriteAttributeBitmap64MaxValue_26(); + break; + case 27: + ChipLogProgress(chipTool, " ***** Test Step 27 : Read attribute BITMAP64 Max Value\n"); + err = TestReadAttributeBitmap64MaxValue_27(); + break; + case 28: + ChipLogProgress(chipTool, " ***** Test Step 28 : Write attribute BITMAP64 Min Value\n"); + err = TestWriteAttributeBitmap64MinValue_28(); + break; + case 29: + ChipLogProgress(chipTool, " ***** Test Step 29 : Read attribute BITMAP64 Min Value\n"); + err = TestReadAttributeBitmap64MinValue_29(); + break; + case 30: + ChipLogProgress(chipTool, " ***** Test Step 30 : Read attribute INT8U Default Value\n"); + err = TestReadAttributeInt8uDefaultValue_30(); + break; + case 31: + ChipLogProgress(chipTool, " ***** Test Step 31 : Write attribute INT8U Max Value\n"); + err = TestWriteAttributeInt8uMaxValue_31(); + break; + case 32: + ChipLogProgress(chipTool, " ***** Test Step 32 : Read attribute INT8U Max Value\n"); + err = TestReadAttributeInt8uMaxValue_32(); + break; + case 33: + ChipLogProgress(chipTool, " ***** Test Step 33 : Write attribute INT8U Min Value\n"); + err = TestWriteAttributeInt8uMinValue_33(); + break; + case 34: + ChipLogProgress(chipTool, " ***** Test Step 34 : Read attribute INT8U Min Value\n"); + err = TestReadAttributeInt8uMinValue_34(); + break; + case 35: + ChipLogProgress(chipTool, " ***** Test Step 35 : Read attribute INT16U Default Value\n"); + err = TestReadAttributeInt16uDefaultValue_35(); + break; + case 36: + ChipLogProgress(chipTool, " ***** Test Step 36 : Write attribute INT16U Max Value\n"); + err = TestWriteAttributeInt16uMaxValue_36(); + break; + case 37: + ChipLogProgress(chipTool, " ***** Test Step 37 : Read attribute INT16U Max Value\n"); + err = TestReadAttributeInt16uMaxValue_37(); + break; + case 38: + ChipLogProgress(chipTool, " ***** Test Step 38 : Write attribute INT16U Min Value\n"); + err = TestWriteAttributeInt16uMinValue_38(); + break; + case 39: + ChipLogProgress(chipTool, " ***** Test Step 39 : Read attribute INT16U Min Value\n"); + err = TestReadAttributeInt16uMinValue_39(); + break; + case 40: + ChipLogProgress(chipTool, " ***** Test Step 40 : Read attribute INT32U Default Value\n"); + err = TestReadAttributeInt32uDefaultValue_40(); + break; + case 41: + ChipLogProgress(chipTool, " ***** Test Step 41 : Write attribute INT32U Max Value\n"); + err = TestWriteAttributeInt32uMaxValue_41(); + break; + case 42: + ChipLogProgress(chipTool, " ***** Test Step 42 : Read attribute INT32U Max Value\n"); + err = TestReadAttributeInt32uMaxValue_42(); + break; + case 43: + ChipLogProgress(chipTool, " ***** Test Step 43 : Write attribute INT32U Min Value\n"); + err = TestWriteAttributeInt32uMinValue_43(); + break; + case 44: + ChipLogProgress(chipTool, " ***** Test Step 44 : Read attribute INT32U Min Value\n"); + err = TestReadAttributeInt32uMinValue_44(); + break; + case 45: + ChipLogProgress(chipTool, " ***** Test Step 45 : Read attribute INT64U Default Value\n"); + err = TestReadAttributeInt64uDefaultValue_45(); + break; + case 46: + ChipLogProgress(chipTool, " ***** Test Step 46 : Write attribute INT64U Max Value\n"); + err = TestWriteAttributeInt64uMaxValue_46(); + break; + case 47: + ChipLogProgress(chipTool, " ***** Test Step 47 : Read attribute INT64U Max Value\n"); + err = TestReadAttributeInt64uMaxValue_47(); + break; + case 48: + ChipLogProgress(chipTool, " ***** Test Step 48 : Write attribute INT64U Min Value\n"); + err = TestWriteAttributeInt64uMinValue_48(); + break; + case 49: + ChipLogProgress(chipTool, " ***** Test Step 49 : Read attribute INT64U Min Value\n"); + err = TestReadAttributeInt64uMinValue_49(); + break; + case 50: + ChipLogProgress(chipTool, " ***** Test Step 50 : Read attribute INT8S Default Value\n"); + err = TestReadAttributeInt8sDefaultValue_50(); + break; + case 51: + ChipLogProgress(chipTool, " ***** Test Step 51 : Write attribute INT8S Max Value\n"); + err = TestWriteAttributeInt8sMaxValue_51(); + break; + case 52: + ChipLogProgress(chipTool, " ***** Test Step 52 : Read attribute INT8S Max Value\n"); + err = TestReadAttributeInt8sMaxValue_52(); + break; + case 53: + ChipLogProgress(chipTool, " ***** Test Step 53 : Write attribute INT8S Min Value\n"); + err = TestWriteAttributeInt8sMinValue_53(); + break; + case 54: + ChipLogProgress(chipTool, " ***** Test Step 54 : Read attribute INT8S Min Value\n"); + err = TestReadAttributeInt8sMinValue_54(); + break; + case 55: + ChipLogProgress(chipTool, " ***** Test Step 55 : Write attribute INT8S Default Value\n"); + err = TestWriteAttributeInt8sDefaultValue_55(); + break; + case 56: + ChipLogProgress(chipTool, " ***** Test Step 56 : Read attribute INT8S Default Value\n"); + err = TestReadAttributeInt8sDefaultValue_56(); + break; + case 57: + ChipLogProgress(chipTool, " ***** Test Step 57 : Read attribute INT16S Default Value\n"); + err = TestReadAttributeInt16sDefaultValue_57(); + break; + case 58: + ChipLogProgress(chipTool, " ***** Test Step 58 : Write attribute INT16S Max Value\n"); + err = TestWriteAttributeInt16sMaxValue_58(); + break; + case 59: + ChipLogProgress(chipTool, " ***** Test Step 59 : Read attribute INT16S Max Value\n"); + err = TestReadAttributeInt16sMaxValue_59(); + break; + case 60: + ChipLogProgress(chipTool, " ***** Test Step 60 : Write attribute INT16S Min Value\n"); + err = TestWriteAttributeInt16sMinValue_60(); + break; + case 61: + ChipLogProgress(chipTool, " ***** Test Step 61 : Read attribute INT16S Min Value\n"); + err = TestReadAttributeInt16sMinValue_61(); + break; + case 62: + ChipLogProgress(chipTool, " ***** Test Step 62 : Write attribute INT16S Default Value\n"); + err = TestWriteAttributeInt16sDefaultValue_62(); + break; + case 63: + ChipLogProgress(chipTool, " ***** Test Step 63 : Read attribute INT16S Default Value\n"); + err = TestReadAttributeInt16sDefaultValue_63(); + break; + case 64: + ChipLogProgress(chipTool, " ***** Test Step 64 : Read attribute INT32S Default Value\n"); + err = TestReadAttributeInt32sDefaultValue_64(); + break; + case 65: + ChipLogProgress(chipTool, " ***** Test Step 65 : Write attribute INT32S Max Value\n"); + err = TestWriteAttributeInt32sMaxValue_65(); + break; + case 66: + ChipLogProgress(chipTool, " ***** Test Step 66 : Read attribute INT32S Max Value\n"); + err = TestReadAttributeInt32sMaxValue_66(); + break; + case 67: + ChipLogProgress(chipTool, " ***** Test Step 67 : Write attribute INT32S Min Value\n"); + err = TestWriteAttributeInt32sMinValue_67(); + break; + case 68: + ChipLogProgress(chipTool, " ***** Test Step 68 : Read attribute INT32S Min Value\n"); + err = TestReadAttributeInt32sMinValue_68(); + break; + case 69: + ChipLogProgress(chipTool, " ***** Test Step 69 : Write attribute INT32S Default Value\n"); + err = TestWriteAttributeInt32sDefaultValue_69(); + break; + case 70: + ChipLogProgress(chipTool, " ***** Test Step 70 : Read attribute INT32S Default Value\n"); + err = TestReadAttributeInt32sDefaultValue_70(); + break; + case 71: + ChipLogProgress(chipTool, " ***** Test Step 71 : Read attribute INT64S Default Value\n"); + err = TestReadAttributeInt64sDefaultValue_71(); + break; + case 72: + ChipLogProgress(chipTool, " ***** Test Step 72 : Write attribute INT64S Max Value\n"); + err = TestWriteAttributeInt64sMaxValue_72(); + break; + case 73: + ChipLogProgress(chipTool, " ***** Test Step 73 : Read attribute INT64S Max Value\n"); + err = TestReadAttributeInt64sMaxValue_73(); + break; + case 74: + ChipLogProgress(chipTool, " ***** Test Step 74 : Write attribute INT64S Min Value\n"); + err = TestWriteAttributeInt64sMinValue_74(); + break; + case 75: + ChipLogProgress(chipTool, " ***** Test Step 75 : Read attribute INT64S Min Value\n"); + err = TestReadAttributeInt64sMinValue_75(); + break; + case 76: + ChipLogProgress(chipTool, " ***** Test Step 76 : Write attribute INT64S Default Value\n"); + err = TestWriteAttributeInt64sDefaultValue_76(); + break; + case 77: + ChipLogProgress(chipTool, " ***** Test Step 77 : Read attribute INT64S Default Value\n"); + err = TestReadAttributeInt64sDefaultValue_77(); + break; + case 78: + ChipLogProgress(chipTool, " ***** Test Step 78 : Read attribute ENUM8 Default Value\n"); + err = TestReadAttributeEnum8DefaultValue_78(); + break; + case 79: + ChipLogProgress(chipTool, " ***** Test Step 79 : Write attribute ENUM8 Max Value\n"); + err = TestWriteAttributeEnum8MaxValue_79(); + break; + case 80: + ChipLogProgress(chipTool, " ***** Test Step 80 : Read attribute ENUM8 Max Value\n"); + err = TestReadAttributeEnum8MaxValue_80(); + break; + case 81: + ChipLogProgress(chipTool, " ***** Test Step 81 : Write attribute ENUM8 Min Value\n"); + err = TestWriteAttributeEnum8MinValue_81(); + break; + case 82: + ChipLogProgress(chipTool, " ***** Test Step 82 : Read attribute ENUM8 Min Value\n"); + err = TestReadAttributeEnum8MinValue_82(); + break; + case 83: + ChipLogProgress(chipTool, " ***** Test Step 83 : Read attribute ENUM16 Default Value\n"); + err = TestReadAttributeEnum16DefaultValue_83(); + break; + case 84: + ChipLogProgress(chipTool, " ***** Test Step 84 : Write attribute ENUM16 Max Value\n"); + err = TestWriteAttributeEnum16MaxValue_84(); + break; + case 85: + ChipLogProgress(chipTool, " ***** Test Step 85 : Read attribute ENUM16 Max Value\n"); + err = TestReadAttributeEnum16MaxValue_85(); + break; + case 86: + ChipLogProgress(chipTool, " ***** Test Step 86 : Write attribute ENUM16 Min Value\n"); + err = TestWriteAttributeEnum16MinValue_86(); + break; + case 87: + ChipLogProgress(chipTool, " ***** Test Step 87 : Read attribute ENUM16 Min Value\n"); + err = TestReadAttributeEnum16MinValue_87(); + break; + case 88: + ChipLogProgress(chipTool, " ***** Test Step 88 : Read attribute OCTET_STRING Default Value\n"); + err = TestReadAttributeOctetStringDefaultValue_88(); + break; + case 89: + ChipLogProgress(chipTool, " ***** Test Step 89 : Write attribute OCTET_STRING\n"); + err = TestWriteAttributeOctetString_89(); + break; + case 90: + ChipLogProgress(chipTool, " ***** Test Step 90 : Read attribute OCTET_STRING\n"); + err = TestReadAttributeOctetString_90(); + break; + case 91: + ChipLogProgress(chipTool, " ***** Test Step 91 : Write attribute OCTET_STRING\n"); + err = TestWriteAttributeOctetString_91(); + break; + case 92: + ChipLogProgress(chipTool, " ***** Test Step 92 : Read attribute OCTET_STRING\n"); + err = TestReadAttributeOctetString_92(); + break; + case 93: + ChipLogProgress(chipTool, " ***** Test Step 93 : Write attribute OCTET_STRING\n"); + err = TestWriteAttributeOctetString_93(); + break; + case 94: + ChipLogProgress(chipTool, " ***** Test Step 94 : Read attribute LONG_OCTET_STRING Default Value\n"); + err = TestReadAttributeLongOctetStringDefaultValue_94(); + break; + case 95: + ChipLogProgress(chipTool, " ***** Test Step 95 : Write attribute LONG_OCTET_STRING\n"); + err = TestWriteAttributeLongOctetString_95(); + break; + case 96: + ChipLogProgress(chipTool, " ***** Test Step 96 : Read attribute LONG_OCTET_STRING\n"); + err = TestReadAttributeLongOctetString_96(); + break; + case 97: + ChipLogProgress(chipTool, " ***** Test Step 97 : Write attribute LONG_OCTET_STRING\n"); + err = TestWriteAttributeLongOctetString_97(); + break; + case 98: + ChipLogProgress(chipTool, " ***** Test Step 98 : Read attribute CHAR_STRING Default Value\n"); + err = TestReadAttributeCharStringDefaultValue_98(); + break; + case 99: + ChipLogProgress(chipTool, " ***** Test Step 99 : Write attribute CHAR_STRING\n"); + err = TestWriteAttributeCharString_99(); + break; + case 100: + ChipLogProgress(chipTool, " ***** Test Step 100 : Write attribute CHAR_STRING - Value too long\n"); + err = TestWriteAttributeCharStringValueTooLong_100(); + break; + case 101: + ChipLogProgress(chipTool, " ***** Test Step 101 : Write attribute CHAR_STRING - Empty\n"); + err = TestWriteAttributeCharStringEmpty_101(); + break; + case 102: + ChipLogProgress(chipTool, " ***** Test Step 102 : Read attribute LONG_CHAR_STRING Default Value\n"); + err = TestReadAttributeLongCharStringDefaultValue_102(); + break; + case 103: + ChipLogProgress(chipTool, " ***** Test Step 103 : Write attribute LONG_CHAR_STRING\n"); + err = TestWriteAttributeLongCharString_103(); + break; + case 104: + ChipLogProgress(chipTool, " ***** Test Step 104 : Read attribute LONG_CHAR_STRING\n"); + err = TestReadAttributeLongCharString_104(); + break; + case 105: + ChipLogProgress(chipTool, " ***** Test Step 105 : Write attribute LONG_CHAR_STRING\n"); + err = TestWriteAttributeLongCharString_105(); + break; + case 106: + ChipLogProgress(chipTool, " ***** Test Step 106 : Read attribute LIST\n"); + err = TestReadAttributeList_106(); + break; + case 107: + ChipLogProgress(chipTool, " ***** Test Step 107 : Read attribute LIST_OCTET_STRING\n"); + err = TestReadAttributeListOctetString_107(); + break; + case 108: + ChipLogProgress(chipTool, " ***** Test Step 108 : Read attribute LIST_STRUCT_OCTET_STRING\n"); + err = TestReadAttributeListStructOctetString_108(); + break; + case 109: + ChipLogProgress(chipTool, " ***** Test Step 109 : Read attribute EPOCH_US Default Value\n"); + err = TestReadAttributeEpochUsDefaultValue_109(); + break; + case 110: + ChipLogProgress(chipTool, " ***** Test Step 110 : Write attribute EPOCH_US Max Value\n"); + err = TestWriteAttributeEpochUsMaxValue_110(); + break; + case 111: + ChipLogProgress(chipTool, " ***** Test Step 111 : Read attribute EPOCH_US Max Value\n"); + err = TestReadAttributeEpochUsMaxValue_111(); + break; + case 112: + ChipLogProgress(chipTool, " ***** Test Step 112 : Write attribute EPOCH_US Min Value\n"); + err = TestWriteAttributeEpochUsMinValue_112(); + break; + case 113: + ChipLogProgress(chipTool, " ***** Test Step 113 : Read attribute EPOCH_US Min Value\n"); + err = TestReadAttributeEpochUsMinValue_113(); + break; + case 114: + ChipLogProgress(chipTool, " ***** Test Step 114 : Read attribute EPOCH_S Default Value\n"); + err = TestReadAttributeEpochSDefaultValue_114(); + break; + case 115: + ChipLogProgress(chipTool, " ***** Test Step 115 : Write attribute EPOCH_S Max Value\n"); + err = TestWriteAttributeEpochSMaxValue_115(); + break; + case 116: + ChipLogProgress(chipTool, " ***** Test Step 116 : Read attribute EPOCH_S Max Value\n"); + err = TestReadAttributeEpochSMaxValue_116(); + break; + case 117: + ChipLogProgress(chipTool, " ***** Test Step 117 : Write attribute EPOCH_S Min Value\n"); + err = TestWriteAttributeEpochSMinValue_117(); + break; + case 118: + ChipLogProgress(chipTool, " ***** Test Step 118 : Read attribute EPOCH_S Min Value\n"); + err = TestReadAttributeEpochSMinValue_118(); + break; + case 119: + ChipLogProgress(chipTool, " ***** Test Step 119 : Read attribute UNSUPPORTED\n"); + err = TestReadAttributeUnsupported_119(); + break; + case 120: + ChipLogProgress(chipTool, " ***** Test Step 120 : Writeattribute UNSUPPORTED\n"); + err = TestWriteattributeUnsupported_120(); + break; + case 121: + ChipLogProgress(chipTool, " ***** Test Step 121 : Send Test Command to unsupported endpoint\n"); + err = TestSendTestCommandToUnsupportedEndpoint_121(); + break; + } - return cluster.ReadAttributeScheduleProgrammingVisibility(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 122; - void OnSuccessResponse_10(uint8_t scheduleProgrammingVisibility) - { - VerifyOrReturn(CheckValue("scheduleProgrammingVisibility", scheduleProgrammingVisibility, 0)); - NextTest(); - } + chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; + chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; + chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; + chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; + chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; + chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; + chip::Callback::Callback mOnFailureCallback_9{ OnFailureCallback_9, this }; + chip::Callback::Callback mOnSuccessCallback_9{ OnSuccessCallback_9, this }; + chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; + chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, this }; + chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; + chip::Callback::Callback mOnSuccessCallback_11{ OnSuccessCallback_11, this }; + chip::Callback::Callback mOnFailureCallback_12{ OnFailureCallback_12, this }; + chip::Callback::Callback mOnSuccessCallback_12{ OnSuccessCallback_12, this }; + chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; + chip::Callback::Callback mOnSuccessCallback_13{ OnSuccessCallback_13, this }; + chip::Callback::Callback mOnFailureCallback_14{ OnFailureCallback_14, this }; + chip::Callback::Callback mOnSuccessCallback_14{ OnSuccessCallback_14, this }; + chip::Callback::Callback mOnFailureCallback_15{ OnFailureCallback_15, this }; + chip::Callback::Callback mOnSuccessCallback_15{ OnSuccessCallback_15, this }; + chip::Callback::Callback mOnFailureCallback_16{ OnFailureCallback_16, this }; + chip::Callback::Callback mOnSuccessCallback_16{ OnSuccessCallback_16, this }; + chip::Callback::Callback mOnFailureCallback_17{ OnFailureCallback_17, this }; + chip::Callback::Callback mOnSuccessCallback_17{ OnSuccessCallback_17, this }; + chip::Callback::Callback mOnFailureCallback_18{ OnFailureCallback_18, this }; + chip::Callback::Callback mOnSuccessCallback_18{ OnSuccessCallback_18, this }; + chip::Callback::Callback mOnFailureCallback_19{ OnFailureCallback_19, this }; + chip::Callback::Callback mOnSuccessCallback_19{ OnSuccessCallback_19, this }; + chip::Callback::Callback mOnFailureCallback_20{ OnFailureCallback_20, this }; + chip::Callback::Callback mOnSuccessCallback_20{ OnSuccessCallback_20, this }; + chip::Callback::Callback mOnFailureCallback_21{ OnFailureCallback_21, this }; + chip::Callback::Callback mOnSuccessCallback_21{ OnSuccessCallback_21, this }; + chip::Callback::Callback mOnFailureCallback_22{ OnFailureCallback_22, this }; + chip::Callback::Callback mOnSuccessCallback_22{ OnSuccessCallback_22, this }; + chip::Callback::Callback mOnFailureCallback_23{ OnFailureCallback_23, this }; + chip::Callback::Callback mOnSuccessCallback_23{ OnSuccessCallback_23, this }; + chip::Callback::Callback mOnFailureCallback_24{ OnFailureCallback_24, this }; + chip::Callback::Callback mOnSuccessCallback_24{ OnSuccessCallback_24, this }; + chip::Callback::Callback mOnFailureCallback_25{ OnFailureCallback_25, this }; + chip::Callback::Callback mOnSuccessCallback_25{ OnSuccessCallback_25, this }; + chip::Callback::Callback mOnFailureCallback_26{ OnFailureCallback_26, this }; + chip::Callback::Callback mOnSuccessCallback_26{ OnSuccessCallback_26, this }; + chip::Callback::Callback mOnFailureCallback_27{ OnFailureCallback_27, this }; + chip::Callback::Callback mOnSuccessCallback_27{ OnSuccessCallback_27, this }; + chip::Callback::Callback mOnFailureCallback_28{ OnFailureCallback_28, this }; + chip::Callback::Callback mOnSuccessCallback_28{ OnSuccessCallback_28, this }; + chip::Callback::Callback mOnFailureCallback_29{ OnFailureCallback_29, this }; + chip::Callback::Callback mOnSuccessCallback_29{ OnSuccessCallback_29, this }; + chip::Callback::Callback mOnFailureCallback_30{ OnFailureCallback_30, this }; + chip::Callback::Callback mOnSuccessCallback_30{ OnSuccessCallback_30, this }; + chip::Callback::Callback mOnFailureCallback_31{ OnFailureCallback_31, this }; + chip::Callback::Callback mOnSuccessCallback_31{ OnSuccessCallback_31, this }; + chip::Callback::Callback mOnFailureCallback_32{ OnFailureCallback_32, this }; + chip::Callback::Callback mOnSuccessCallback_32{ OnSuccessCallback_32, this }; + chip::Callback::Callback mOnFailureCallback_33{ OnFailureCallback_33, this }; + chip::Callback::Callback mOnSuccessCallback_33{ OnSuccessCallback_33, this }; + chip::Callback::Callback mOnFailureCallback_34{ OnFailureCallback_34, this }; + chip::Callback::Callback mOnSuccessCallback_34{ OnSuccessCallback_34, this }; + chip::Callback::Callback mOnFailureCallback_35{ OnFailureCallback_35, this }; + chip::Callback::Callback mOnSuccessCallback_35{ OnSuccessCallback_35, this }; + chip::Callback::Callback mOnFailureCallback_36{ OnFailureCallback_36, this }; + chip::Callback::Callback mOnSuccessCallback_36{ OnSuccessCallback_36, this }; + chip::Callback::Callback mOnFailureCallback_37{ OnFailureCallback_37, this }; + chip::Callback::Callback mOnSuccessCallback_37{ OnSuccessCallback_37, this }; + chip::Callback::Callback mOnFailureCallback_38{ OnFailureCallback_38, this }; + chip::Callback::Callback mOnSuccessCallback_38{ OnSuccessCallback_38, this }; + chip::Callback::Callback mOnFailureCallback_39{ OnFailureCallback_39, this }; + chip::Callback::Callback mOnSuccessCallback_39{ OnSuccessCallback_39, this }; + chip::Callback::Callback mOnFailureCallback_40{ OnFailureCallback_40, this }; + chip::Callback::Callback mOnSuccessCallback_40{ OnSuccessCallback_40, this }; + chip::Callback::Callback mOnFailureCallback_41{ OnFailureCallback_41, this }; + chip::Callback::Callback mOnSuccessCallback_41{ OnSuccessCallback_41, this }; + chip::Callback::Callback mOnFailureCallback_42{ OnFailureCallback_42, this }; + chip::Callback::Callback mOnSuccessCallback_42{ OnSuccessCallback_42, this }; + chip::Callback::Callback mOnFailureCallback_43{ OnFailureCallback_43, this }; + chip::Callback::Callback mOnSuccessCallback_43{ OnSuccessCallback_43, this }; + chip::Callback::Callback mOnFailureCallback_44{ OnFailureCallback_44, this }; + chip::Callback::Callback mOnSuccessCallback_44{ OnSuccessCallback_44, this }; + chip::Callback::Callback mOnFailureCallback_45{ OnFailureCallback_45, this }; + chip::Callback::Callback mOnSuccessCallback_45{ OnSuccessCallback_45, this }; + chip::Callback::Callback mOnFailureCallback_46{ OnFailureCallback_46, this }; + chip::Callback::Callback mOnSuccessCallback_46{ OnSuccessCallback_46, this }; + chip::Callback::Callback mOnFailureCallback_47{ OnFailureCallback_47, this }; + chip::Callback::Callback mOnSuccessCallback_47{ OnSuccessCallback_47, this }; + chip::Callback::Callback mOnFailureCallback_48{ OnFailureCallback_48, this }; + chip::Callback::Callback mOnSuccessCallback_48{ OnSuccessCallback_48, this }; + chip::Callback::Callback mOnFailureCallback_49{ OnFailureCallback_49, this }; + chip::Callback::Callback mOnSuccessCallback_49{ OnSuccessCallback_49, this }; + chip::Callback::Callback mOnFailureCallback_50{ OnFailureCallback_50, this }; + chip::Callback::Callback mOnSuccessCallback_50{ OnSuccessCallback_50, this }; + chip::Callback::Callback mOnFailureCallback_51{ OnFailureCallback_51, this }; + chip::Callback::Callback mOnSuccessCallback_51{ OnSuccessCallback_51, this }; + chip::Callback::Callback mOnFailureCallback_52{ OnFailureCallback_52, this }; + chip::Callback::Callback mOnSuccessCallback_52{ OnSuccessCallback_52, this }; + chip::Callback::Callback mOnFailureCallback_53{ OnFailureCallback_53, this }; + chip::Callback::Callback mOnSuccessCallback_53{ OnSuccessCallback_53, this }; + chip::Callback::Callback mOnFailureCallback_54{ OnFailureCallback_54, this }; + chip::Callback::Callback mOnSuccessCallback_54{ OnSuccessCallback_54, this }; + chip::Callback::Callback mOnFailureCallback_55{ OnFailureCallback_55, this }; + chip::Callback::Callback mOnSuccessCallback_55{ OnSuccessCallback_55, this }; + chip::Callback::Callback mOnFailureCallback_56{ OnFailureCallback_56, this }; + chip::Callback::Callback mOnSuccessCallback_56{ OnSuccessCallback_56, this }; + chip::Callback::Callback mOnFailureCallback_57{ OnFailureCallback_57, this }; + chip::Callback::Callback mOnSuccessCallback_57{ OnSuccessCallback_57, this }; + chip::Callback::Callback mOnFailureCallback_58{ OnFailureCallback_58, this }; + chip::Callback::Callback mOnSuccessCallback_58{ OnSuccessCallback_58, this }; + chip::Callback::Callback mOnFailureCallback_59{ OnFailureCallback_59, this }; + chip::Callback::Callback mOnSuccessCallback_59{ OnSuccessCallback_59, this }; + chip::Callback::Callback mOnFailureCallback_60{ OnFailureCallback_60, this }; + chip::Callback::Callback mOnSuccessCallback_60{ OnSuccessCallback_60, this }; + chip::Callback::Callback mOnFailureCallback_61{ OnFailureCallback_61, this }; + chip::Callback::Callback mOnSuccessCallback_61{ OnSuccessCallback_61, this }; + chip::Callback::Callback mOnFailureCallback_62{ OnFailureCallback_62, this }; + chip::Callback::Callback mOnSuccessCallback_62{ OnSuccessCallback_62, this }; + chip::Callback::Callback mOnFailureCallback_63{ OnFailureCallback_63, this }; + chip::Callback::Callback mOnSuccessCallback_63{ OnSuccessCallback_63, this }; + chip::Callback::Callback mOnFailureCallback_64{ OnFailureCallback_64, this }; + chip::Callback::Callback mOnSuccessCallback_64{ OnSuccessCallback_64, this }; + chip::Callback::Callback mOnFailureCallback_65{ OnFailureCallback_65, this }; + chip::Callback::Callback mOnSuccessCallback_65{ OnSuccessCallback_65, this }; + chip::Callback::Callback mOnFailureCallback_66{ OnFailureCallback_66, this }; + chip::Callback::Callback mOnSuccessCallback_66{ OnSuccessCallback_66, this }; + chip::Callback::Callback mOnFailureCallback_67{ OnFailureCallback_67, this }; + chip::Callback::Callback mOnSuccessCallback_67{ OnSuccessCallback_67, this }; + chip::Callback::Callback mOnFailureCallback_68{ OnFailureCallback_68, this }; + chip::Callback::Callback mOnSuccessCallback_68{ OnSuccessCallback_68, this }; + chip::Callback::Callback mOnFailureCallback_69{ OnFailureCallback_69, this }; + chip::Callback::Callback mOnSuccessCallback_69{ OnSuccessCallback_69, this }; + chip::Callback::Callback mOnFailureCallback_70{ OnFailureCallback_70, this }; + chip::Callback::Callback mOnSuccessCallback_70{ OnSuccessCallback_70, this }; + chip::Callback::Callback mOnFailureCallback_71{ OnFailureCallback_71, this }; + chip::Callback::Callback mOnSuccessCallback_71{ OnSuccessCallback_71, this }; + chip::Callback::Callback mOnFailureCallback_72{ OnFailureCallback_72, this }; + chip::Callback::Callback mOnSuccessCallback_72{ OnSuccessCallback_72, this }; + chip::Callback::Callback mOnFailureCallback_73{ OnFailureCallback_73, this }; + chip::Callback::Callback mOnSuccessCallback_73{ OnSuccessCallback_73, this }; + chip::Callback::Callback mOnFailureCallback_74{ OnFailureCallback_74, this }; + chip::Callback::Callback mOnSuccessCallback_74{ OnSuccessCallback_74, this }; + chip::Callback::Callback mOnFailureCallback_75{ OnFailureCallback_75, this }; + chip::Callback::Callback mOnSuccessCallback_75{ OnSuccessCallback_75, this }; + chip::Callback::Callback mOnFailureCallback_76{ OnFailureCallback_76, this }; + chip::Callback::Callback mOnSuccessCallback_76{ OnSuccessCallback_76, this }; + chip::Callback::Callback mOnFailureCallback_77{ OnFailureCallback_77, this }; + chip::Callback::Callback mOnSuccessCallback_77{ OnSuccessCallback_77, this }; + chip::Callback::Callback mOnFailureCallback_78{ OnFailureCallback_78, this }; + chip::Callback::Callback mOnSuccessCallback_78{ OnSuccessCallback_78, this }; + chip::Callback::Callback mOnFailureCallback_79{ OnFailureCallback_79, this }; + chip::Callback::Callback mOnSuccessCallback_79{ OnSuccessCallback_79, this }; + chip::Callback::Callback mOnFailureCallback_80{ OnFailureCallback_80, this }; + chip::Callback::Callback mOnSuccessCallback_80{ OnSuccessCallback_80, this }; + chip::Callback::Callback mOnFailureCallback_81{ OnFailureCallback_81, this }; + chip::Callback::Callback mOnSuccessCallback_81{ OnSuccessCallback_81, this }; + chip::Callback::Callback mOnFailureCallback_82{ OnFailureCallback_82, this }; + chip::Callback::Callback mOnSuccessCallback_82{ OnSuccessCallback_82, this }; + chip::Callback::Callback mOnFailureCallback_83{ OnFailureCallback_83, this }; + chip::Callback::Callback mOnSuccessCallback_83{ OnSuccessCallback_83, this }; + chip::Callback::Callback mOnFailureCallback_84{ OnFailureCallback_84, this }; + chip::Callback::Callback mOnSuccessCallback_84{ OnSuccessCallback_84, this }; + chip::Callback::Callback mOnFailureCallback_85{ OnFailureCallback_85, this }; + chip::Callback::Callback mOnSuccessCallback_85{ OnSuccessCallback_85, this }; + chip::Callback::Callback mOnFailureCallback_86{ OnFailureCallback_86, this }; + chip::Callback::Callback mOnSuccessCallback_86{ OnSuccessCallback_86, this }; + chip::Callback::Callback mOnFailureCallback_87{ OnFailureCallback_87, this }; + chip::Callback::Callback mOnSuccessCallback_87{ OnSuccessCallback_87, this }; + chip::Callback::Callback mOnFailureCallback_88{ OnFailureCallback_88, this }; + chip::Callback::Callback mOnSuccessCallback_88{ OnSuccessCallback_88, + this }; + chip::Callback::Callback mOnFailureCallback_89{ OnFailureCallback_89, this }; + chip::Callback::Callback mOnSuccessCallback_89{ OnSuccessCallback_89, + this }; + chip::Callback::Callback mOnFailureCallback_90{ OnFailureCallback_90, this }; + chip::Callback::Callback mOnSuccessCallback_90{ OnSuccessCallback_90, + this }; + chip::Callback::Callback mOnFailureCallback_91{ OnFailureCallback_91, this }; + chip::Callback::Callback mOnSuccessCallback_91{ OnSuccessCallback_91, + this }; + chip::Callback::Callback mOnFailureCallback_92{ OnFailureCallback_92, this }; + chip::Callback::Callback mOnSuccessCallback_92{ OnSuccessCallback_92, + this }; + chip::Callback::Callback mOnFailureCallback_93{ OnFailureCallback_93, this }; + chip::Callback::Callback mOnSuccessCallback_93{ OnSuccessCallback_93, + this }; + chip::Callback::Callback mOnFailureCallback_94{ OnFailureCallback_94, this }; + chip::Callback::Callback mOnSuccessCallback_94{ OnSuccessCallback_94, + this }; + chip::Callback::Callback mOnFailureCallback_95{ OnFailureCallback_95, this }; + chip::Callback::Callback mOnSuccessCallback_95{ OnSuccessCallback_95, + this }; + chip::Callback::Callback mOnFailureCallback_96{ OnFailureCallback_96, this }; + chip::Callback::Callback mOnSuccessCallback_96{ OnSuccessCallback_96, + this }; + chip::Callback::Callback mOnFailureCallback_97{ OnFailureCallback_97, this }; + chip::Callback::Callback mOnSuccessCallback_97{ OnSuccessCallback_97, + this }; + chip::Callback::Callback mOnFailureCallback_98{ OnFailureCallback_98, this }; + chip::Callback::Callback mOnSuccessCallback_98{ OnSuccessCallback_98, + this }; + chip::Callback::Callback mOnFailureCallback_99{ OnFailureCallback_99, this }; + chip::Callback::Callback mOnSuccessCallback_99{ OnSuccessCallback_99, + this }; + chip::Callback::Callback mOnFailureCallback_100{ OnFailureCallback_100, this }; + chip::Callback::Callback mOnSuccessCallback_100{ OnSuccessCallback_100, + this }; + chip::Callback::Callback mOnFailureCallback_101{ OnFailureCallback_101, this }; + chip::Callback::Callback mOnSuccessCallback_101{ OnSuccessCallback_101, + this }; + chip::Callback::Callback mOnFailureCallback_102{ OnFailureCallback_102, this }; + chip::Callback::Callback mOnSuccessCallback_102{ OnSuccessCallback_102, + this }; + chip::Callback::Callback mOnFailureCallback_103{ OnFailureCallback_103, this }; + chip::Callback::Callback mOnSuccessCallback_103{ OnSuccessCallback_103, + this }; + chip::Callback::Callback mOnFailureCallback_104{ OnFailureCallback_104, this }; + chip::Callback::Callback mOnSuccessCallback_104{ OnSuccessCallback_104, + this }; + chip::Callback::Callback mOnFailureCallback_105{ OnFailureCallback_105, this }; + chip::Callback::Callback mOnSuccessCallback_105{ OnSuccessCallback_105, + this }; + chip::Callback::Callback mOnFailureCallback_106{ OnFailureCallback_106, this }; + chip::Callback::Callback mOnSuccessCallback_106{ + OnSuccessCallback_106, this + }; + chip::Callback::Callback mOnFailureCallback_107{ OnFailureCallback_107, this }; + chip::Callback::Callback mOnSuccessCallback_107{ + OnSuccessCallback_107, this + }; + chip::Callback::Callback mOnFailureCallback_108{ OnFailureCallback_108, this }; + chip::Callback::Callback + mOnSuccessCallback_108{ OnSuccessCallback_108, this }; + chip::Callback::Callback mOnFailureCallback_109{ OnFailureCallback_109, this }; + chip::Callback::Callback mOnSuccessCallback_109{ OnSuccessCallback_109, this }; + chip::Callback::Callback mOnFailureCallback_110{ OnFailureCallback_110, this }; + chip::Callback::Callback mOnSuccessCallback_110{ OnSuccessCallback_110, this }; + chip::Callback::Callback mOnFailureCallback_111{ OnFailureCallback_111, this }; + chip::Callback::Callback mOnSuccessCallback_111{ OnSuccessCallback_111, this }; + chip::Callback::Callback mOnFailureCallback_112{ OnFailureCallback_112, this }; + chip::Callback::Callback mOnSuccessCallback_112{ OnSuccessCallback_112, this }; + chip::Callback::Callback mOnFailureCallback_113{ OnFailureCallback_113, this }; + chip::Callback::Callback mOnSuccessCallback_113{ OnSuccessCallback_113, this }; + chip::Callback::Callback mOnFailureCallback_114{ OnFailureCallback_114, this }; + chip::Callback::Callback mOnSuccessCallback_114{ OnSuccessCallback_114, this }; + chip::Callback::Callback mOnFailureCallback_115{ OnFailureCallback_115, this }; + chip::Callback::Callback mOnSuccessCallback_115{ OnSuccessCallback_115, this }; + chip::Callback::Callback mOnFailureCallback_116{ OnFailureCallback_116, this }; + chip::Callback::Callback mOnSuccessCallback_116{ OnSuccessCallback_116, this }; + chip::Callback::Callback mOnFailureCallback_117{ OnFailureCallback_117, this }; + chip::Callback::Callback mOnSuccessCallback_117{ OnSuccessCallback_117, this }; + chip::Callback::Callback mOnFailureCallback_118{ OnFailureCallback_118, this }; + chip::Callback::Callback mOnSuccessCallback_118{ OnSuccessCallback_118, this }; + chip::Callback::Callback mOnFailureCallback_119{ OnFailureCallback_119, this }; + chip::Callback::Callback mOnSuccessCallback_119{ OnSuccessCallback_119, this }; + chip::Callback::Callback mOnFailureCallback_120{ OnFailureCallback_120, this }; + chip::Callback::Callback mOnSuccessCallback_120{ OnSuccessCallback_120, this }; - CHIP_ERROR TestReadTheOptionalAttributeScheduleProgrammingVisibility_11() + static void OnFailureCallback_5(void * context, uint8_t status) { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeScheduleProgrammingVisibility(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel()); + (static_cast(context))->OnFailureResponse_5(status); } - void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_11(uint8_t scheduleProgrammingVisibility) + static void OnSuccessCallback_5(void * context, bool boolean) { - VerifyOrReturn(CheckConstraintType("scheduleProgrammingVisibility", "", "enum8")); - NextTest(); + (static_cast(context))->OnSuccessResponse_5(boolean); } - CHIP_ERROR TestWriteToTheMandatoryAttributeScheduleProgrammingVisibility_12() + static void OnFailureCallback_6(void * context, uint8_t status) { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - uint8_t scheduleProgrammingVisibilityArgument = 0; - - return cluster.WriteAttributeScheduleProgrammingVisibility(mOnSuccessCallback_12.Cancel(), mOnFailureCallback_12.Cancel(), - scheduleProgrammingVisibilityArgument); + (static_cast(context))->OnFailureResponse_6(status); } - void OnFailureResponse_12(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_12(uint8_t scheduleProgrammingVisibility) { NextTest(); } - - CHIP_ERROR TestReadTheOptionalAttributeScheduleProgrammingVisibility_13() + static void OnSuccessCallback_6(void * context, bool boolean) { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeScheduleProgrammingVisibility(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel()); + (static_cast(context))->OnSuccessResponse_6(boolean); } - void OnFailureResponse_13(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_13(uint8_t scheduleProgrammingVisibility) + static void OnFailureCallback_7(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("scheduleProgrammingVisibility", scheduleProgrammingVisibility, 0)); - NextTest(); + (static_cast(context))->OnFailureResponse_7(status); } - CHIP_ERROR TestReadTheOptionalAttributeScheduleProgrammingVisibility_14() + static void OnSuccessCallback_7(void * context, bool boolean) { - chip::Controller::ThermostatUserInterfaceConfigurationClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeScheduleProgrammingVisibility(mOnSuccessCallback_14.Cancel(), mOnFailureCallback_14.Cancel()); + (static_cast(context))->OnSuccessResponse_7(boolean); } - void OnFailureResponse_14(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_14(uint8_t scheduleProgrammingVisibility) + static void OnFailureCallback_8(void * context, uint8_t status) { - VerifyOrReturn(CheckConstraintType("scheduleProgrammingVisibility", "", "enum8")); - NextTest(); + (static_cast(context))->OnFailureResponse_8(status); } -}; - -class Test_TC_PCC_2_1 : public TestCommand -{ -public: - Test_TC_PCC_2_1() : TestCommand("Test_TC_PCC_2_1"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + static void OnSuccessCallback_8(void * context, bool boolean) { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_PCC_2_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_PCC_2_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : read the mandatory attribute: MaxPressure\n"); - err = TestReadTheMandatoryAttributeMaxPressure_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : read the mandatory attribute: EffectiveOperationMode\n"); - err = TestReadTheMandatoryAttributeEffectiveOperationMode_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : read the mandatory attribute: EffectiveControlMode\n"); - err = TestReadTheMandatoryAttributeEffectiveControlMode_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : read the mandatory attribute: Capacity\n"); - err = TestReadTheMandatoryAttributeCapacity_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : read the mandatory attribute: MaxPressure\n"); - err = TestReadTheMandatoryAttributeMaxPressure_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : read the mandatory attribute: EffectiveOperationMode\n"); - err = TestReadTheMandatoryAttributeEffectiveOperationMode_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : read the mandatory attribute: EffectiveControlMode\n"); - err = TestReadTheMandatoryAttributeEffectiveControlMode_6(); - break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : read the mandatory attribute: Capacity\n"); - err = TestReadTheMandatoryAttributeCapacity_7(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + (static_cast(context))->OnSuccessResponse_8(boolean); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 8; - - chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; - chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, - this }; - chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; - chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, - this }; - chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, - this }; - chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; - chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, - this }; - chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; - - static void OnFailureCallback_0(void * context, uint8_t status) + static void OnFailureCallback_9(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_9(status); } - static void OnSuccessCallback_0(void * context, int16_t maxPressure) + static void OnSuccessCallback_9(void * context, bool boolean) { - (static_cast(context))->OnSuccessResponse_0(maxPressure); + (static_cast(context))->OnSuccessResponse_9(boolean); } - static void OnFailureCallback_1(void * context, uint8_t status) + static void OnFailureCallback_10(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_10(status); } - static void OnSuccessCallback_1(void * context, uint8_t effectiveOperationMode) + static void OnSuccessCallback_10(void * context, uint8_t bitmap8) { - (static_cast(context))->OnSuccessResponse_1(effectiveOperationMode); + (static_cast(context))->OnSuccessResponse_10(bitmap8); } - static void OnFailureCallback_2(void * context, uint8_t status) + static void OnFailureCallback_11(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_11(status); } - static void OnSuccessCallback_2(void * context, uint8_t effectiveControlMode) + static void OnSuccessCallback_11(void * context, uint8_t bitmap8) { - (static_cast(context))->OnSuccessResponse_2(effectiveControlMode); + (static_cast(context))->OnSuccessResponse_11(bitmap8); } - static void OnFailureCallback_3(void * context, uint8_t status) + static void OnFailureCallback_12(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_3(status); + (static_cast(context))->OnFailureResponse_12(status); } - static void OnSuccessCallback_3(void * context, int16_t capacity) + static void OnSuccessCallback_12(void * context, uint8_t bitmap8) { - (static_cast(context))->OnSuccessResponse_3(capacity); + (static_cast(context))->OnSuccessResponse_12(bitmap8); } - static void OnFailureCallback_4(void * context, uint8_t status) + static void OnFailureCallback_13(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_13(status); } - static void OnSuccessCallback_4(void * context, int16_t maxPressure) + static void OnSuccessCallback_13(void * context, uint8_t bitmap8) { - (static_cast(context))->OnSuccessResponse_4(maxPressure); + (static_cast(context))->OnSuccessResponse_13(bitmap8); } - static void OnFailureCallback_5(void * context, uint8_t status) + static void OnFailureCallback_14(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_5(status); + (static_cast(context))->OnFailureResponse_14(status); } - static void OnSuccessCallback_5(void * context, uint8_t effectiveOperationMode) + static void OnSuccessCallback_14(void * context, uint8_t bitmap8) { - (static_cast(context))->OnSuccessResponse_5(effectiveOperationMode); + (static_cast(context))->OnSuccessResponse_14(bitmap8); } - static void OnFailureCallback_6(void * context, uint8_t status) + static void OnFailureCallback_15(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_6(status); + (static_cast(context))->OnFailureResponse_15(status); } - static void OnSuccessCallback_6(void * context, uint8_t effectiveControlMode) + static void OnSuccessCallback_15(void * context, uint16_t bitmap16) { - (static_cast(context))->OnSuccessResponse_6(effectiveControlMode); + (static_cast(context))->OnSuccessResponse_15(bitmap16); } - static void OnFailureCallback_7(void * context, uint8_t status) + static void OnFailureCallback_16(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_7(status); + (static_cast(context))->OnFailureResponse_16(status); } - static void OnSuccessCallback_7(void * context, int16_t capacity) + static void OnSuccessCallback_16(void * context, uint16_t bitmap16) { - (static_cast(context))->OnSuccessResponse_7(capacity); + (static_cast(context))->OnSuccessResponse_16(bitmap16); } - // - // Tests methods - // - - CHIP_ERROR TestReadTheMandatoryAttributeMaxPressure_0() + static void OnFailureCallback_17(void * context, uint8_t status) { - chip::Controller::PumpConfigurationAndControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeMaxPressure(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); + (static_cast(context))->OnFailureResponse_17(status); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0(int16_t maxPressure) + static void OnSuccessCallback_17(void * context, uint16_t bitmap16) { - VerifyOrReturn(CheckConstraintType("maxPressure", "", "int16")); - NextTest(); + (static_cast(context))->OnSuccessResponse_17(bitmap16); } - CHIP_ERROR TestReadTheMandatoryAttributeEffectiveOperationMode_1() + static void OnFailureCallback_18(void * context, uint8_t status) { - chip::Controller::PumpConfigurationAndControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeEffectiveOperationMode(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + (static_cast(context))->OnFailureResponse_18(status); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_1(uint8_t effectiveOperationMode) + static void OnSuccessCallback_18(void * context, uint16_t bitmap16) { - VerifyOrReturn(CheckConstraintType("effectiveOperationMode", "", "enum8")); - NextTest(); + (static_cast(context))->OnSuccessResponse_18(bitmap16); } - CHIP_ERROR TestReadTheMandatoryAttributeEffectiveControlMode_2() + static void OnFailureCallback_19(void * context, uint8_t status) { - chip::Controller::PumpConfigurationAndControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeEffectiveControlMode(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); + (static_cast(context))->OnFailureResponse_19(status); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_2(uint8_t effectiveControlMode) + static void OnSuccessCallback_19(void * context, uint16_t bitmap16) { - VerifyOrReturn(CheckConstraintType("effectiveControlMode", "", "enum8")); - NextTest(); + (static_cast(context))->OnSuccessResponse_19(bitmap16); } - CHIP_ERROR TestReadTheMandatoryAttributeCapacity_3() + static void OnFailureCallback_20(void * context, uint8_t status) { - chip::Controller::PumpConfigurationAndControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeCapacity(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + (static_cast(context))->OnFailureResponse_20(status); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_3(int16_t capacity) + static void OnSuccessCallback_20(void * context, uint32_t bitmap32) { - VerifyOrReturn(CheckConstraintType("capacity", "", "int16")); - NextTest(); + (static_cast(context))->OnSuccessResponse_20(bitmap32); } - CHIP_ERROR TestReadTheMandatoryAttributeMaxPressure_4() + static void OnFailureCallback_21(void * context, uint8_t status) { - chip::Controller::PumpConfigurationAndControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeMaxPressure(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + (static_cast(context))->OnFailureResponse_21(status); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_4(int16_t maxPressure) + static void OnSuccessCallback_21(void * context, uint32_t bitmap32) { - VerifyOrReturn(CheckConstraintType("maxPressure", "", "int16")); - NextTest(); + (static_cast(context))->OnSuccessResponse_21(bitmap32); } - CHIP_ERROR TestReadTheMandatoryAttributeEffectiveOperationMode_5() + static void OnFailureCallback_22(void * context, uint8_t status) { - chip::Controller::PumpConfigurationAndControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeEffectiveOperationMode(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + (static_cast(context))->OnFailureResponse_22(status); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_5(uint8_t effectiveOperationMode) + static void OnSuccessCallback_22(void * context, uint32_t bitmap32) { - VerifyOrReturn(CheckConstraintType("effectiveOperationMode", "", "enum8")); - NextTest(); + (static_cast(context))->OnSuccessResponse_22(bitmap32); } - CHIP_ERROR TestReadTheMandatoryAttributeEffectiveControlMode_6() + static void OnFailureCallback_23(void * context, uint8_t status) { - chip::Controller::PumpConfigurationAndControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeEffectiveControlMode(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); + (static_cast(context))->OnFailureResponse_23(status); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_6(uint8_t effectiveControlMode) + static void OnSuccessCallback_23(void * context, uint32_t bitmap32) { - VerifyOrReturn(CheckConstraintType("effectiveControlMode", "", "enum8")); - NextTest(); + (static_cast(context))->OnSuccessResponse_23(bitmap32); } - CHIP_ERROR TestReadTheMandatoryAttributeCapacity_7() + static void OnFailureCallback_24(void * context, uint8_t status) { - chip::Controller::PumpConfigurationAndControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeCapacity(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + (static_cast(context))->OnFailureResponse_24(status); } - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_7(int16_t capacity) + static void OnSuccessCallback_24(void * context, uint32_t bitmap32) { - VerifyOrReturn(CheckConstraintType("capacity", "", "int16")); - NextTest(); + (static_cast(context))->OnSuccessResponse_24(bitmap32); } -}; - -class Test_TC_CC_3_1 : public TestCommand -{ -public: - Test_TC_CC_3_1() : TestCommand("Test_TC_CC_3_1"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + static void OnFailureCallback_25(void * context, uint8_t status) { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_3_1\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_3_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Move to hue shortest distance command\n"); - err = TestMoveToHueShortestDistanceCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Move to hue longest distance command\n"); - err = TestMoveToHueLongestDistanceCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Move to hue up command\n"); - err = TestMoveToHueUpCommand_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Move to hue down command\n"); - err = TestMoveToHueDownCommand_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_6(); - break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + (static_cast(context))->OnFailureResponse_25(status); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 8; - - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; - - static void OnFailureCallback_1(void * context, uint8_t status) + static void OnSuccessCallback_25(void * context, uint64_t bitmap64) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnSuccessResponse_25(bitmap64); } - static void OnSuccessCallback_1(void * context, bool onOff) + static void OnFailureCallback_26(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_1(onOff); + (static_cast(context))->OnFailureResponse_26(status); } - static void OnFailureCallback_7(void * context, uint8_t status) + static void OnSuccessCallback_26(void * context, uint64_t bitmap64) { - (static_cast(context))->OnFailureResponse_7(status); + (static_cast(context))->OnSuccessResponse_26(bitmap64); } - static void OnSuccessCallback_7(void * context, bool onOff) + static void OnFailureCallback_27(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_7(onOff); + (static_cast(context))->OnFailureResponse_27(status); } - // - // Tests methods - // - - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + static void OnSuccessCallback_27(void * context, uint64_t bitmap64) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::On::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + (static_cast(context))->OnSuccessResponse_27(bitmap64); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0() { NextTest(); } - - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + static void OnFailureCallback_28(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + (static_cast(context))->OnFailureResponse_28(status); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_1(bool onOff) + static void OnSuccessCallback_28(void * context, uint64_t bitmap64) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); - NextTest(); + (static_cast(context))->OnSuccessResponse_28(bitmap64); } - CHIP_ERROR TestMoveToHueShortestDistanceCommand_2() + static void OnFailureCallback_29(void * context, uint8_t status) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::ColorControl::Commands::MoveToHue::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::MoveToHue::Type request; - request.hue = 150; - request.direction = static_cast(0); - request.transitionTime = 100U; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + (static_cast(context))->OnFailureResponse_29(status); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnSuccessCallback_29(void * context, uint64_t bitmap64) + { + (static_cast(context))->OnSuccessResponse_29(bitmap64); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_30(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_30(status); + } - void OnSuccessResponse_2() { NextTest(); } + static void OnSuccessCallback_30(void * context, uint8_t int8u) + { + (static_cast(context))->OnSuccessResponse_30(int8u); + } - CHIP_ERROR TestMoveToHueLongestDistanceCommand_3() + static void OnFailureCallback_31(void * context, uint8_t status) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_31(status); + } - using requestType = chip::app::Clusters::ColorControl::Commands::MoveToHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnSuccessCallback_31(void * context, uint8_t int8u) + { + (static_cast(context))->OnSuccessResponse_31(int8u); + } - chip::app::Clusters::ColorControl::Commands::MoveToHue::Type request; - request.hue = 200; - request.direction = static_cast(1); - request.transitionTime = 100U; - request.optionsMask = 0; - request.optionsOverride = 0; + static void OnFailureCallback_32(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_32(status); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + static void OnSuccessCallback_32(void * context, uint8_t int8u) + { + (static_cast(context))->OnSuccessResponse_32(int8u); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnFailureCallback_33(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_33(status); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_33(void * context, uint8_t int8u) + { + (static_cast(context))->OnSuccessResponse_33(int8u); + } - void OnSuccessResponse_3() { NextTest(); } + static void OnFailureCallback_34(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_34(status); + } - CHIP_ERROR TestMoveToHueUpCommand_4() + static void OnSuccessCallback_34(void * context, uint8_t int8u) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_34(int8u); + } - using requestType = chip::app::Clusters::ColorControl::Commands::MoveToHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnFailureCallback_35(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_35(status); + } - chip::app::Clusters::ColorControl::Commands::MoveToHue::Type request; - request.hue = 250; - request.direction = static_cast(2); - request.transitionTime = 100U; - request.optionsMask = 0; - request.optionsOverride = 0; + static void OnSuccessCallback_35(void * context, uint16_t int16u) + { + (static_cast(context))->OnSuccessResponse_35(int16u); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); - }; + static void OnFailureCallback_36(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_36(status); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnSuccessCallback_36(void * context, uint16_t int16u) + { + (static_cast(context))->OnSuccessResponse_36(int16u); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_37(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_37(status); + } - void OnSuccessResponse_4() { NextTest(); } + static void OnSuccessCallback_37(void * context, uint16_t int16u) + { + (static_cast(context))->OnSuccessResponse_37(int16u); + } - CHIP_ERROR TestMoveToHueDownCommand_5() + static void OnFailureCallback_38(void * context, uint8_t status) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_38(status); + } - using requestType = chip::app::Clusters::ColorControl::Commands::MoveToHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnSuccessCallback_38(void * context, uint16_t int16u) + { + (static_cast(context))->OnSuccessResponse_38(int16u); + } - chip::app::Clusters::ColorControl::Commands::MoveToHue::Type request; - request.hue = 225; - request.direction = static_cast(3); - request.transitionTime = 100U; - request.optionsMask = 0; - request.optionsOverride = 0; + static void OnFailureCallback_39(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_39(status); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_5(); - }; + static void OnSuccessCallback_39(void * context, uint16_t int16u) + { + (static_cast(context))->OnSuccessResponse_39(int16u); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_5(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnFailureCallback_40(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_40(status); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_40(void * context, uint32_t int32u) + { + (static_cast(context))->OnSuccessResponse_40(int32u); + } - void OnSuccessResponse_5() { NextTest(); } + static void OnFailureCallback_41(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_41(status); + } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_6() + static void OnSuccessCallback_41(void * context, uint32_t int32u) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_41(int32u); + } - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnFailureCallback_42(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_42(status); + } - chip::app::Clusters::OnOff::Commands::Off::Type request; + static void OnSuccessCallback_42(void * context, uint32_t int32u) + { + (static_cast(context))->OnSuccessResponse_42(int32u); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_6(); - }; + static void OnFailureCallback_43(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_43(status); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_6(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnSuccessCallback_43(void * context, uint32_t int32u) + { + (static_cast(context))->OnSuccessResponse_43(int32u); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_44(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_44(status); + } - void OnSuccessResponse_6() { NextTest(); } + static void OnSuccessCallback_44(void * context, uint32_t int32u) + { + (static_cast(context))->OnSuccessResponse_44(int32u); + } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7() + static void OnFailureCallback_45(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_45(status); + } - return cluster.ReadAttributeOnOff(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + static void OnSuccessCallback_45(void * context, uint64_t int64u) + { + (static_cast(context))->OnSuccessResponse_45(int64u); } - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_46(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_46(status); + } - void OnSuccessResponse_7(bool onOff) + static void OnSuccessCallback_46(void * context, uint64_t int64u) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); - NextTest(); + (static_cast(context))->OnSuccessResponse_46(int64u); } -}; -class Test_TC_CC_3_2 : public TestCommand -{ -public: - Test_TC_CC_3_2() : TestCommand("Test_TC_CC_3_2"), mTestIndex(0) {} + static void OnFailureCallback_47(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_47(status); + } - /////////// TestCommand Interface ///////// - void NextTest() override + static void OnSuccessCallback_47(void * context, uint64_t int64u) + { + (static_cast(context))->OnSuccessResponse_47(int64u); + } + + static void OnFailureCallback_48(void * context, uint8_t status) { - CHIP_ERROR err = CHIP_NO_ERROR; + (static_cast(context))->OnFailureResponse_48(status); + } - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_3_2\n"); - } + static void OnSuccessCallback_48(void * context, uint64_t int64u) + { + (static_cast(context))->OnSuccessResponse_48(int64u); + } - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_3_2\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + static void OnFailureCallback_49(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_49(status); + } - Wait(); + static void OnSuccessCallback_49(void * context, uint64_t int64u) + { + (static_cast(context))->OnSuccessResponse_49(int64u); + } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Move hue up command\n"); - err = TestMoveHueUpCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Move hue stop command\n"); - err = TestMoveHueStopCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Move hue down command\n"); - err = TestMoveHueDownCommand_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Move hue stop command\n"); - err = TestMoveHueStopCommand_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_6(); - break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7(); - break; - } + static void OnFailureCallback_50(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_50(status); + } - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + static void OnSuccessCallback_50(void * context, int8_t int8s) + { + (static_cast(context))->OnSuccessResponse_50(int8s); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 8; + static void OnFailureCallback_51(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_51(status); + } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; + static void OnSuccessCallback_51(void * context, int8_t int8s) + { + (static_cast(context))->OnSuccessResponse_51(int8s); + } - static void OnFailureCallback_1(void * context, uint8_t status) + static void OnFailureCallback_52(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_52(status); } - static void OnSuccessCallback_1(void * context, bool onOff) + static void OnSuccessCallback_52(void * context, int8_t int8s) { - (static_cast(context))->OnSuccessResponse_1(onOff); + (static_cast(context))->OnSuccessResponse_52(int8s); } - static void OnFailureCallback_7(void * context, uint8_t status) + static void OnFailureCallback_53(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_7(status); + (static_cast(context))->OnFailureResponse_53(status); } - static void OnSuccessCallback_7(void * context, bool onOff) + static void OnSuccessCallback_53(void * context, int8_t int8s) { - (static_cast(context))->OnSuccessResponse_7(onOff); + (static_cast(context))->OnSuccessResponse_53(int8s); } - // - // Tests methods - // + static void OnFailureCallback_54(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_54(status); + } - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + static void OnSuccessCallback_54(void * context, int8_t int8s) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_54(int8s); + } - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnFailureCallback_55(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_55(status); + } - chip::app::Clusters::OnOff::Commands::On::Type request; + static void OnSuccessCallback_55(void * context, int8_t int8s) + { + (static_cast(context))->OnSuccessResponse_55(int8s); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + static void OnFailureCallback_56(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_56(status); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnSuccessCallback_56(void * context, int8_t int8s) + { + (static_cast(context))->OnSuccessResponse_56(int8s); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_57(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_57(status); + } - void OnSuccessResponse_0() { NextTest(); } + static void OnSuccessCallback_57(void * context, int16_t int16s) + { + (static_cast(context))->OnSuccessResponse_57(int16s); + } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + static void OnFailureCallback_58(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_58(status); + } - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + static void OnSuccessCallback_58(void * context, int16_t int16s) + { + (static_cast(context))->OnSuccessResponse_58(int16s); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_59(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_59(status); + } - void OnSuccessResponse_1(bool onOff) + static void OnSuccessCallback_59(void * context, int16_t int16s) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); - NextTest(); + (static_cast(context))->OnSuccessResponse_59(int16s); } - CHIP_ERROR TestMoveHueUpCommand_2() + static void OnFailureCallback_60(void * context, uint8_t status) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_60(status); + } - using requestType = chip::app::Clusters::ColorControl::Commands::MoveHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnSuccessCallback_60(void * context, int16_t int16s) + { + (static_cast(context))->OnSuccessResponse_60(int16s); + } - chip::app::Clusters::ColorControl::Commands::MoveHue::Type request; - request.moveMode = static_cast(1); - request.rate = 50; - request.optionsMask = 0; - request.optionsOverride = 0; + static void OnFailureCallback_61(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_61(status); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + static void OnSuccessCallback_61(void * context, int16_t int16s) + { + (static_cast(context))->OnSuccessResponse_61(int16s); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnFailureCallback_62(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_62(status); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_62(void * context, int16_t int16s) + { + (static_cast(context))->OnSuccessResponse_62(int16s); + } - void OnSuccessResponse_2() { NextTest(); } + static void OnFailureCallback_63(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_63(status); + } - CHIP_ERROR TestMoveHueStopCommand_3() + static void OnSuccessCallback_63(void * context, int16_t int16s) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_63(int16s); + } - using requestType = chip::app::Clusters::ColorControl::Commands::MoveHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnFailureCallback_64(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_64(status); + } - chip::app::Clusters::ColorControl::Commands::MoveHue::Type request; - request.moveMode = static_cast(0); - request.rate = 50; - request.optionsMask = 0; - request.optionsOverride = 0; + static void OnSuccessCallback_64(void * context, int32_t int32s) + { + (static_cast(context))->OnSuccessResponse_64(int32s); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + static void OnFailureCallback_65(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_65(status); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnSuccessCallback_65(void * context, int32_t int32s) + { + (static_cast(context))->OnSuccessResponse_65(int32s); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_3() { NextTest(); } + static void OnFailureCallback_66(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_66(status); + } - CHIP_ERROR TestMoveHueDownCommand_4() + static void OnSuccessCallback_66(void * context, int32_t int32s) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_66(int32s); + } - using requestType = chip::app::Clusters::ColorControl::Commands::MoveHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnFailureCallback_67(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_67(status); + } - chip::app::Clusters::ColorControl::Commands::MoveHue::Type request; - request.moveMode = static_cast(3); - request.rate = 50; - request.optionsMask = 0; - request.optionsOverride = 0; + static void OnSuccessCallback_67(void * context, int32_t int32s) + { + (static_cast(context))->OnSuccessResponse_67(int32s); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); - }; + static void OnFailureCallback_68(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_68(status); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnSuccessCallback_68(void * context, int32_t int32s) + { + (static_cast(context))->OnSuccessResponse_68(int32s); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_69(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_69(status); + } - void OnSuccessResponse_4() { NextTest(); } + static void OnSuccessCallback_69(void * context, int32_t int32s) + { + (static_cast(context))->OnSuccessResponse_69(int32s); + } - CHIP_ERROR TestMoveHueStopCommand_5() + static void OnFailureCallback_70(void * context, uint8_t status) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_70(status); + } - using requestType = chip::app::Clusters::ColorControl::Commands::MoveHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnSuccessCallback_70(void * context, int32_t int32s) + { + (static_cast(context))->OnSuccessResponse_70(int32s); + } - chip::app::Clusters::ColorControl::Commands::MoveHue::Type request; - request.moveMode = static_cast(0); - request.rate = 50; - request.optionsMask = 0; - request.optionsOverride = 0; + static void OnFailureCallback_71(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_71(status); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_5(); - }; + static void OnSuccessCallback_71(void * context, int64_t int64s) + { + (static_cast(context))->OnSuccessResponse_71(int64s); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_5(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnFailureCallback_72(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_72(status); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_72(void * context, int64_t int64s) + { + (static_cast(context))->OnSuccessResponse_72(int64s); + } - void OnSuccessResponse_5() { NextTest(); } + static void OnFailureCallback_73(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_73(status); + } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_6() + static void OnSuccessCallback_73(void * context, int64_t int64s) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_73(int64s); + } - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnFailureCallback_74(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_74(status); + } - chip::app::Clusters::OnOff::Commands::Off::Type request; + static void OnSuccessCallback_74(void * context, int64_t int64s) + { + (static_cast(context))->OnSuccessResponse_74(int64s); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_6(); - }; + static void OnFailureCallback_75(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_75(status); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_6(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnSuccessCallback_75(void * context, int64_t int64s) + { + (static_cast(context))->OnSuccessResponse_75(int64s); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_76(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_76(status); + } - void OnSuccessResponse_6() { NextTest(); } + static void OnSuccessCallback_76(void * context, int64_t int64s) + { + (static_cast(context))->OnSuccessResponse_76(int64s); + } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7() + static void OnFailureCallback_77(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_77(status); + } - return cluster.ReadAttributeOnOff(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + static void OnSuccessCallback_77(void * context, int64_t int64s) + { + (static_cast(context))->OnSuccessResponse_77(int64s); } - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_78(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_78(status); + } - void OnSuccessResponse_7(bool onOff) + static void OnSuccessCallback_78(void * context, uint8_t enum8) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); - NextTest(); + (static_cast(context))->OnSuccessResponse_78(enum8); } -}; -class Test_TC_CC_3_3 : public TestCommand -{ -public: - Test_TC_CC_3_3() : TestCommand("Test_TC_CC_3_3"), mTestIndex(0) {} + static void OnFailureCallback_79(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_79(status); + } - /////////// TestCommand Interface ///////// - void NextTest() override + static void OnSuccessCallback_79(void * context, uint8_t enum8) { - CHIP_ERROR err = CHIP_NO_ERROR; + (static_cast(context))->OnSuccessResponse_79(enum8); + } - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_3_3\n"); - } + static void OnFailureCallback_80(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_80(status); + } - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_3_3\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + static void OnSuccessCallback_80(void * context, uint8_t enum8) + { + (static_cast(context))->OnSuccessResponse_80(enum8); + } - Wait(); + static void OnFailureCallback_81(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_81(status); + } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Step hue up command\n"); - err = TestStepHueUpCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Step hue down command\n"); - err = TestStepHueDownCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); - break; - } + static void OnSuccessCallback_81(void * context, uint8_t enum8) + { + (static_cast(context))->OnSuccessResponse_81(enum8); + } - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + static void OnFailureCallback_82(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_82(status); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 6; + static void OnSuccessCallback_82(void * context, uint8_t enum8) + { + (static_cast(context))->OnSuccessResponse_82(enum8); + } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + static void OnFailureCallback_83(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_83(status); + } - static void OnFailureCallback_1(void * context, uint8_t status) + static void OnSuccessCallback_83(void * context, uint16_t enum16) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnSuccessResponse_83(enum16); } - static void OnSuccessCallback_1(void * context, bool onOff) + static void OnFailureCallback_84(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_1(onOff); + (static_cast(context))->OnFailureResponse_84(status); } - static void OnFailureCallback_5(void * context, uint8_t status) + static void OnSuccessCallback_84(void * context, uint16_t enum16) { - (static_cast(context))->OnFailureResponse_5(status); + (static_cast(context))->OnSuccessResponse_84(enum16); } - static void OnSuccessCallback_5(void * context, bool onOff) + static void OnFailureCallback_85(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_5(onOff); + (static_cast(context))->OnFailureResponse_85(status); } - // - // Tests methods - // - - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + static void OnSuccessCallback_85(void * context, uint16_t enum16) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::On::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + (static_cast(context))->OnSuccessResponse_85(enum16); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0() { NextTest(); } - - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + static void OnFailureCallback_86(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + (static_cast(context))->OnFailureResponse_86(status); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_1(bool onOff) + static void OnSuccessCallback_86(void * context, uint16_t enum16) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); - NextTest(); + (static_cast(context))->OnSuccessResponse_86(enum16); } - CHIP_ERROR TestStepHueUpCommand_2() + static void OnFailureCallback_87(void * context, uint8_t status) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::ColorControl::Commands::StepHue::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::StepHue::Type request; - request.stepMode = static_cast(1); - request.stepSize = 5; - request.transitionTime = 25; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + (static_cast(context))->OnFailureResponse_87(status); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_2() { NextTest(); } - - CHIP_ERROR TestStepHueDownCommand_3() + static void OnSuccessCallback_87(void * context, uint16_t enum16) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::ColorControl::Commands::StepHue::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::StepHue::Type request; - request.stepMode = static_cast(3); - request.stepSize = 5; - request.transitionTime = 25; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + (static_cast(context))->OnSuccessResponse_87(enum16); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_3() { NextTest(); } - - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() + static void OnFailureCallback_88(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Off::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + (static_cast(context))->OnFailureResponse_88(status); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_88(void * context, chip::ByteSpan octetString) + { + (static_cast(context))->OnSuccessResponse_88(octetString); + } - void OnSuccessResponse_4() { NextTest(); } + static void OnFailureCallback_89(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_89(status); + } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() + static void OnSuccessCallback_89(void * context, chip::ByteSpan octetString) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_89(octetString); + } - return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + static void OnFailureCallback_90(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_90(status); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_90(void * context, chip::ByteSpan octetString) + { + (static_cast(context))->OnSuccessResponse_90(octetString); + } - void OnSuccessResponse_5(bool onOff) + static void OnFailureCallback_91(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); - NextTest(); + (static_cast(context))->OnFailureResponse_91(status); } -}; -class Test_TC_CC_4_1 : public TestCommand -{ -public: - Test_TC_CC_4_1() : TestCommand("Test_TC_CC_4_1"), mTestIndex(0) {} + static void OnSuccessCallback_91(void * context, chip::ByteSpan octetString) + { + (static_cast(context))->OnSuccessResponse_91(octetString); + } - /////////// TestCommand Interface ///////// - void NextTest() override + static void OnFailureCallback_92(void * context, uint8_t status) { - CHIP_ERROR err = CHIP_NO_ERROR; + (static_cast(context))->OnFailureResponse_92(status); + } - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_4_1\n"); - } + static void OnSuccessCallback_92(void * context, chip::ByteSpan octetString) + { + (static_cast(context))->OnSuccessResponse_92(octetString); + } - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_4_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + static void OnFailureCallback_93(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_93(status); + } - Wait(); + static void OnSuccessCallback_93(void * context, chip::ByteSpan octetString) + { + (static_cast(context))->OnSuccessResponse_93(octetString); + } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Move to saturation command\n"); - err = TestMoveToSaturationCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); - break; - } + static void OnFailureCallback_94(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_94(status); + } - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + static void OnSuccessCallback_94(void * context, chip::ByteSpan longOctetString) + { + (static_cast(context))->OnSuccessResponse_94(longOctetString); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 5; + static void OnFailureCallback_95(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_95(status); + } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + static void OnSuccessCallback_95(void * context, chip::ByteSpan longOctetString) + { + (static_cast(context))->OnSuccessResponse_95(longOctetString); + } - static void OnFailureCallback_1(void * context, uint8_t status) + static void OnFailureCallback_96(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_96(status); } - static void OnSuccessCallback_1(void * context, bool onOff) + static void OnSuccessCallback_96(void * context, chip::ByteSpan longOctetString) { - (static_cast(context))->OnSuccessResponse_1(onOff); + (static_cast(context))->OnSuccessResponse_96(longOctetString); } - static void OnFailureCallback_4(void * context, uint8_t status) + static void OnFailureCallback_97(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_97(status); } - static void OnSuccessCallback_4(void * context, bool onOff) + static void OnSuccessCallback_97(void * context, chip::ByteSpan longOctetString) { - (static_cast(context))->OnSuccessResponse_4(onOff); + (static_cast(context))->OnSuccessResponse_97(longOctetString); } - // - // Tests methods - // - - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + static void OnFailureCallback_98(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::On::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + (static_cast(context))->OnFailureResponse_98(status); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_0() { NextTest(); } - - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + static void OnSuccessCallback_98(void * context, chip::ByteSpan charString) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + (static_cast(context))->OnSuccessResponse_98(charString); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_1(bool onOff) + static void OnFailureCallback_99(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); - NextTest(); + (static_cast(context))->OnFailureResponse_99(status); } - CHIP_ERROR TestMoveToSaturationCommand_2() + static void OnSuccessCallback_99(void * context, chip::ByteSpan charString) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_99(charString); + } - using requestType = chip::app::Clusters::ColorControl::Commands::MoveToSaturation::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnFailureCallback_100(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_100(status); + } - chip::app::Clusters::ColorControl::Commands::MoveToSaturation::Type request; - request.saturation = 90; - request.transitionTime = 10U; - request.optionsMask = 0; - request.optionsOverride = 0; + static void OnSuccessCallback_100(void * context, chip::ByteSpan charString) + { + (static_cast(context))->OnSuccessResponse_100(charString); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + static void OnFailureCallback_101(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_101(status); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnSuccessCallback_101(void * context, chip::ByteSpan charString) + { + (static_cast(context))->OnSuccessResponse_101(charString); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_102(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_102(status); + } - void OnSuccessResponse_2() { NextTest(); } + static void OnSuccessCallback_102(void * context, chip::ByteSpan longCharString) + { + (static_cast(context))->OnSuccessResponse_102(longCharString); + } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() + static void OnFailureCallback_103(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_103(status); + } - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnSuccessCallback_103(void * context, chip::ByteSpan longCharString) + { + (static_cast(context))->OnSuccessResponse_103(longCharString); + } - chip::app::Clusters::OnOff::Commands::Off::Type request; + static void OnFailureCallback_104(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_104(status); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + static void OnSuccessCallback_104(void * context, chip::ByteSpan longCharString) + { + (static_cast(context))->OnSuccessResponse_104(longCharString); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnFailureCallback_105(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_105(status); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_105(void * context, chip::ByteSpan longCharString) + { + (static_cast(context))->OnSuccessResponse_105(longCharString); + } - void OnSuccessResponse_3() { NextTest(); } + static void OnFailureCallback_106(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_106(status); + } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() + static void OnSuccessCallback_106(void * context, uint16_t count, uint8_t * listInt8u) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_106(count, listInt8u); + } - return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + static void OnFailureCallback_107(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_107(status); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_107(void * context, uint16_t count, chip::ByteSpan * listOctetString) + { + (static_cast(context))->OnSuccessResponse_107(count, listOctetString); + } - void OnSuccessResponse_4(bool onOff) + static void OnFailureCallback_108(void * context, uint8_t status) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); - NextTest(); + (static_cast(context))->OnFailureResponse_108(status); } -}; -class Test_TC_CC_4_2 : public TestCommand -{ -public: - Test_TC_CC_4_2() : TestCommand("Test_TC_CC_4_2"), mTestIndex(0) {} + static void OnSuccessCallback_108(void * context, uint16_t count, _TestListStructOctet * listStructOctetString) + { + (static_cast(context))->OnSuccessResponse_108(count, listStructOctetString); + } - /////////// TestCommand Interface ///////// - void NextTest() override + static void OnFailureCallback_109(void * context, uint8_t status) { - CHIP_ERROR err = CHIP_NO_ERROR; + (static_cast(context))->OnFailureResponse_109(status); + } - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_4_2\n"); - } + static void OnSuccessCallback_109(void * context, uint64_t epochUs) + { + (static_cast(context))->OnSuccessResponse_109(epochUs); + } - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_4_2\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + static void OnFailureCallback_110(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_110(status); + } - Wait(); + static void OnSuccessCallback_110(void * context, uint64_t epochUs) + { + (static_cast(context))->OnSuccessResponse_110(epochUs); + } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Move saturation up command\n"); - err = TestMoveSaturationUpCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Move saturation down command\n"); - err = TestMoveSaturationDownCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); - break; - } + static void OnFailureCallback_111(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_111(status); + } - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + static void OnSuccessCallback_111(void * context, uint64_t epochUs) + { + (static_cast(context))->OnSuccessResponse_111(epochUs); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 6; + static void OnFailureCallback_112(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_112(status); + } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + static void OnSuccessCallback_112(void * context, uint64_t epochUs) + { + (static_cast(context))->OnSuccessResponse_112(epochUs); + } - static void OnFailureCallback_1(void * context, uint8_t status) + static void OnFailureCallback_113(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_113(status); } - static void OnSuccessCallback_1(void * context, bool onOff) + static void OnSuccessCallback_113(void * context, uint64_t epochUs) { - (static_cast(context))->OnSuccessResponse_1(onOff); + (static_cast(context))->OnSuccessResponse_113(epochUs); } - static void OnFailureCallback_5(void * context, uint8_t status) + static void OnFailureCallback_114(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_5(status); + (static_cast(context))->OnFailureResponse_114(status); } - static void OnSuccessCallback_5(void * context, bool onOff) + static void OnSuccessCallback_114(void * context, uint32_t epochS) { - (static_cast(context))->OnSuccessResponse_5(onOff); + (static_cast(context))->OnSuccessResponse_114(epochS); } - // - // Tests methods - // + static void OnFailureCallback_115(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_115(status); + } - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + static void OnSuccessCallback_115(void * context, uint32_t epochS) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnSuccessResponse_115(epochS); + } - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + static void OnFailureCallback_116(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_116(status); + } - chip::app::Clusters::OnOff::Commands::On::Type request; + static void OnSuccessCallback_116(void * context, uint32_t epochS) + { + (static_cast(context))->OnSuccessResponse_116(epochS); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + static void OnFailureCallback_117(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_117(status); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnSuccessCallback_117(void * context, uint32_t epochS) + { + (static_cast(context))->OnSuccessResponse_117(epochS); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_118(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_118(status); + } - void OnSuccessResponse_0() { NextTest(); } + static void OnSuccessCallback_118(void * context, uint32_t epochS) + { + (static_cast(context))->OnSuccessResponse_118(epochS); + } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + static void OnFailureCallback_119(void * context, uint8_t status) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_119(status); + } - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + static void OnSuccessCallback_119(void * context, bool unsupported) + { + (static_cast(context))->OnSuccessResponse_119(unsupported); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_120(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_120(status); + } - void OnSuccessResponse_1(bool onOff) + static void OnSuccessCallback_120(void * context, bool unsupported) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); - NextTest(); + (static_cast(context))->OnSuccessResponse_120(unsupported); } - CHIP_ERROR TestMoveSaturationUpCommand_2() + // + // Tests methods + // + + CHIP_ERROR TestSendTestCommand_0() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::MoveSaturation::Type; + using requestType = chip::app::Clusters::TestCluster::Commands::Test::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::ColorControl::Commands::MoveSaturation::Type request; - request.moveMode = static_cast(1); - request.rate = 5; - request.optionsMask = 0; - request.optionsOverride = 0; + chip::app::Clusters::TestCluster::Commands::Test::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); + (static_cast(context))->OnSuccessResponse_0(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_0(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_0() { NextTest(); } - CHIP_ERROR TestMoveSaturationDownCommand_3() + CHIP_ERROR TestSendTestNotHandledCommand_1() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::MoveSaturation::Type; + using requestType = chip::app::Clusters::TestCluster::Commands::TestNotHandled::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::ColorControl::Commands::MoveSaturation::Type request; - request.moveMode = static_cast(3); - request.rate = 5; - request.optionsMask = 0; - request.optionsOverride = 0; + chip::app::Clusters::TestCluster::Commands::TestNotHandled::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); + (static_cast(context))->OnSuccessResponse_1(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); + (static_cast(context))->OnFailureResponse_1(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { NextTest(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_1() { ThrowSuccessResponse(); } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() + CHIP_ERROR TestSendTestSpecificCommand_2() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + using requestType = chip::app::Clusters::TestCluster::Commands::TestSpecific::Type; + using responseType = chip::app::Clusters::TestCluster::Commands::TestSpecificResponse::DecodableType; - chip::app::Clusters::OnOff::Commands::Off::Type request; + chip::app::Clusters::TestCluster::Commands::TestSpecific::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); + (static_cast(context))->OnSuccessResponse_2(data.returnValue); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_2(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_4() { NextTest(); } - - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); - } - - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5(bool onOff) + void OnSuccessResponse_2(uint8_t returnValue) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("returnValue", returnValue, 7)); NextTest(); } -}; - -class Test_TC_CC_4_3 : public TestCommand -{ -public: - Test_TC_CC_4_3() : TestCommand("Test_TC_CC_4_3"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestSendTestAddArgumentsCommand_3() { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_4_3\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_4_3\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Step saturation up command\n"); - err = TestStepSaturationUpCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Step saturation down command\n"); - err = TestStepSaturationDownCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); - break; - } - - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } - -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 6; + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + using requestType = chip::app::Clusters::TestCluster::Commands::TestAddArguments::Type; + using responseType = chip::app::Clusters::TestCluster::Commands::TestAddArgumentsResponse::DecodableType; - static void OnFailureCallback_1(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_1(status); - } + chip::app::Clusters::TestCluster::Commands::TestAddArguments::Type request; + request.arg1 = 3; + request.arg2 = 17; - static void OnSuccessCallback_1(void * context, bool onOff) - { - (static_cast(context))->OnSuccessResponse_1(onOff); - } + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(data.returnValue); + }; - static void OnFailureCallback_5(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_5(status); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - static void OnSuccessCallback_5(void * context, bool onOff) + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_3(uint8_t returnValue) { - (static_cast(context))->OnSuccessResponse_5(onOff); + VerifyOrReturn(CheckValue("returnValue", returnValue, 20)); + NextTest(); } - // - // Tests methods - // - - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + CHIP_ERROR TestSendFailingTestAddArgumentsCommand_4() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + using requestType = chip::app::Clusters::TestCluster::Commands::TestAddArguments::Type; + using responseType = chip::app::Clusters::TestCluster::Commands::TestAddArgumentsResponse::DecodableType; - chip::app::Clusters::OnOff::Commands::On::Type request; + chip::app::Clusters::TestCluster::Commands::TestAddArguments::Type request; + request.arg1 = 250; + request.arg2 = 6; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); + (static_cast(context))->OnSuccessResponse_4(data.returnValue); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_4(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { NextTest(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_4(uint8_t returnValue) { ThrowSuccessResponse(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeBooleanDefaultValue_5() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeBoolean(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_5(bool boolean) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValue("boolean", boolean, 0)); NextTest(); } - CHIP_ERROR TestStepSaturationUpCommand_2() + CHIP_ERROR TestWriteAttributeBooleanTrue_6() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::StepSaturation::Type; - using responseType = chip::app::DataModel::NullObjectType; + bool booleanArgument = 1; - chip::app::Clusters::ColorControl::Commands::StepSaturation::Type request; - request.stepMode = static_cast(1); - request.stepSize = 15; - request.transitionTime = 10; - request.optionsMask = 0; - request.optionsOverride = 0; + return cluster.WriteAttributeBoolean(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel(), booleanArgument); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + void OnSuccessResponse_6(bool boolean) { NextTest(); } + + CHIP_ERROR TestReadAttributeBooleanTrue_7() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeBoolean(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_7(bool boolean) + { + VerifyOrReturn(CheckValue("boolean", boolean, 1)); + NextTest(); + } - CHIP_ERROR TestStepSaturationDownCommand_3() + CHIP_ERROR TestWriteAttributeBooleanFalse_8() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::StepSaturation::Type; - using responseType = chip::app::DataModel::NullObjectType; + bool booleanArgument = 0; - chip::app::Clusters::ColorControl::Commands::StepSaturation::Type request; - request.stepMode = static_cast(3); - request.stepSize = 20; - request.transitionTime = 10; - request.optionsMask = 0; - request.optionsOverride = 0; + return cluster.WriteAttributeBoolean(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel(), booleanArgument); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + void OnSuccessResponse_8(bool boolean) { NextTest(); } + + CHIP_ERROR TestReadAttributeBooleanFalse_9() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeBoolean(mOnSuccessCallback_9.Cancel(), mOnFailureCallback_9.Cancel()); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_9(bool boolean) + { + VerifyOrReturn(CheckValue("boolean", boolean, 0)); + NextTest(); + } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() + CHIP_ERROR TestReadAttributeBitmap8DefaultValue_10() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeBitmap8(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); + } - chip::app::Clusters::OnOff::Commands::Off::Type request; + void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); - }; + void OnSuccessResponse_10(uint8_t bitmap8) + { + VerifyOrReturn(CheckValue("bitmap8", bitmap8, 0)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeBitmap8MaxValue_11() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint8_t bitmap8Argument = 255; + + return cluster.WriteAttributeBitmap8(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel(), bitmap8Argument); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4() { NextTest(); } + void OnSuccessResponse_11(uint8_t bitmap8) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() + CHIP_ERROR TestReadAttributeBitmap8MaxValue_12() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + return cluster.ReadAttributeBitmap8(mOnSuccessCallback_12.Cancel(), mOnFailureCallback_12.Cancel()); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_12(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5(bool onOff) + void OnSuccessResponse_12(uint8_t bitmap8) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("bitmap8", bitmap8, 255)); NextTest(); } -}; -class Test_TC_CC_4_4 : public TestCommand -{ -public: - Test_TC_CC_4_4() : TestCommand("Test_TC_CC_4_4"), mTestIndex(0) {} + CHIP_ERROR TestWriteAttributeBitmap8MinValue_13() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - /////////// TestCommand Interface ///////// - void NextTest() override + uint8_t bitmap8Argument = 0; + + return cluster.WriteAttributeBitmap8(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel(), bitmap8Argument); + } + + void OnFailureResponse_13(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_13(uint8_t bitmap8) { NextTest(); } + + CHIP_ERROR TestReadAttributeBitmap8MinValue_14() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_4_4\n"); - } + return cluster.ReadAttributeBitmap8(mOnSuccessCallback_14.Cancel(), mOnFailureCallback_14.Cancel()); + } - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_4_4\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + void OnFailureResponse_14(uint8_t status) { ThrowFailureResponse(); } - Wait(); + void OnSuccessResponse_14(uint8_t bitmap8) + { + VerifyOrReturn(CheckValue("bitmap8", bitmap8, 0)); + NextTest(); + } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Move To current hue and saturation command\n"); - err = TestMoveToCurrentHueAndSaturationCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); - break; - } + CHIP_ERROR TestReadAttributeBitmap16DefaultValue_15() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeBitmap16(mOnSuccessCallback_15.Cancel(), mOnFailureCallback_15.Cancel()); + } + + void OnFailureResponse_15(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_15(uint16_t bitmap16) + { + VerifyOrReturn(CheckValue("bitmap16", bitmap16, 0U)); + NextTest(); + } + + CHIP_ERROR TestWriteAttributeBitmap16MaxValue_16() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + uint16_t bitmap16Argument = 65535U; + + return cluster.WriteAttributeBitmap16(mOnSuccessCallback_16.Cancel(), mOnFailureCallback_16.Cancel(), bitmap16Argument); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 5; + void OnFailureResponse_16(uint8_t status) { ThrowFailureResponse(); } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + void OnSuccessResponse_16(uint16_t bitmap16) { NextTest(); } - static void OnFailureCallback_1(void * context, uint8_t status) + CHIP_ERROR TestReadAttributeBitmap16MaxValue_17() { - (static_cast(context))->OnFailureResponse_1(status); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeBitmap16(mOnSuccessCallback_17.Cancel(), mOnFailureCallback_17.Cancel()); } - static void OnSuccessCallback_1(void * context, bool onOff) + void OnFailureResponse_17(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_17(uint16_t bitmap16) { - (static_cast(context))->OnSuccessResponse_1(onOff); + VerifyOrReturn(CheckValue("bitmap16", bitmap16, 65535U)); + NextTest(); } - static void OnFailureCallback_4(void * context, uint8_t status) + CHIP_ERROR TestWriteAttributeBitmap16MinValue_18() { - (static_cast(context))->OnFailureResponse_4(status); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint16_t bitmap16Argument = 0U; + + return cluster.WriteAttributeBitmap16(mOnSuccessCallback_18.Cancel(), mOnFailureCallback_18.Cancel(), bitmap16Argument); } - static void OnSuccessCallback_4(void * context, bool onOff) + void OnFailureResponse_18(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_18(uint16_t bitmap16) { NextTest(); } + + CHIP_ERROR TestReadAttributeBitmap16MinValue_19() { - (static_cast(context))->OnSuccessResponse_4(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeBitmap16(mOnSuccessCallback_19.Cancel(), mOnFailureCallback_19.Cancel()); } - // - // Tests methods - // + void OnFailureResponse_19(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + void OnSuccessResponse_19(uint16_t bitmap16) { - chip::Controller::OnOffClusterTest cluster; + VerifyOrReturn(CheckValue("bitmap16", bitmap16, 0U)); + NextTest(); + } + + CHIP_ERROR TestReadAttributeBitmap32DefaultValue_20() + { + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeBitmap32(mOnSuccessCallback_20.Cancel(), mOnFailureCallback_20.Cancel()); + } - chip::app::Clusters::OnOff::Commands::On::Type request; + void OnFailureResponse_20(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + void OnSuccessResponse_20(uint32_t bitmap32) + { + VerifyOrReturn(CheckValue("bitmap32", bitmap32, 0UL)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeBitmap32MaxValue_21() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint32_t bitmap32Argument = 4294967295UL; + + return cluster.WriteAttributeBitmap32(mOnSuccessCallback_21.Cancel(), mOnFailureCallback_21.Cancel(), bitmap32Argument); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_21(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_21(uint32_t bitmap32) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeBitmap32MaxValue_22() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeBitmap32(mOnSuccessCallback_22.Cancel(), mOnFailureCallback_22.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_22(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_22(uint32_t bitmap32) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValue("bitmap32", bitmap32, 4294967295UL)); NextTest(); } - CHIP_ERROR TestMoveToCurrentHueAndSaturationCommand_2() + CHIP_ERROR TestWriteAttributeBitmap32MinValue_23() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::MoveToHueAndSaturation::Type; - using responseType = chip::app::DataModel::NullObjectType; + uint32_t bitmap32Argument = 0UL; - chip::app::Clusters::ColorControl::Commands::MoveToHueAndSaturation::Type request; - request.hue = 40; - request.saturation = 160; - request.transitionTime = 10U; - request.optionsMask = 0; - request.optionsOverride = 0; + return cluster.WriteAttributeBitmap32(mOnSuccessCallback_23.Cancel(), mOnFailureCallback_23.Cancel(), bitmap32Argument); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + void OnFailureResponse_23(uint8_t status) { ThrowFailureResponse(); } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + void OnSuccessResponse_23(uint32_t bitmap32) { NextTest(); } + + CHIP_ERROR TestReadAttributeBitmap32MinValue_24() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeBitmap32(mOnSuccessCallback_24.Cancel(), mOnFailureCallback_24.Cancel()); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_24(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_24(uint32_t bitmap32) + { + VerifyOrReturn(CheckValue("bitmap32", bitmap32, 0UL)); + NextTest(); + } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() + CHIP_ERROR TestReadAttributeBitmap64DefaultValue_25() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeBitmap64(mOnSuccessCallback_25.Cancel(), mOnFailureCallback_25.Cancel()); + } - chip::app::Clusters::OnOff::Commands::Off::Type request; + void OnFailureResponse_25(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + void OnSuccessResponse_25(uint64_t bitmap64) + { + VerifyOrReturn(CheckValue("bitmap64", bitmap64, 0ULL)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeBitmap64MaxValue_26() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint64_t bitmap64Argument = 18446744073709551615ULL; + + return cluster.WriteAttributeBitmap64(mOnSuccessCallback_26.Cancel(), mOnFailureCallback_26.Cancel(), bitmap64Argument); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_26(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_26(uint64_t bitmap64) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() + CHIP_ERROR TestReadAttributeBitmap64MaxValue_27() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + return cluster.ReadAttributeBitmap64(mOnSuccessCallback_27.Cancel(), mOnFailureCallback_27.Cancel()); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_27(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4(bool onOff) + void OnSuccessResponse_27(uint64_t bitmap64) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("bitmap64", bitmap64, 18446744073709551615ULL)); NextTest(); } -}; - -class Test_TC_CC_5_1 : public TestCommand -{ -public: - Test_TC_CC_5_1() : TestCommand("Test_TC_CC_5_1"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestWriteAttributeBitmap64MinValue_28() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_5_1\n"); - } + uint64_t bitmap64Argument = 0ULL; - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_5_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + return cluster.WriteAttributeBitmap64(mOnSuccessCallback_28.Cancel(), mOnFailureCallback_28.Cancel(), bitmap64Argument); + } - Wait(); + void OnFailureResponse_28(uint8_t status) { ThrowFailureResponse(); } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Move to Color command\n"); - err = TestMoveToColorCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); - break; - } + void OnSuccessResponse_28(uint64_t bitmap64) { NextTest(); } - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } + CHIP_ERROR TestReadAttributeBitmap64MinValue_29() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 5; + return cluster.ReadAttributeBitmap64(mOnSuccessCallback_29.Cancel(), mOnFailureCallback_29.Cancel()); + } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + void OnFailureResponse_29(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_1(void * context, uint8_t status) + void OnSuccessResponse_29(uint64_t bitmap64) { - (static_cast(context))->OnFailureResponse_1(status); + VerifyOrReturn(CheckValue("bitmap64", bitmap64, 0ULL)); + NextTest(); } - static void OnSuccessCallback_1(void * context, bool onOff) + CHIP_ERROR TestReadAttributeInt8uDefaultValue_30() { - (static_cast(context))->OnSuccessResponse_1(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeInt8u(mOnSuccessCallback_30.Cancel(), mOnFailureCallback_30.Cancel()); } - static void OnFailureCallback_4(void * context, uint8_t status) + void OnFailureResponse_30(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_30(uint8_t int8u) { - (static_cast(context))->OnFailureResponse_4(status); + VerifyOrReturn(CheckValue("int8u", int8u, 0)); + NextTest(); } - static void OnSuccessCallback_4(void * context, bool onOff) + CHIP_ERROR TestWriteAttributeInt8uMaxValue_31() { - (static_cast(context))->OnSuccessResponse_4(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint8_t int8uArgument = 255; + + return cluster.WriteAttributeInt8u(mOnSuccessCallback_31.Cancel(), mOnFailureCallback_31.Cancel(), int8uArgument); } - // - // Tests methods - // + void OnFailureResponse_31(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + void OnSuccessResponse_31(uint8_t int8u) { NextTest(); } + + CHIP_ERROR TestReadAttributeInt8uMaxValue_32() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeInt8u(mOnSuccessCallback_32.Cancel(), mOnFailureCallback_32.Cancel()); + } - chip::app::Clusters::OnOff::Commands::On::Type request; + void OnFailureResponse_32(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + void OnSuccessResponse_32(uint8_t int8u) + { + VerifyOrReturn(CheckValue("int8u", int8u, 255)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeInt8uMinValue_33() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint8_t int8uArgument = 0; + + return cluster.WriteAttributeInt8u(mOnSuccessCallback_33.Cancel(), mOnFailureCallback_33.Cancel(), int8uArgument); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_33(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_33(uint8_t int8u) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeInt8uMinValue_34() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeInt8u(mOnSuccessCallback_34.Cancel(), mOnFailureCallback_34.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_34(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_34(uint8_t int8u) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValue("int8u", int8u, 0)); NextTest(); } - CHIP_ERROR TestMoveToColorCommand_2() + CHIP_ERROR TestReadAttributeInt16uDefaultValue_35() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::MoveToColor::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeInt16u(mOnSuccessCallback_35.Cancel(), mOnFailureCallback_35.Cancel()); + } - chip::app::Clusters::ColorControl::Commands::MoveToColor::Type request; - request.colorX = 200U; - request.colorY = 300U; - request.transitionTime = 20U; - request.optionsMask = 0; - request.optionsOverride = 0; + void OnFailureResponse_35(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + void OnSuccessResponse_35(uint16_t int16u) + { + VerifyOrReturn(CheckValue("int16u", int16u, 0U)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeInt16uMaxValue_36() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint16_t int16uArgument = 65535U; + + return cluster.WriteAttributeInt16u(mOnSuccessCallback_36.Cancel(), mOnFailureCallback_36.Cancel(), int16uArgument); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_36(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_36(uint16_t int16u) { NextTest(); } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() + CHIP_ERROR TestReadAttributeInt16uMaxValue_37() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeInt16u(mOnSuccessCallback_37.Cancel(), mOnFailureCallback_37.Cancel()); + } - chip::app::Clusters::OnOff::Commands::Off::Type request; + void OnFailureResponse_37(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + void OnSuccessResponse_37(uint16_t int16u) + { + VerifyOrReturn(CheckValue("int16u", int16u, 65535U)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeInt16uMinValue_38() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint16_t int16uArgument = 0U; + + return cluster.WriteAttributeInt16u(mOnSuccessCallback_38.Cancel(), mOnFailureCallback_38.Cancel(), int16uArgument); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_38(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_38(uint16_t int16u) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() + CHIP_ERROR TestReadAttributeInt16uMinValue_39() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + return cluster.ReadAttributeInt16u(mOnSuccessCallback_39.Cancel(), mOnFailureCallback_39.Cancel()); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_39(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4(bool onOff) + void OnSuccessResponse_39(uint16_t int16u) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("int16u", int16u, 0U)); NextTest(); } -}; - -class Test_TC_CC_5_2 : public TestCommand -{ -public: - Test_TC_CC_5_2() : TestCommand("Test_TC_CC_5_2"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestReadAttributeInt32uDefaultValue_40() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_5_2\n"); - } + return cluster.ReadAttributeInt32u(mOnSuccessCallback_40.Cancel(), mOnFailureCallback_40.Cancel()); + } - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_5_2\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + void OnFailureResponse_40(uint8_t status) { ThrowFailureResponse(); } - Wait(); + void OnSuccessResponse_40(uint32_t int32u) + { + VerifyOrReturn(CheckValue("int32u", int32u, 0UL)); + NextTest(); + } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Move Color command\n"); - err = TestMoveColorCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Stop Move Step command\n"); - err = TestStopMoveStepCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); - break; - } + CHIP_ERROR TestWriteAttributeInt32uMaxValue_41() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + uint32_t int32uArgument = 4294967295UL; + + return cluster.WriteAttributeInt32u(mOnSuccessCallback_41.Cancel(), mOnFailureCallback_41.Cancel(), int32uArgument); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 6; + void OnFailureResponse_41(uint8_t status) { ThrowFailureResponse(); } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + void OnSuccessResponse_41(uint32_t int32u) { NextTest(); } - static void OnFailureCallback_1(void * context, uint8_t status) + CHIP_ERROR TestReadAttributeInt32uMaxValue_42() { - (static_cast(context))->OnFailureResponse_1(status); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeInt32u(mOnSuccessCallback_42.Cancel(), mOnFailureCallback_42.Cancel()); } - static void OnSuccessCallback_1(void * context, bool onOff) + void OnFailureResponse_42(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_42(uint32_t int32u) { - (static_cast(context))->OnSuccessResponse_1(onOff); + VerifyOrReturn(CheckValue("int32u", int32u, 4294967295UL)); + NextTest(); } - static void OnFailureCallback_5(void * context, uint8_t status) + CHIP_ERROR TestWriteAttributeInt32uMinValue_43() { - (static_cast(context))->OnFailureResponse_5(status); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint32_t int32uArgument = 0UL; + + return cluster.WriteAttributeInt32u(mOnSuccessCallback_43.Cancel(), mOnFailureCallback_43.Cancel(), int32uArgument); } - static void OnSuccessCallback_5(void * context, bool onOff) + void OnFailureResponse_43(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_43(uint32_t int32u) { NextTest(); } + + CHIP_ERROR TestReadAttributeInt32uMinValue_44() { - (static_cast(context))->OnSuccessResponse_5(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeInt32u(mOnSuccessCallback_44.Cancel(), mOnFailureCallback_44.Cancel()); } - // - // Tests methods - // + void OnFailureResponse_44(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + void OnSuccessResponse_44(uint32_t int32u) { - chip::Controller::OnOffClusterTest cluster; + VerifyOrReturn(CheckValue("int32u", int32u, 0UL)); + NextTest(); + } + + CHIP_ERROR TestReadAttributeInt64uDefaultValue_45() + { + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeInt64u(mOnSuccessCallback_45.Cancel(), mOnFailureCallback_45.Cancel()); + } - chip::app::Clusters::OnOff::Commands::On::Type request; + void OnFailureResponse_45(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + void OnSuccessResponse_45(uint64_t int64u) + { + VerifyOrReturn(CheckValue("int64u", int64u, 0ULL)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeInt64uMaxValue_46() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint64_t int64uArgument = 18446744073709551615ULL; + + return cluster.WriteAttributeInt64u(mOnSuccessCallback_46.Cancel(), mOnFailureCallback_46.Cancel(), int64uArgument); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_46(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_46(uint64_t int64u) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeInt64uMaxValue_47() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeInt64u(mOnSuccessCallback_47.Cancel(), mOnFailureCallback_47.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_47(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_47(uint64_t int64u) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValue("int64u", int64u, 18446744073709551615ULL)); NextTest(); } - CHIP_ERROR TestMoveColorCommand_2() + CHIP_ERROR TestWriteAttributeInt64uMinValue_48() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::MoveColor::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::MoveColor::Type request; - request.rateX = 15; - request.rateY = 20; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + uint64_t int64uArgument = 0ULL; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeInt64u(mOnSuccessCallback_48.Cancel(), mOnFailureCallback_48.Cancel(), int64uArgument); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_48(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_48(uint64_t int64u) { NextTest(); } - CHIP_ERROR TestStopMoveStepCommand_3() + CHIP_ERROR TestReadAttributeInt64uMinValue_49() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::StopMoveStep::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeInt64u(mOnSuccessCallback_49.Cancel(), mOnFailureCallback_49.Cancel()); + } - chip::app::Clusters::ColorControl::Commands::StopMoveStep::Type request; - request.optionsMask = 0; - request.optionsOverride = 0; + void OnFailureResponse_49(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + void OnSuccessResponse_49(uint64_t int64u) + { + VerifyOrReturn(CheckValue("int64u", int64u, 0ULL)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestReadAttributeInt8sDefaultValue_50() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeInt8s(mOnSuccessCallback_50.Cancel(), mOnFailureCallback_50.Cancel()); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_50(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_50(int8_t int8s) + { + VerifyOrReturn(CheckValue("int8s", int8s, 0)); + NextTest(); + } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() + CHIP_ERROR TestWriteAttributeInt8sMaxValue_51() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Off::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); - }; + int8_t int8sArgument = 127; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeInt8s(mOnSuccessCallback_51.Cancel(), mOnFailureCallback_51.Cancel(), int8sArgument); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_51(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4() { NextTest(); } + void OnSuccessResponse_51(int8_t int8s) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() + CHIP_ERROR TestReadAttributeInt8sMaxValue_52() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + return cluster.ReadAttributeInt8s(mOnSuccessCallback_52.Cancel(), mOnFailureCallback_52.Cancel()); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_52(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5(bool onOff) + void OnSuccessResponse_52(int8_t int8s) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("int8s", int8s, 127)); NextTest(); } -}; - -class Test_TC_CC_5_3 : public TestCommand -{ -public: - Test_TC_CC_5_3() : TestCommand("Test_TC_CC_5_3"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestWriteAttributeInt8sMinValue_53() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_5_3\n"); - } + int8_t int8sArgument = -128; - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_5_3\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + return cluster.WriteAttributeInt8s(mOnSuccessCallback_53.Cancel(), mOnFailureCallback_53.Cancel(), int8sArgument); + } - Wait(); + void OnFailureResponse_53(uint8_t status) { ThrowFailureResponse(); } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Step Color command\n"); - err = TestStepColorCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); - break; - } + void OnSuccessResponse_53(int8_t int8s) { NextTest(); } - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } + CHIP_ERROR TestReadAttributeInt8sMinValue_54() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 5; + return cluster.ReadAttributeInt8s(mOnSuccessCallback_54.Cancel(), mOnFailureCallback_54.Cancel()); + } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + void OnFailureResponse_54(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_1(void * context, uint8_t status) + void OnSuccessResponse_54(int8_t int8s) { - (static_cast(context))->OnFailureResponse_1(status); + VerifyOrReturn(CheckValue("int8s", int8s, -128)); + NextTest(); } - static void OnSuccessCallback_1(void * context, bool onOff) + CHIP_ERROR TestWriteAttributeInt8sDefaultValue_55() { - (static_cast(context))->OnSuccessResponse_1(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + int8_t int8sArgument = 0; + + return cluster.WriteAttributeInt8s(mOnSuccessCallback_55.Cancel(), mOnFailureCallback_55.Cancel(), int8sArgument); } - static void OnFailureCallback_4(void * context, uint8_t status) + void OnFailureResponse_55(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_55(int8_t int8s) { NextTest(); } + + CHIP_ERROR TestReadAttributeInt8sDefaultValue_56() { - (static_cast(context))->OnFailureResponse_4(status); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeInt8s(mOnSuccessCallback_56.Cancel(), mOnFailureCallback_56.Cancel()); } - static void OnSuccessCallback_4(void * context, bool onOff) + void OnFailureResponse_56(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_56(int8_t int8s) { - (static_cast(context))->OnSuccessResponse_4(onOff); + VerifyOrReturn(CheckValue("int8s", int8s, 0)); + NextTest(); } - // - // Tests methods - // - - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + CHIP_ERROR TestReadAttributeInt16sDefaultValue_57() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeInt16s(mOnSuccessCallback_57.Cancel(), mOnFailureCallback_57.Cancel()); + } - chip::app::Clusters::OnOff::Commands::On::Type request; + void OnFailureResponse_57(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + void OnSuccessResponse_57(int16_t int16s) + { + VerifyOrReturn(CheckValue("int16s", int16s, 0)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeInt16sMaxValue_58() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + int16_t int16sArgument = 32767; + + return cluster.WriteAttributeInt16s(mOnSuccessCallback_58.Cancel(), mOnFailureCallback_58.Cancel(), int16sArgument); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_58(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_58(int16_t int16s) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeInt16sMaxValue_59() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeInt16s(mOnSuccessCallback_59.Cancel(), mOnFailureCallback_59.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_59(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_59(int16_t int16s) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValue("int16s", int16s, 32767)); NextTest(); } - CHIP_ERROR TestStepColorCommand_2() + CHIP_ERROR TestWriteAttributeInt16sMinValue_60() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::StepColor::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::StepColor::Type request; - request.stepX = 15; - request.stepY = 20; - request.transitionTime = 50U; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + int16_t int16sArgument = -32768; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeInt16s(mOnSuccessCallback_60.Cancel(), mOnFailureCallback_60.Cancel(), int16sArgument); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_60(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_60(int16_t int16s) { NextTest(); } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() + CHIP_ERROR TestReadAttributeInt16sMinValue_61() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeInt16s(mOnSuccessCallback_61.Cancel(), mOnFailureCallback_61.Cancel()); + } - chip::app::Clusters::OnOff::Commands::Off::Type request; + void OnFailureResponse_61(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + void OnSuccessResponse_61(int16_t int16s) + { + VerifyOrReturn(CheckValue("int16s", int16s, -32768)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeInt16sDefaultValue_62() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + int16_t int16sArgument = 0; + + return cluster.WriteAttributeInt16s(mOnSuccessCallback_62.Cancel(), mOnFailureCallback_62.Cancel(), int16sArgument); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_62(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_62(int16_t int16s) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() + CHIP_ERROR TestReadAttributeInt16sDefaultValue_63() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + return cluster.ReadAttributeInt16s(mOnSuccessCallback_63.Cancel(), mOnFailureCallback_63.Cancel()); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_63(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4(bool onOff) + void OnSuccessResponse_63(int16_t int16s) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("int16s", int16s, 0)); NextTest(); } -}; -class Test_TC_CC_6_1 : public TestCommand -{ -public: - Test_TC_CC_6_1() : TestCommand("Test_TC_CC_6_1"), mTestIndex(0) {} - - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestReadAttributeInt32sDefaultValue_64() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_6_1\n"); - } + return cluster.ReadAttributeInt32s(mOnSuccessCallback_64.Cancel(), mOnFailureCallback_64.Cancel()); + } - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_6_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + void OnFailureResponse_64(uint8_t status) { ThrowFailureResponse(); } - Wait(); + void OnSuccessResponse_64(int32_t int32s) + { + VerifyOrReturn(CheckValue("int32s", int32s, 0L)); + NextTest(); + } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Move To Color Temperature command\n"); - err = TestMoveToColorTemperatureCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); - break; - } + CHIP_ERROR TestWriteAttributeInt32sMaxValue_65() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + int32_t int32sArgument = 2147483647L; + + return cluster.WriteAttributeInt32s(mOnSuccessCallback_65.Cancel(), mOnFailureCallback_65.Cancel(), int32sArgument); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 5; + void OnFailureResponse_65(uint8_t status) { ThrowFailureResponse(); } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + void OnSuccessResponse_65(int32_t int32s) { NextTest(); } - static void OnFailureCallback_1(void * context, uint8_t status) + CHIP_ERROR TestReadAttributeInt32sMaxValue_66() { - (static_cast(context))->OnFailureResponse_1(status); - } + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_1(void * context, bool onOff) - { - (static_cast(context))->OnSuccessResponse_1(onOff); + return cluster.ReadAttributeInt32s(mOnSuccessCallback_66.Cancel(), mOnFailureCallback_66.Cancel()); } - static void OnFailureCallback_4(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_4(status); - } + void OnFailureResponse_66(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_4(void * context, bool onOff) + void OnSuccessResponse_66(int32_t int32s) { - (static_cast(context))->OnSuccessResponse_4(onOff); + VerifyOrReturn(CheckValue("int32s", int32s, 2147483647L)); + NextTest(); } - // - // Tests methods - // - - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + CHIP_ERROR TestWriteAttributeInt32sMinValue_67() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::On::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + int32_t int32sArgument = -2147483648L; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeInt32s(mOnSuccessCallback_67.Cancel(), mOnFailureCallback_67.Cancel(), int32sArgument); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_67(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_67(int32_t int32s) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeInt32sMinValue_68() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeInt32s(mOnSuccessCallback_68.Cancel(), mOnFailureCallback_68.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_68(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_68(int32_t int32s) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValue("int32s", int32s, -2147483648L)); NextTest(); } - CHIP_ERROR TestMoveToColorTemperatureCommand_2() + CHIP_ERROR TestWriteAttributeInt32sDefaultValue_69() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::MoveToColorTemperature::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::MoveToColorTemperature::Type request; - request.colorTemperature = 100U; - request.transitionTime = 10U; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + int32_t int32sArgument = 0L; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeInt32s(mOnSuccessCallback_69.Cancel(), mOnFailureCallback_69.Cancel(), int32sArgument); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_69(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_69(int32_t int32s) { NextTest(); } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() + CHIP_ERROR TestReadAttributeInt32sDefaultValue_70() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Off::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeInt32s(mOnSuccessCallback_70.Cancel(), mOnFailureCallback_70.Cancel()); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_70(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_70(int32_t int32s) + { + VerifyOrReturn(CheckValue("int32s", int32s, 0L)); + NextTest(); + } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() + CHIP_ERROR TestReadAttributeInt64sDefaultValue_71() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + return cluster.ReadAttributeInt64s(mOnSuccessCallback_71.Cancel(), mOnFailureCallback_71.Cancel()); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_71(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4(bool onOff) + void OnSuccessResponse_71(int64_t int64s) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("int64s", int64s, 0LL)); NextTest(); } -}; - -class Test_TC_CC_6_2 : public TestCommand -{ -public: - Test_TC_CC_6_2() : TestCommand("Test_TC_CC_6_2"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestWriteAttributeInt64sMaxValue_72() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_6_2\n"); - } + int64_t int64sArgument = 9223372036854775807LL; - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_6_2\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + return cluster.WriteAttributeInt64s(mOnSuccessCallback_72.Cancel(), mOnFailureCallback_72.Cancel(), int64sArgument); + } - Wait(); + void OnFailureResponse_72(uint8_t status) { ThrowFailureResponse(); } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Move up color temperature command\n"); - err = TestMoveUpColorTemperatureCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Stop Color Temperature command\n"); - err = TestStopColorTemperatureCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Move down color temperature command\n"); - err = TestMoveDownColorTemperatureCommand_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_6(); - break; - } + void OnSuccessResponse_72(int64_t int64s) { NextTest(); } - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } + CHIP_ERROR TestReadAttributeInt64sMaxValue_73() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 7; + return cluster.ReadAttributeInt64s(mOnSuccessCallback_73.Cancel(), mOnFailureCallback_73.Cancel()); + } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; - chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; + void OnFailureResponse_73(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_1(void * context, uint8_t status) + void OnSuccessResponse_73(int64_t int64s) { - (static_cast(context))->OnFailureResponse_1(status); + VerifyOrReturn(CheckValue("int64s", int64s, 9223372036854775807LL)); + NextTest(); } - static void OnSuccessCallback_1(void * context, bool onOff) + CHIP_ERROR TestWriteAttributeInt64sMinValue_74() { - (static_cast(context))->OnSuccessResponse_1(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + int64_t int64sArgument = -9223372036854775807LL; + + return cluster.WriteAttributeInt64s(mOnSuccessCallback_74.Cancel(), mOnFailureCallback_74.Cancel(), int64sArgument); } - static void OnFailureCallback_6(void * context, uint8_t status) + void OnFailureResponse_74(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_74(int64_t int64s) { NextTest(); } + + CHIP_ERROR TestReadAttributeInt64sMinValue_75() { - (static_cast(context))->OnFailureResponse_6(status); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeInt64s(mOnSuccessCallback_75.Cancel(), mOnFailureCallback_75.Cancel()); } - static void OnSuccessCallback_6(void * context, bool onOff) + void OnFailureResponse_75(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_75(int64_t int64s) { - (static_cast(context))->OnSuccessResponse_6(onOff); + VerifyOrReturn(CheckValue("int64s", int64s, -9223372036854775807LL)); + NextTest(); } - // - // Tests methods - // - - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + CHIP_ERROR TestWriteAttributeInt64sDefaultValue_76() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + int64_t int64sArgument = 0LL; - chip::app::Clusters::OnOff::Commands::On::Type request; + return cluster.WriteAttributeInt64s(mOnSuccessCallback_76.Cancel(), mOnFailureCallback_76.Cancel(), int64sArgument); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + void OnFailureResponse_76(uint8_t status) { ThrowFailureResponse(); } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + void OnSuccessResponse_76(int64_t int64s) { NextTest(); } + + CHIP_ERROR TestReadAttributeInt64sDefaultValue_77() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeInt64s(mOnSuccessCallback_77.Cancel(), mOnFailureCallback_77.Cancel()); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_77(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_77(int64_t int64s) + { + VerifyOrReturn(CheckValue("int64s", int64s, 0LL)); + NextTest(); + } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeEnum8DefaultValue_78() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeEnum8(mOnSuccessCallback_78.Cancel(), mOnFailureCallback_78.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_78(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_78(uint8_t enum8) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValue("enum8", enum8, 0)); NextTest(); } - CHIP_ERROR TestMoveUpColorTemperatureCommand_2() + CHIP_ERROR TestWriteAttributeEnum8MaxValue_79() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type request; - request.moveMode = static_cast(1); - request.rate = 10U; - request.colorTemperatureMinimum = 1U; - request.colorTemperatureMaximum = 255U; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + uint8_t enum8Argument = 255; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeEnum8(mOnSuccessCallback_79.Cancel(), mOnFailureCallback_79.Cancel(), enum8Argument); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_79(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_79(uint8_t enum8) { NextTest(); } - CHIP_ERROR TestStopColorTemperatureCommand_3() + CHIP_ERROR TestReadAttributeEnum8MaxValue_80() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeEnum8(mOnSuccessCallback_80.Cancel(), mOnFailureCallback_80.Cancel()); + } - chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type request; - request.moveMode = static_cast(0); - request.rate = 10U; - request.colorTemperatureMinimum = 1U; - request.colorTemperatureMaximum = 255U; - request.optionsMask = 0; - request.optionsOverride = 0; + void OnFailureResponse_80(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + void OnSuccessResponse_80(uint8_t enum8) + { + VerifyOrReturn(CheckValue("enum8", enum8, 255)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeEnum8MinValue_81() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint8_t enum8Argument = 0; + + return cluster.WriteAttributeEnum8(mOnSuccessCallback_81.Cancel(), mOnFailureCallback_81.Cancel(), enum8Argument); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_81(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_81(uint8_t enum8) { NextTest(); } - CHIP_ERROR TestMoveDownColorTemperatureCommand_4() + CHIP_ERROR TestReadAttributeEnum8MinValue_82() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeEnum8(mOnSuccessCallback_82.Cancel(), mOnFailureCallback_82.Cancel()); + } - chip::app::Clusters::ColorControl::Commands::MoveColorTemperature::Type request; - request.moveMode = static_cast(3); - request.rate = 20U; - request.colorTemperatureMinimum = 1U; - request.colorTemperatureMaximum = 255U; - request.optionsMask = 0; - request.optionsOverride = 0; + void OnFailureResponse_82(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); - }; + void OnSuccessResponse_82(uint8_t enum8) + { + VerifyOrReturn(CheckValue("enum8", enum8, 0)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestReadAttributeEnum16DefaultValue_83() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeEnum16(mOnSuccessCallback_83.Cancel(), mOnFailureCallback_83.Cancel()); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_83(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4() { NextTest(); } + void OnSuccessResponse_83(uint16_t enum16) + { + VerifyOrReturn(CheckValue("enum16", enum16, 0U)); + NextTest(); + } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_5() + CHIP_ERROR TestWriteAttributeEnum16MaxValue_84() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Off::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_5(); - }; + uint16_t enum16Argument = 65535U; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_5(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeEnum16(mOnSuccessCallback_84.Cancel(), mOnFailureCallback_84.Cancel(), enum16Argument); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_84(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5() { NextTest(); } + void OnSuccessResponse_84(uint16_t enum16) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_6() + CHIP_ERROR TestReadAttributeEnum16MaxValue_85() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); + return cluster.ReadAttributeEnum16(mOnSuccessCallback_85.Cancel(), mOnFailureCallback_85.Cancel()); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_85(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_6(bool onOff) + void OnSuccessResponse_85(uint16_t enum16) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValue("enum16", enum16, 65535U)); NextTest(); } -}; - -class Test_TC_CC_6_3 : public TestCommand -{ -public: - Test_TC_CC_6_3() : TestCommand("Test_TC_CC_6_3"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestWriteAttributeEnum16MinValue_86() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_6_3\n"); - } + uint16_t enum16Argument = 0U; - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_6_3\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + return cluster.WriteAttributeEnum16(mOnSuccessCallback_86.Cancel(), mOnFailureCallback_86.Cancel(), enum16Argument); + } - Wait(); + void OnFailureResponse_86(uint8_t status) { ThrowFailureResponse(); } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Step up color temperature command\n"); - err = TestStepUpColorTemperatureCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Step down color temperature command\n"); - err = TestStepDownColorTemperatureCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); - break; - } + void OnSuccessResponse_86(uint16_t enum16) { NextTest(); } - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } + CHIP_ERROR TestReadAttributeEnum16MinValue_87() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 6; + return cluster.ReadAttributeEnum16(mOnSuccessCallback_87.Cancel(), mOnFailureCallback_87.Cancel()); + } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + void OnFailureResponse_87(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_1(void * context, uint8_t status) + void OnSuccessResponse_87(uint16_t enum16) { - (static_cast(context))->OnFailureResponse_1(status); + VerifyOrReturn(CheckValue("enum16", enum16, 0U)); + NextTest(); } - static void OnSuccessCallback_1(void * context, bool onOff) + CHIP_ERROR TestReadAttributeOctetStringDefaultValue_88() { - (static_cast(context))->OnSuccessResponse_1(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeOctetString(mOnSuccessCallback_88.Cancel(), mOnFailureCallback_88.Cancel()); } - static void OnFailureCallback_5(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_5(status); - } + void OnFailureResponse_88(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_5(void * context, bool onOff) + void OnSuccessResponse_88(chip::ByteSpan octetString) { - (static_cast(context))->OnSuccessResponse_5(onOff); + VerifyOrReturn(CheckValueAsString("octetString", octetString, "")); + NextTest(); } - // - // Tests methods - // - - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + CHIP_ERROR TestWriteAttributeOctetString_89() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::On::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + chip::ByteSpan octetStringArgument = chip::ByteSpan(chip::Uint8::from_const_char("TestValue"), strlen("TestValue")); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeOctetString(mOnSuccessCallback_89.Cancel(), mOnFailureCallback_89.Cancel(), + octetStringArgument); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_89(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_89(chip::ByteSpan octetString) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeOctetString_90() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeOctetString(mOnSuccessCallback_90.Cancel(), mOnFailureCallback_90.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_90(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_90(chip::ByteSpan octetString) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValueAsString("octetString", octetString, "TestValue")); NextTest(); } - CHIP_ERROR TestStepUpColorTemperatureCommand_2() + CHIP_ERROR TestWriteAttributeOctetString_91() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::StepColorTemperature::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::StepColorTemperature::Type request; - request.stepMode = static_cast(1); - request.stepSize = 5U; - request.transitionTime = 50U; - request.colorTemperatureMinimum = 5U; - request.colorTemperatureMaximum = 100U; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + chip::ByteSpan octetStringArgument = + chip::ByteSpan(chip::Uint8::from_const_char("TestValueLongerThan10"), strlen("TestValueLongerThan10")); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeOctetString(mOnSuccessCallback_91.Cancel(), mOnFailureCallback_91.Cancel(), + octetStringArgument); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_91(uint8_t status) { NextTest(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_91(chip::ByteSpan octetString) { ThrowSuccessResponse(); } - CHIP_ERROR TestStepDownColorTemperatureCommand_3() + CHIP_ERROR TestReadAttributeOctetString_92() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::StepColorTemperature::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::StepColorTemperature::Type request; - request.stepMode = static_cast(3); - request.stepSize = 5U; - request.transitionTime = 50U; - request.colorTemperatureMinimum = 5U; - request.colorTemperatureMaximum = 100U; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeOctetString(mOnSuccessCallback_92.Cancel(), mOnFailureCallback_92.Cancel()); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_92(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_92(chip::ByteSpan octetString) + { + VerifyOrReturn(CheckValueAsString("octetString", octetString, "TestValue")); + NextTest(); + } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() + CHIP_ERROR TestWriteAttributeOctetString_93() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Off::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); - }; + chip::ByteSpan octetStringArgument = chip::ByteSpan(chip::Uint8::from_const_char(""), strlen("")); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeOctetString(mOnSuccessCallback_93.Cancel(), mOnFailureCallback_93.Cancel(), + octetStringArgument); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_93(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4() { NextTest(); } + void OnSuccessResponse_93(chip::ByteSpan octetString) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() + CHIP_ERROR TestReadAttributeLongOctetStringDefaultValue_94() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + return cluster.ReadAttributeLongOctetString(mOnSuccessCallback_94.Cancel(), mOnFailureCallback_94.Cancel()); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_94(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5(bool onOff) + void OnSuccessResponse_94(chip::ByteSpan longOctetString) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValueAsString("longOctetString", longOctetString, "")); NextTest(); } -}; - -class Test_TC_CC_7_1 : public TestCommand -{ -public: - Test_TC_CC_7_1() : TestCommand("Test_TC_CC_7_1"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestWriteAttributeLongOctetString_95() { - CHIP_ERROR err = CHIP_NO_ERROR; + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_7_1\n"); - } + chip::ByteSpan longOctetStringArgument = chip::ByteSpan( + chip::Uint8::from_const_char( + "111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" + "111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" + "111111111111111111111111111111111111111111111111111111111111111111111111"), + strlen("111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" + "111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" + "111111111111111111111111111111111111111111111111111111111111111111111111111111")); - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_7_1\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } + return cluster.WriteAttributeLongOctetString(mOnSuccessCallback_95.Cancel(), mOnFailureCallback_95.Cancel(), + longOctetStringArgument); + } - Wait(); + void OnFailureResponse_95(uint8_t status) { ThrowFailureResponse(); } - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Enhanced Move To Hue command\n"); - err = TestEnhancedMoveToHueCommand_2(); - break; - case 3: - ChipLogProgress( - chipTool, " ***** Test Step 3 : Check Remaining time attribute value matched the value sent by the last command\n"); - err = TestCheckRemainingTimeAttributeValueMatchedTheValueSentByTheLastCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); - break; - } + void OnSuccessResponse_95(chip::ByteSpan longOctetString) { NextTest(); } - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } - } + CHIP_ERROR TestReadAttributeLongOctetString_96() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 6; + return cluster.ReadAttributeLongOctetString(mOnSuccessCallback_96.Cancel(), mOnFailureCallback_96.Cancel()); + } - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + void OnFailureResponse_96(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_1(void * context, uint8_t status) + void OnSuccessResponse_96(chip::ByteSpan longOctetString) { - (static_cast(context))->OnFailureResponse_1(status); + VerifyOrReturn(CheckValueAsString( + "longOctetString", longOctetString, + "1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" + "1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" + "1111111111111111111111111111111111111111111111111111111111111111")); + NextTest(); } - static void OnSuccessCallback_1(void * context, bool onOff) + CHIP_ERROR TestWriteAttributeLongOctetString_97() { - (static_cast(context))->OnSuccessResponse_1(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + chip::ByteSpan longOctetStringArgument = chip::ByteSpan(chip::Uint8::from_const_char(""), strlen("")); + + return cluster.WriteAttributeLongOctetString(mOnSuccessCallback_97.Cancel(), mOnFailureCallback_97.Cancel(), + longOctetStringArgument); } - static void OnFailureCallback_3(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_3(status); - } + void OnFailureResponse_97(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_3(void * context, uint16_t remainingTime) + void OnSuccessResponse_97(chip::ByteSpan longOctetString) { NextTest(); } + + CHIP_ERROR TestReadAttributeCharStringDefaultValue_98() { - (static_cast(context))->OnSuccessResponse_3(remainingTime); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeCharString(mOnSuccessCallback_98.Cancel(), mOnFailureCallback_98.Cancel()); } - static void OnFailureCallback_5(void * context, uint8_t status) + void OnFailureResponse_98(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_98(chip::ByteSpan charString) { - (static_cast(context))->OnFailureResponse_5(status); + VerifyOrReturn(CheckValueAsString("charString", charString, "")); + NextTest(); } - static void OnSuccessCallback_5(void * context, bool onOff) + CHIP_ERROR TestWriteAttributeCharString_99() { - (static_cast(context))->OnSuccessResponse_5(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + chip::ByteSpan charStringArgument = chip::ByteSpan(chip::Uint8::from_const_char("☉T☉"), strlen("☉T☉")); + + return cluster.WriteAttributeCharString(mOnSuccessCallback_99.Cancel(), mOnFailureCallback_99.Cancel(), charStringArgument); } - // - // Tests methods - // + void OnFailureResponse_99(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + void OnSuccessResponse_99(chip::ByteSpan charString) { NextTest(); } + + CHIP_ERROR TestWriteAttributeCharStringValueTooLong_100() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + chip::ByteSpan charStringArgument = + chip::ByteSpan(chip::Uint8::from_const_char("☉TestValueLongerThan10☉"), strlen("☉TestValueLongerThan10☉")); - chip::app::Clusters::OnOff::Commands::On::Type request; + return cluster.WriteAttributeCharString(mOnSuccessCallback_100.Cancel(), mOnFailureCallback_100.Cancel(), + charStringArgument); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + void OnFailureResponse_100(uint8_t status) { NextTest(); } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + void OnSuccessResponse_100(chip::ByteSpan charString) { ThrowSuccessResponse(); } + + CHIP_ERROR TestWriteAttributeCharStringEmpty_101() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + chip::ByteSpan charStringArgument = chip::ByteSpan(chip::Uint8::from_const_char(""), strlen("")); + + return cluster.WriteAttributeCharString(mOnSuccessCallback_101.Cancel(), mOnFailureCallback_101.Cancel(), + charStringArgument); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_101(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_101(chip::ByteSpan charString) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeLongCharStringDefaultValue_102() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeLongCharString(mOnSuccessCallback_102.Cancel(), mOnFailureCallback_102.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_102(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_102(chip::ByteSpan longCharString) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValueAsString("longCharString", longCharString, "")); NextTest(); } - CHIP_ERROR TestEnhancedMoveToHueCommand_2() + CHIP_ERROR TestWriteAttributeLongCharString_103() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveToHue::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::EnhancedMoveToHue::Type request; - request.enhancedHue = 1025U; - request.direction = static_cast(0); - request.transitionTime = 1U; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + chip::ByteSpan longCharStringArgument = chip::ByteSpan( + chip::Uint8::from_const_char( + "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" + "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" + "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉"), + strlen("☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" + "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" + "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉")); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeLongCharString(mOnSuccessCallback_103.Cancel(), mOnFailureCallback_103.Cancel(), + longCharStringArgument); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_103(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_103(chip::ByteSpan longCharString) { NextTest(); } - CHIP_ERROR TestCheckRemainingTimeAttributeValueMatchedTheValueSentByTheLastCommand_3() + CHIP_ERROR TestReadAttributeLongCharString_104() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeRemainingTime(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + return cluster.ReadAttributeLongCharString(mOnSuccessCallback_104.Cancel(), mOnFailureCallback_104.Cancel()); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_104(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3(uint16_t remainingTime) + void OnSuccessResponse_104(chip::ByteSpan longCharString) { - VerifyOrReturn(CheckValue("remainingTime", remainingTime, 1U)); + VerifyOrReturn(CheckValueAsString( + "longCharString", longCharString, + "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" + "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉" + "☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉☉")); NextTest(); } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() + CHIP_ERROR TestWriteAttributeLongCharString_105() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Off::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); - }; + chip::ByteSpan longCharStringArgument = chip::ByteSpan(chip::Uint8::from_const_char(""), strlen("")); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeLongCharString(mOnSuccessCallback_105.Cancel(), mOnFailureCallback_105.Cancel(), + longCharStringArgument); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_105(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4() { NextTest(); } + void OnSuccessResponse_105(chip::ByteSpan longCharString) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() + CHIP_ERROR TestReadAttributeList_106() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + return cluster.ReadAttributeListInt8u(mOnSuccessCallback_106.Cancel(), mOnFailureCallback_106.Cancel()); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_106(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5(bool onOff) + void OnSuccessResponse_106(uint16_t count, uint8_t * listInt8u) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(CheckValueAsList("listInt8u", count, 4)); NextTest(); } -}; - -class Test_TC_CC_7_2 : public TestCommand -{ -public: - Test_TC_CC_7_2() : TestCommand("Test_TC_CC_7_2"), mTestIndex(0) {} - /////////// TestCommand Interface ///////// - void NextTest() override + CHIP_ERROR TestReadAttributeListOctetString_107() { - CHIP_ERROR err = CHIP_NO_ERROR; - - if (0 == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_7_2\n"); - } - - if (mTestCount == mTestIndex) - { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_7_2\n"); - SetCommandExitStatus(CHIP_NO_ERROR); - return; - } - - Wait(); - - // Ensure we increment mTestIndex before we start running the relevant - // command. That way if we lose the timeslice after we send the message - // but before our function call returns, we won't end up with an - // incorrect mTestIndex value observed when we get the response. - switch (mTestIndex++) - { - case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); - break; - case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); - break; - case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Enhanced Move Hue Down command \n"); - err = TestEnhancedMoveHueDownCommand_2(); - break; - case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Enhanced Move Hue Stop command\n"); - err = TestEnhancedMoveHueStopCommand_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Enhanced Move Hue Up command\n"); - err = TestEnhancedMoveHueUpCommand_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Enhanced Move Hue Stop command\n"); - err = TestEnhancedMoveHueStopCommand_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_6(); - break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7(); - break; - } + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - if (CHIP_NO_ERROR != err) - { - ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); - SetCommandExitStatus(err); - } + return cluster.ReadAttributeListOctetString(mOnSuccessCallback_107.Cancel(), mOnFailureCallback_107.Cancel()); } -private: - std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 8; - - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_7{ OnFailureCallback_7, this }; - chip::Callback::Callback mOnSuccessCallback_7{ OnSuccessCallback_7, this }; + void OnFailureResponse_107(uint8_t status) { ThrowFailureResponse(); } - static void OnFailureCallback_1(void * context, uint8_t status) + void OnSuccessResponse_107(uint16_t count, chip::ByteSpan * listOctetString) { - (static_cast(context))->OnFailureResponse_1(status); + VerifyOrReturn(CheckValueAsList("listOctetString", count, 4)); + NextTest(); } - static void OnSuccessCallback_1(void * context, bool onOff) + CHIP_ERROR TestReadAttributeListStructOctetString_108() { - (static_cast(context))->OnSuccessResponse_1(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeListStructOctetString(mOnSuccessCallback_108.Cancel(), mOnFailureCallback_108.Cancel()); } - static void OnFailureCallback_7(void * context, uint8_t status) + void OnFailureResponse_108(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_108(uint16_t count, _TestListStructOctet * listStructOctetString) { - (static_cast(context))->OnFailureResponse_7(status); + VerifyOrReturn(CheckValueAsList("listStructOctetString", count, 4)); + NextTest(); } - static void OnSuccessCallback_7(void * context, bool onOff) + CHIP_ERROR TestReadAttributeEpochUsDefaultValue_109() { - (static_cast(context))->OnSuccessResponse_7(onOff); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeEpochUs(mOnSuccessCallback_109.Cancel(), mOnFailureCallback_109.Cancel()); } - // - // Tests methods - // + void OnFailureResponse_109(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + void OnSuccessResponse_109(uint64_t epochUs) { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; + VerifyOrReturn(CheckValue("epochUs", epochUs, 0ULL)); + NextTest(); + } - chip::app::Clusters::OnOff::Commands::On::Type request; + CHIP_ERROR TestWriteAttributeEpochUsMaxValue_110() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + uint64_t epochUsArgument = 18446744073709551615ULL; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeEpochUs(mOnSuccessCallback_110.Cancel(), mOnFailureCallback_110.Cancel(), epochUsArgument); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_110(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_110(uint64_t epochUs) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeEpochUsMaxValue_111() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeEpochUs(mOnSuccessCallback_111.Cancel(), mOnFailureCallback_111.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_111(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_111(uint64_t epochUs) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValue("epochUs", epochUs, 18446744073709551615ULL)); NextTest(); } - CHIP_ERROR TestEnhancedMoveHueDownCommand_2() + CHIP_ERROR TestWriteAttributeEpochUsMinValue_112() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + uint64_t epochUsArgument = 0ULL; - chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type request; - request.moveMode = static_cast(3); - request.rate = 5U; - request.optionsMask = 0; - request.optionsOverride = 0; + return cluster.WriteAttributeEpochUs(mOnSuccessCallback_112.Cancel(), mOnFailureCallback_112.Cancel(), epochUsArgument); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + void OnFailureResponse_112(uint8_t status) { ThrowFailureResponse(); } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + void OnSuccessResponse_112(uint64_t epochUs) { NextTest(); } + + CHIP_ERROR TestReadAttributeEpochUsMinValue_113() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeEpochUs(mOnSuccessCallback_113.Cancel(), mOnFailureCallback_113.Cancel()); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_113(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_113(uint64_t epochUs) + { + VerifyOrReturn(CheckValue("epochUs", epochUs, 0ULL)); + NextTest(); + } - CHIP_ERROR TestEnhancedMoveHueStopCommand_3() + CHIP_ERROR TestReadAttributeEpochSDefaultValue_114() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeEpochS(mOnSuccessCallback_114.Cancel(), mOnFailureCallback_114.Cancel()); + } - chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type request; - request.moveMode = static_cast(0); - request.rate = 0U; - request.optionsMask = 0; - request.optionsOverride = 0; + void OnFailureResponse_114(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + void OnSuccessResponse_114(uint32_t epochS) + { + VerifyOrReturn(CheckValue("epochS", epochS, 0UL)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeEpochSMaxValue_115() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint32_t epochSArgument = 4294967295UL; + + return cluster.WriteAttributeEpochS(mOnSuccessCallback_115.Cancel(), mOnFailureCallback_115.Cancel(), epochSArgument); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_115(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_115(uint32_t epochS) { NextTest(); } - CHIP_ERROR TestEnhancedMoveHueUpCommand_4() + CHIP_ERROR TestReadAttributeEpochSMaxValue_116() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeEpochS(mOnSuccessCallback_116.Cancel(), mOnFailureCallback_116.Cancel()); + } - chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type request; - request.moveMode = static_cast(1); - request.rate = 50U; - request.optionsMask = 0; - request.optionsOverride = 0; + void OnFailureResponse_116(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); - }; + void OnSuccessResponse_116(uint32_t epochS) + { + VerifyOrReturn(CheckValue("epochS", epochS, 4294967295UL)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestWriteAttributeEpochSMinValue_117() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + uint32_t epochSArgument = 0UL; + + return cluster.WriteAttributeEpochS(mOnSuccessCallback_117.Cancel(), mOnFailureCallback_117.Cancel(), epochSArgument); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_117(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_4() { NextTest(); } + void OnSuccessResponse_117(uint32_t epochS) { NextTest(); } - CHIP_ERROR TestEnhancedMoveHueStopCommand_5() + CHIP_ERROR TestReadAttributeEpochSMinValue_118() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + return cluster.ReadAttributeEpochS(mOnSuccessCallback_118.Cancel(), mOnFailureCallback_118.Cancel()); + } - chip::app::Clusters::ColorControl::Commands::EnhancedMoveHue::Type request; - request.moveMode = static_cast(0); - request.rate = 0U; - request.optionsMask = 0; - request.optionsOverride = 0; + void OnFailureResponse_118(uint8_t status) { ThrowFailureResponse(); } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_5(); - }; + void OnSuccessResponse_118(uint32_t epochS) + { + VerifyOrReturn(CheckValue("epochS", epochS, 0UL)); + NextTest(); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_5(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + CHIP_ERROR TestReadAttributeUnsupported_119() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + return cluster.ReadAttributeUnsupported(mOnSuccessCallback_119.Cancel(), mOnFailureCallback_119.Cancel()); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_119(uint8_t status) + { + (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); + } - void OnSuccessResponse_5() { NextTest(); } + void OnSuccessResponse_119(bool unsupported) + { + VerifyOrReturn(CheckValue("unsupported", unsupported, 0)); + NextTest(); + } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_6() + CHIP_ERROR TestWriteattributeUnsupported_120() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Off::Type request; + bool unsupportedArgument = 0; - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_6(); - }; + return cluster.WriteAttributeUnsupported(mOnSuccessCallback_120.Cancel(), mOnFailureCallback_120.Cancel(), + unsupportedArgument); + } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_6(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + void OnFailureResponse_120(uint8_t status) + { + (status == EMBER_ZCL_STATUS_UNSUPPORTED_ATTRIBUTE) ? NextTest() : ThrowFailureResponse(); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + void OnSuccessResponse_120(bool unsupported) { NextTest(); } - void OnSuccessResponse_6() { NextTest(); } + CHIP_ERROR TestSendTestCommandToUnsupportedEndpoint_121() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 200); + + using requestType = chip::app::Clusters::TestCluster::Commands::Test::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::TestCluster::Commands::Test::Type request; - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_7() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_121(); + }; - return cluster.ReadAttributeOnOff(mOnSuccessCallback_7.Cancel(), mOnFailureCallback_7.Cancel()); + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_121(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_121(uint8_t status) { NextTest(); } - void OnSuccessResponse_7(bool onOff) - { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); - NextTest(); - } + void OnSuccessResponse_121() { ThrowSuccessResponse(); } }; -class Test_TC_CC_7_3 : public TestCommand +class TestClusterComplexTypes : public TestCommand { public: - Test_TC_CC_7_3() : TestCommand("Test_TC_CC_7_3"), mTestIndex(0) {} + TestClusterComplexTypes() : TestCommand("TestClusterComplexTypes"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -16123,12 +15981,12 @@ class Test_TC_CC_7_3 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_7_3\n"); + ChipLogProgress(chipTool, " **** Test Start: TestClusterComplexTypes\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_7_3\n"); + ChipLogProgress(chipTool, " **** Test Complete: TestClusterComplexTypes\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -16142,28 +16000,35 @@ class Test_TC_CC_7_3 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Send Test Command With Struct Argument and arg1.b is true\n"); + err = TestSendTestCommandWithStructArgumentAndArg1bIsTrue_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Send Test Command With Struct Argument and arg1.b is false\n"); + err = TestSendTestCommandWithStructArgumentAndArg1bIsFalse_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Enhanced Step Hue Up command\n"); - err = TestEnhancedStepHueUpCommand_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Send Test Command With List of INT8U and none of them is set to 0\n"); + err = TestSendTestCommandWithListOfInt8uAndNoneOfThemIsSetTo0_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Enhanced Step Hue Down command\n"); - err = TestEnhancedStepHueDownCommand_3(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Send Test Command With List of INT8U and one of them is set to 0\n"); + err = TestSendTestCommandWithListOfInt8uAndOneOfThemIsSetTo0_3(); break; case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_4(); + ChipLogProgress(chipTool, " ***** Test Step 4 : Send Test Command With List of INT8U and get it reversed\n"); + err = TestSendTestCommandWithListOfInt8uAndGetItReversed_4(); break; case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5(); + ChipLogProgress( + chipTool, " ***** Test Step 5 : Send Test Command With List of Struct Argument and arg1.b of first item is true\n"); + err = TestSendTestCommandWithListOfStructArgumentAndArg1bOfFirstItemIsTrue_5(); + break; + case 6: + ChipLogProgress( + chipTool, + " ***** Test Step 6 : Send Test Command With List of Struct Argument and arg1.b of first item is false\n"); + err = TestSendTestCommandWithListOfStructArgumentAndArg1bOfFirstItemIsFalse_6(); break; } @@ -16176,180 +16041,276 @@ class Test_TC_CC_7_3 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 6; + const uint16_t mTestCount = 7; - chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ OnSuccessCallback_5, this }; + // + // Tests methods + // - static void OnFailureCallback_1(void * context, uint8_t status) + CHIP_ERROR TestSendTestCommandWithStructArgumentAndArg1bIsTrue_0() { - (static_cast(context))->OnFailureResponse_1(status); - } + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); - static void OnSuccessCallback_1(void * context, bool onOff) - { - (static_cast(context))->OnSuccessResponse_1(onOff); - } + using requestType = chip::app::Clusters::TestCluster::Commands::TestStructArgumentRequest::Type; + using responseType = chip::app::DataModel::NullObjectType; - static void OnFailureCallback_5(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_5(status); - } + chip::app::Clusters::TestCluster::Commands::TestStructArgumentRequest::Type request; - static void OnSuccessCallback_5(void * context, bool onOff) - { - (static_cast(context))->OnSuccessResponse_5(onOff); + request.arg1.a = 0; + request.arg1.b = true; + request.arg1.c = static_cast(2); + request.arg1.d = chip::ByteSpan(chip::Uint8::from_const_char("octet_string"), strlen("octet_string")); + request.arg1.e = chip::Span("char_string", strlen("char_string")); + request.arg1.f = static_cast>(1); + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_0(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_0(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - // - // Tests methods - // + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + void OnSuccessResponse_0() { NextTest(); } + + CHIP_ERROR TestSendTestCommandWithStructArgumentAndArg1bIsFalse_1() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; + using requestType = chip::app::Clusters::TestCluster::Commands::TestStructArgumentRequest::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::OnOff::Commands::On::Type request; + chip::app::Clusters::TestCluster::Commands::TestStructArgumentRequest::Type request; + + request.arg1.a = 0; + request.arg1.b = false; + request.arg1.c = static_cast(2); + request.arg1.d = chip::ByteSpan(chip::Uint8::from_const_char("octet_string"), strlen("octet_string")); + request.arg1.e = chip::Span("char_string", strlen("char_string")); + request.arg1.f = static_cast>(1); auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); + (static_cast(context))->OnSuccessResponse_1(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); + (static_cast(context))->OnFailureResponse_1(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { NextTest(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_1() { ThrowSuccessResponse(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestSendTestCommandWithListOfInt8uAndNoneOfThemIsSetTo0_2() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + using requestType = chip::app::Clusters::TestCluster::Commands::TestListInt8UArgumentRequest::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::TestCluster::Commands::TestListInt8UArgumentRequest::Type request; + + uint8_t arg1List[9]; + arg1List[0] = 1; + arg1List[1] = 2; + arg1List[2] = 3; + arg1List[3] = 4; + arg1List[4] = 5; + arg1List[5] = 6; + arg1List[6] = 7; + arg1List[7] = 8; + arg1List[8] = 9; + request.arg1 = arg1List; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_2(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_2(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_2() { NextTest(); } + + CHIP_ERROR TestSendTestCommandWithListOfInt8uAndOneOfThemIsSetTo0_3() { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); - NextTest(); + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::TestCluster::Commands::TestListInt8UArgumentRequest::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::TestCluster::Commands::TestListInt8UArgumentRequest::Type request; + + uint8_t arg1List[10]; + arg1List[0] = 1; + arg1List[1] = 2; + arg1List[2] = 3; + arg1List[3] = 4; + arg1List[4] = 5; + arg1List[5] = 6; + arg1List[6] = 7; + arg1List[7] = 8; + arg1List[8] = 9; + arg1List[9] = 0; + request.arg1 = arg1List; + + auto success = [](void * context, const responseType & data) { + (static_cast(context))->OnSuccessResponse_3(); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_3(status); + }; + return cluster.InvokeCommand(request, this, success, failure); } - CHIP_ERROR TestEnhancedStepHueUpCommand_2() + void OnFailureResponse_3(uint8_t status) { NextTest(); } + + void OnSuccessResponse_3() { ThrowSuccessResponse(); } + + CHIP_ERROR TestSendTestCommandWithListOfInt8uAndGetItReversed_4() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedStepHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + using requestType = chip::app::Clusters::TestCluster::Commands::TestListInt8UReverseRequest::Type; + using responseType = chip::app::Clusters::TestCluster::Commands::TestListInt8UReverseResponse::DecodableType; - chip::app::Clusters::ColorControl::Commands::EnhancedStepHue::Type request; - request.stepMode = static_cast(0); - request.stepSize = 50U; - request.transitionTime = 1U; - request.optionsMask = 0; - request.optionsOverride = 0; + chip::app::Clusters::TestCluster::Commands::TestListInt8UReverseRequest::Type request; + + uint8_t arg1List[9]; + arg1List[0] = 1; + arg1List[1] = 2; + arg1List[2] = 3; + arg1List[3] = 4; + arg1List[4] = 5; + arg1List[5] = 6; + arg1List[6] = 7; + arg1List[7] = 8; + arg1List[8] = 9; + request.arg1 = arg1List; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); + (static_cast(context))->OnSuccessResponse_4(data.arg1); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); + (static_cast(context))->OnFailureResponse_4(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_4(chip::app::DataModel::DecodableList arg1) + { + VerifyOrReturn(CheckValueAsList("arg1", arg1, 9, 8, 7, 6, 5, 4, 3, 2, 1)); + NextTest(); + } - CHIP_ERROR TestEnhancedStepHueDownCommand_3() + CHIP_ERROR TestSendTestCommandWithListOfStructArgumentAndArg1bOfFirstItemIsTrue_5() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedStepHue::Type; - using responseType = chip::app::DataModel::NullObjectType; + using requestType = chip::app::Clusters::TestCluster::Commands::TestListStructArgumentRequest::Type; + using responseType = chip::app::DataModel::NullObjectType; + + chip::app::Clusters::TestCluster::Commands::TestListStructArgumentRequest::Type request; + + chip::app::Clusters::TestCluster::Structs::SimpleStruct::Type arg1List[2]; + + arg1List[0].a = 0; + arg1List[0].b = true; + arg1List[0].c = static_cast(2); + arg1List[0].d = chip::ByteSpan(chip::Uint8::from_const_char("first_octet_string"), strlen("first_octet_string")); + arg1List[0].e = chip::Span("first_char_string", strlen("first_char_string")); + arg1List[0].f = static_cast>(1); + + arg1List[1].a = 1; + arg1List[1].b = true; + arg1List[1].c = static_cast(3); + arg1List[1].d = chip::ByteSpan(chip::Uint8::from_const_char("second_octet_string"), strlen("second_octet_string")); + arg1List[1].e = chip::Span("second_char_string", strlen("second_char_string")); + arg1List[1].f = static_cast>(1); - chip::app::Clusters::ColorControl::Commands::EnhancedStepHue::Type request; - request.stepMode = static_cast(1); - request.stepSize = 75U; - request.transitionTime = 1U; - request.optionsMask = 0; - request.optionsOverride = 0; + request.arg1 = arg1List; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); + (static_cast(context))->OnSuccessResponse_5(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); + (static_cast(context))->OnFailureResponse_5(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_3() { NextTest(); } + void OnSuccessResponse_5() { NextTest(); } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_4() + CHIP_ERROR TestSendTestCommandWithListOfStructArgumentAndArg1bOfFirstItemIsFalse_6() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; + using requestType = chip::app::Clusters::TestCluster::Commands::TestListStructArgumentRequest::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::OnOff::Commands::Off::Type request; + chip::app::Clusters::TestCluster::Commands::TestListStructArgumentRequest::Type request; + + chip::app::Clusters::TestCluster::Structs::SimpleStruct::Type arg1List[2]; + + arg1List[0].a = 1; + arg1List[0].b = true; + arg1List[0].c = static_cast(3); + arg1List[0].d = chip::ByteSpan(chip::Uint8::from_const_char("second_octet_string"), strlen("second_octet_string")); + arg1List[0].e = chip::Span("second_char_string", strlen("second_char_string")); + arg1List[0].f = static_cast>(1); + + arg1List[1].a = 0; + arg1List[1].b = false; + arg1List[1].c = static_cast(2); + arg1List[1].d = chip::ByteSpan(chip::Uint8::from_const_char("first_octet_string"), strlen("first_octet_string")); + arg1List[1].e = chip::Span("first_char_string", strlen("first_char_string")); + arg1List[1].f = static_cast>(1); + + request.arg1 = arg1List; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_4(); + (static_cast(context))->OnSuccessResponse_6(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_6(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_4() { NextTest(); } - - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_5() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeOnOff(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); - } - - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_6(uint8_t status) { NextTest(); } - void OnSuccessResponse_5(bool onOff) - { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); - NextTest(); - } + void OnSuccessResponse_6() { ThrowSuccessResponse(); } }; -class Test_TC_CC_7_4 : public TestCommand +class TestConstraints : public TestCommand { public: - Test_TC_CC_7_4() : TestCommand("Test_TC_CC_7_4"), mTestIndex(0) {} + TestConstraints() : TestCommand("TestConstraints"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -16358,12 +16319,12 @@ class Test_TC_CC_7_4 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_7_4\n"); + ChipLogProgress(chipTool, " **** Test Start: TestConstraints\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_7_4\n"); + ChipLogProgress(chipTool, " **** Test Complete: TestConstraints\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -16377,24 +16338,20 @@ class Test_TC_CC_7_4 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Write attribute INT32U Value\n"); + err = TestWriteAttributeInt32uValue_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Read attribute INT32U Value MinValue Constraints\n"); + err = TestReadAttributeInt32uValueMinValueConstraints_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Enhanced move to hue and saturation command\n"); - err = TestEnhancedMoveToHueAndSaturationCommand_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Read attribute INT32U Value MaxValue Constraints\n"); + err = TestReadAttributeInt32uValueMaxValueConstraints_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Read attribute INT32U Value NotValue Constraints\n"); + err = TestReadAttributeInt32uValueNotValueConstraints_3(); break; } @@ -16407,151 +16364,182 @@ class Test_TC_CC_7_4 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 5; + const uint16_t mTestCount = 4; + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; + chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, this }; + + static void OnFailureCallback_0(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_0(status); + } + + static void OnSuccessCallback_0(void * context, uint32_t int32u) + { + (static_cast(context))->OnSuccessResponse_0(int32u); + } static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_1(status); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnSuccessCallback_1(void * context, bool onOff) + static void OnSuccessCallback_1(void * context, uint32_t int32u) { - (static_cast(context))->OnSuccessResponse_1(onOff); + (static_cast(context))->OnSuccessResponse_1(int32u); } - static void OnFailureCallback_4(void * context, uint8_t status) + static void OnFailureCallback_2(void * context, uint8_t status) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnFailureResponse_2(status); } - static void OnSuccessCallback_4(void * context, bool onOff) + static void OnSuccessCallback_2(void * context, uint32_t int32u) { - (static_cast(context))->OnSuccessResponse_4(onOff); + (static_cast(context))->OnSuccessResponse_2(int32u); + } + + static void OnFailureCallback_3(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_3(status); + } + + static void OnSuccessCallback_3(void * context, uint32_t int32u) + { + (static_cast(context))->OnSuccessResponse_3(int32u); } // // Tests methods // - CHIP_ERROR TestTurnOnLightForColorControlTests_0() + CHIP_ERROR TestWriteAttributeInt32uValue_0() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::On::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + uint32_t int32uArgument = 5UL; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.WriteAttributeInt32u(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel(), int32uArgument); } void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_0(uint32_t int32u) { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributeInt32uValueMinValueConstraints_1() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributeInt32u(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_1(uint32_t int32u) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckConstraintMinValue("int32u", int32u, 5)); NextTest(); } - CHIP_ERROR TestEnhancedMoveToHueAndSaturationCommand_2() + CHIP_ERROR TestReadAttributeInt32uValueMaxValueConstraints_2() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::EnhancedMoveToHueAndSaturation::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::ColorControl::Commands::EnhancedMoveToHueAndSaturation::Type request; - request.enhancedHue = 1200U; - request.saturation = 90; - request.transitionTime = 10U; - request.optionsMask = 0; - request.optionsOverride = 0; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; - - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeInt32u(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_2() { NextTest(); } + void OnSuccessResponse_2(uint32_t int32u) + { + VerifyOrReturn(CheckConstraintMaxValue("int32u", int32u, 5)); + NextTest(); + } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_3() + CHIP_ERROR TestReadAttributeInt32uValueNotValueConstraints_3() { - chip::Controller::OnOffClusterTest cluster; + chip::Controller::TestClusterClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::Off::Type request; + return cluster.ReadAttributeInt32u(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_3(); - }; + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_3(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + void OnSuccessResponse_3(uint32_t int32u) + { + VerifyOrReturn(CheckConstraintNotValue("int32u", int32u, 6)); + NextTest(); } +}; - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } +class TestDelayCommands : public TestCommand +{ +public: + TestDelayCommands() : TestCommand("TestDelayCommands"), mTestIndex(0) {} - void OnSuccessResponse_3() { NextTest(); } + /////////// TestCommand Interface ///////// + void NextTest() override + { + CHIP_ERROR err = CHIP_NO_ERROR; + + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: TestDelayCommands\n"); + } + + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: TestDelayCommands\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } + + Wait(); - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_4() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Wait 100ms\n"); + err = TestWait100ms_0(); + break; + } - return cluster.ReadAttributeOnOff(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 1; - void OnSuccessResponse_4(bool onOff) - { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); - NextTest(); - } + // + // Tests methods + // + + CHIP_ERROR TestWait100ms_0() { return WaitForMs(100); } }; -class Test_TC_CC_8_1 : public TestCommand +class TestDescriptorCluster : public TestCommand { public: - Test_TC_CC_8_1() : TestCommand("Test_TC_CC_8_1"), mTestIndex(0) {} + TestDescriptorCluster() : TestCommand("TestDescriptorCluster"), mTestIndex(0) {} /////////// TestCommand Interface ///////// void NextTest() override @@ -16560,12 +16548,12 @@ class Test_TC_CC_8_1 : public TestCommand if (0 == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Start: Test_TC_CC_8_1\n"); + ChipLogProgress(chipTool, " **** Test Start: TestDescriptorCluster\n"); } if (mTestCount == mTestIndex) { - ChipLogProgress(chipTool, " **** Test Complete: Test_TC_CC_8_1\n"); + ChipLogProgress(chipTool, " **** Test Complete: TestDescriptorCluster\n"); SetCommandExitStatus(CHIP_NO_ERROR); return; } @@ -16579,68 +16567,20 @@ class Test_TC_CC_8_1 : public TestCommand switch (mTestIndex++) { case 0: - ChipLogProgress(chipTool, " ***** Test Step 0 : Turn on light for color control tests\n"); - err = TestTurnOnLightForColorControlTests_0(); + ChipLogProgress(chipTool, " ***** Test Step 0 : Read attribute Device list\n"); + err = TestReadAttributeDeviceList_0(); break; case 1: - ChipLogProgress(chipTool, " ***** Test Step 1 : Check on/off attribute value is true after on command\n"); - err = TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1(); + ChipLogProgress(chipTool, " ***** Test Step 1 : Read attribute Server list\n"); + err = TestReadAttributeServerList_1(); break; case 2: - ChipLogProgress(chipTool, " ***** Test Step 2 : Color Loop Set Command - Set all Attributs\n"); - err = TestColorLoopSetCommandSetAllAttributs_2(); + ChipLogProgress(chipTool, " ***** Test Step 2 : Read attribute Client list\n"); + err = TestReadAttributeClientList_2(); break; case 3: - ChipLogProgress(chipTool, " ***** Test Step 3 : Check ColorLoopDirection Value\n"); - err = TestCheckColorLoopDirectionValue_3(); - break; - case 4: - ChipLogProgress(chipTool, " ***** Test Step 4 : Check ColorLoopTime Value\n"); - err = TestCheckColorLoopTimeValue_4(); - break; - case 5: - ChipLogProgress(chipTool, " ***** Test Step 5 : Check ColorLoopStartEnhancedHue Value\n"); - err = TestCheckColorLoopStartEnhancedHueValue_5(); - break; - case 6: - ChipLogProgress(chipTool, " ***** Test Step 6 : Check ColorLoopActive Value\n"); - err = TestCheckColorLoopActiveValue_6(); - break; - case 7: - ChipLogProgress(chipTool, " ***** Test Step 7 : Color Loop Set Command - Start Color Loop\n"); - err = TestColorLoopSetCommandStartColorLoop_7(); - break; - case 8: - ChipLogProgress(chipTool, " ***** Test Step 8 : Check ColorLoopActive Value\n"); - err = TestCheckColorLoopActiveValue_8(); - break; - case 9: - ChipLogProgress(chipTool, " ***** Test Step 9 : Color Loop Set Command - Set direction and time while running\n"); - err = TestColorLoopSetCommandSetDirectionAndTimeWhileRunning_9(); - break; - case 10: - ChipLogProgress(chipTool, " ***** Test Step 10 : Check ColorLoopDirection Value\n"); - err = TestCheckColorLoopDirectionValue_10(); - break; - case 11: - ChipLogProgress(chipTool, " ***** Test Step 11 : Check ColorLoopTime Value\n"); - err = TestCheckColorLoopTimeValue_11(); - break; - case 12: - ChipLogProgress(chipTool, " ***** Test Step 12 : Color Loop Set Command - Set direction while running\n"); - err = TestColorLoopSetCommandSetDirectionWhileRunning_12(); - break; - case 13: - ChipLogProgress(chipTool, " ***** Test Step 13 : Check ColorLoopDirection Value\n"); - err = TestCheckColorLoopDirectionValue_13(); - break; - case 14: - ChipLogProgress(chipTool, " ***** Test Step 14 : Turn off light that we turned on\n"); - err = TestTurnOffLightThatWeTurnedOn_14(); - break; - case 15: - ChipLogProgress(chipTool, " ***** Test Step 15 : Check on/off attribute value is false after off command\n"); - err = TestCheckOnOffAttributeValueIsFalseAfterOffCommand_15(); + ChipLogProgress(chipTool, " ***** Test Step 3 : Read attribute Parts list\n"); + err = TestReadAttributePartsList_3(); break; } @@ -16653,431 +16593,488 @@ class Test_TC_CC_8_1 : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 16; + const uint16_t mTestCount = 4; + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ + OnSuccessCallback_0, this + }; chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; - chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ + OnSuccessCallback_1, this + }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ + OnSuccessCallback_2, this + }; chip::Callback::Callback mOnFailureCallback_3{ OnFailureCallback_3, this }; - chip::Callback::Callback mOnSuccessCallback_3{ OnSuccessCallback_3, - this }; - chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; - chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; - chip::Callback::Callback mOnFailureCallback_5{ OnFailureCallback_5, this }; - chip::Callback::Callback mOnSuccessCallback_5{ - OnSuccessCallback_5, this + chip::Callback::Callback mOnSuccessCallback_3{ + OnSuccessCallback_3, this }; - chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; - chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; - chip::Callback::Callback mOnFailureCallback_8{ OnFailureCallback_8, this }; - chip::Callback::Callback mOnSuccessCallback_8{ OnSuccessCallback_8, this }; - chip::Callback::Callback mOnFailureCallback_10{ OnFailureCallback_10, this }; - chip::Callback::Callback mOnSuccessCallback_10{ OnSuccessCallback_10, - this }; - chip::Callback::Callback mOnFailureCallback_11{ OnFailureCallback_11, this }; - chip::Callback::Callback mOnSuccessCallback_11{ OnSuccessCallback_11, this }; - chip::Callback::Callback mOnFailureCallback_13{ OnFailureCallback_13, this }; - chip::Callback::Callback mOnSuccessCallback_13{ OnSuccessCallback_13, - this }; - chip::Callback::Callback mOnFailureCallback_15{ OnFailureCallback_15, this }; - chip::Callback::Callback mOnSuccessCallback_15{ OnSuccessCallback_15, this }; - - static void OnFailureCallback_1(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_1(status); - } - - static void OnSuccessCallback_1(void * context, bool onOff) - { - (static_cast(context))->OnSuccessResponse_1(onOff); - } - - static void OnFailureCallback_3(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_3(status); - } - static void OnSuccessCallback_3(void * context, uint8_t colorLoopDirection) + static void OnFailureCallback_0(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_3(colorLoopDirection); + (static_cast(context))->OnFailureResponse_0(status); } - static void OnFailureCallback_4(void * context, uint8_t status) + static void OnSuccessCallback_0(void * context, uint16_t count, _DeviceType * deviceList) { - (static_cast(context))->OnFailureResponse_4(status); + (static_cast(context))->OnSuccessResponse_0(count, deviceList); } - static void OnSuccessCallback_4(void * context, uint16_t colorLoopTime) + static void OnFailureCallback_1(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_4(colorLoopTime); + (static_cast(context))->OnFailureResponse_1(status); } - static void OnFailureCallback_5(void * context, uint8_t status) + static void OnSuccessCallback_1(void * context, uint16_t count, chip::ClusterId * serverList) { - (static_cast(context))->OnFailureResponse_5(status); + (static_cast(context))->OnSuccessResponse_1(count, serverList); } - static void OnSuccessCallback_5(void * context, uint16_t colorLoopStartEnhancedHue) + static void OnFailureCallback_2(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_5(colorLoopStartEnhancedHue); + (static_cast(context))->OnFailureResponse_2(status); } - static void OnFailureCallback_6(void * context, uint8_t status) + static void OnSuccessCallback_2(void * context, uint16_t count, chip::ClusterId * clientList) { - (static_cast(context))->OnFailureResponse_6(status); + (static_cast(context))->OnSuccessResponse_2(count, clientList); } - static void OnSuccessCallback_6(void * context, uint8_t colorLoopActive) + static void OnFailureCallback_3(void * context, uint8_t status) { - (static_cast(context))->OnSuccessResponse_6(colorLoopActive); + (static_cast(context))->OnFailureResponse_3(status); } - static void OnFailureCallback_8(void * context, uint8_t status) + static void OnSuccessCallback_3(void * context, uint16_t count, chip::EndpointId * partsList) { - (static_cast(context))->OnFailureResponse_8(status); + (static_cast(context))->OnSuccessResponse_3(count, partsList); } - static void OnSuccessCallback_8(void * context, uint8_t colorLoopActive) - { - (static_cast(context))->OnSuccessResponse_8(colorLoopActive); - } + // + // Tests methods + // - static void OnFailureCallback_10(void * context, uint8_t status) + CHIP_ERROR TestReadAttributeDeviceList_0() { - (static_cast(context))->OnFailureResponse_10(status); - } + chip::Controller::DescriptorClusterTest cluster; + cluster.Associate(mDevice, 0); - static void OnSuccessCallback_10(void * context, uint8_t colorLoopDirection) - { - (static_cast(context))->OnSuccessResponse_10(colorLoopDirection); + return cluster.ReadAttributeDeviceList(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - static void OnFailureCallback_11(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_11(status); - } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_11(void * context, uint16_t colorLoopTime) + void OnSuccessResponse_0(uint16_t count, _DeviceType * deviceList) { - (static_cast(context))->OnSuccessResponse_11(colorLoopTime); + VerifyOrReturn(CheckValueAsList("deviceList", count, 1)); + NextTest(); } - static void OnFailureCallback_13(void * context, uint8_t status) + CHIP_ERROR TestReadAttributeServerList_1() { - (static_cast(context))->OnFailureResponse_13(status); - } + chip::Controller::DescriptorClusterTest cluster; + cluster.Associate(mDevice, 0); - static void OnSuccessCallback_13(void * context, uint8_t colorLoopDirection) - { - (static_cast(context))->OnSuccessResponse_13(colorLoopDirection); + return cluster.ReadAttributeServerList(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - static void OnFailureCallback_15(void * context, uint8_t status) - { - (static_cast(context))->OnFailureResponse_15(status); - } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - static void OnSuccessCallback_15(void * context, bool onOff) + void OnSuccessResponse_1(uint16_t count, chip::ClusterId * serverList) { - (static_cast(context))->OnSuccessResponse_15(onOff); + VerifyOrReturn(CheckValueAsList("serverList", count, 18)); + NextTest(); } - // - // Tests methods - // - - CHIP_ERROR TestTurnOnLightForColorControlTests_0() - { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); - - using requestType = chip::app::Clusters::OnOff::Commands::On::Type; - using responseType = chip::app::DataModel::NullObjectType; - - chip::app::Clusters::OnOff::Commands::On::Type request; - - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_0(); - }; + CHIP_ERROR TestReadAttributeClientList_2() + { + chip::Controller::DescriptorClusterTest cluster; + cluster.Associate(mDevice, 0); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_0(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + return cluster.ReadAttributeClientList(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel()); } - void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_0() { NextTest(); } + void OnSuccessResponse_2(uint16_t count, chip::ClusterId * clientList) + { + VerifyOrReturn(CheckValueAsList("clientList", count, 0)); + NextTest(); + } - CHIP_ERROR TestCheckOnOffAttributeValueIsTrueAfterOnCommand_1() + CHIP_ERROR TestReadAttributePartsList_3() { - chip::Controller::OnOffClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::DescriptorClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); + return cluster.ReadAttributePartsList(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); } - void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_1(bool onOff) + void OnSuccessResponse_3(uint16_t count, chip::EndpointId * partsList) { - VerifyOrReturn(CheckValue("onOff", onOff, 1)); + VerifyOrReturn(CheckValueAsList("partsList", count, 2)); NextTest(); } +}; - CHIP_ERROR TestColorLoopSetCommandSetAllAttributs_2() +class TestOperationalCredentialsCluster : public TestCommand +{ +public: + TestOperationalCredentialsCluster() : TestCommand("TestOperationalCredentialsCluster"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + CHIP_ERROR err = CHIP_NO_ERROR; - using requestType = chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type; - using responseType = chip::app::DataModel::NullObjectType; + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: TestOperationalCredentialsCluster\n"); + } - chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type request; - request.updateFlags = static_cast>(14); - request.action = static_cast(0); - request.direction = static_cast(1); - request.time = 100U; - request.startHue = 500U; - request.optionsMask = 0; - request.optionsOverride = 0; + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: TestOperationalCredentialsCluster\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_2(); - }; + Wait(); - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_2(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Read number of supported fabrics\n"); + err = TestReadNumberOfSupportedFabrics_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Read number of commissioned fabrics\n"); + err = TestReadNumberOfCommissionedFabrics_1(); + break; + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } } - void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 2; - void OnSuccessResponse_2() { NextTest(); } + chip::Callback::Callback mOnFailureCallback_0{ OnFailureCallback_0, this }; + chip::Callback::Callback mOnSuccessCallback_0{ OnSuccessCallback_0, this }; + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, + this }; - CHIP_ERROR TestCheckColorLoopDirectionValue_3() + static void OnFailureCallback_0(void * context, uint8_t status) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeColorLoopDirection(mOnSuccessCallback_3.Cancel(), mOnFailureCallback_3.Cancel()); + (static_cast(context))->OnFailureResponse_0(status); } - void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_3(uint8_t colorLoopDirection) + static void OnSuccessCallback_0(void * context, uint8_t supportedFabrics) { - VerifyOrReturn(CheckValue("colorLoopDirection", colorLoopDirection, 1)); - NextTest(); + (static_cast(context))->OnSuccessResponse_0(supportedFabrics); } - CHIP_ERROR TestCheckColorLoopTimeValue_4() + static void OnFailureCallback_1(void * context, uint8_t status) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); - - return cluster.ReadAttributeColorLoopTime(mOnSuccessCallback_4.Cancel(), mOnFailureCallback_4.Cancel()); + (static_cast(context))->OnFailureResponse_1(status); } - void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - - void OnSuccessResponse_4(uint16_t colorLoopTime) + static void OnSuccessCallback_1(void * context, uint8_t commissionedFabrics) { - VerifyOrReturn(CheckValue("colorLoopTime", colorLoopTime, 100U)); - NextTest(); + (static_cast(context))->OnSuccessResponse_1(commissionedFabrics); } - CHIP_ERROR TestCheckColorLoopStartEnhancedHueValue_5() + // + // Tests methods + // + + CHIP_ERROR TestReadNumberOfSupportedFabrics_0() { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::OperationalCredentialsClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeColorLoopStartEnhancedHue(mOnSuccessCallback_5.Cancel(), mOnFailureCallback_5.Cancel()); + return cluster.ReadAttributeSupportedFabrics(mOnSuccessCallback_0.Cancel(), mOnFailureCallback_0.Cancel()); } - void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_5(uint16_t colorLoopStartEnhancedHue) + void OnSuccessResponse_0(uint8_t supportedFabrics) { - VerifyOrReturn(CheckValue("colorLoopStartEnhancedHue", colorLoopStartEnhancedHue, 500U)); + VerifyOrReturn(CheckConstraintType("supportedFabrics", "", "uint8")); + VerifyOrReturn(CheckConstraintMinValue("supportedFabrics", supportedFabrics, 4)); NextTest(); } - CHIP_ERROR TestCheckColorLoopActiveValue_6() + CHIP_ERROR TestReadNumberOfCommissionedFabrics_1() { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + chip::Controller::OperationalCredentialsClusterTest cluster; + cluster.Associate(mDevice, 0); - return cluster.ReadAttributeColorLoopActive(mOnSuccessCallback_6.Cancel(), mOnFailureCallback_6.Cancel()); + return cluster.ReadAttributeCommissionedFabrics(mOnSuccessCallback_1.Cancel(), mOnFailureCallback_1.Cancel()); } - void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_6(uint8_t colorLoopActive) + void OnSuccessResponse_1(uint8_t commissionedFabrics) { - VerifyOrReturn(CheckValue("colorLoopActive", colorLoopActive, 0)); + VerifyOrReturn(CheckConstraintType("commissionedFabrics", "", "uint8")); + VerifyOrReturn(CheckConstraintMinValue("commissionedFabrics", commissionedFabrics, 1)); NextTest(); } +}; - CHIP_ERROR TestColorLoopSetCommandStartColorLoop_7() +class TestSubscribe_OnOff : public TestCommand +{ +public: + TestSubscribe_OnOff() : TestCommand("TestSubscribe_OnOff"), mTestIndex(0) {} + + /////////// TestCommand Interface ///////// + void NextTest() override { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + CHIP_ERROR err = CHIP_NO_ERROR; - using requestType = chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type; - using responseType = chip::app::DataModel::NullObjectType; + if (0 == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Start: TestSubscribe_OnOff\n"); + } - chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type request; - request.updateFlags = static_cast>(1); - request.action = static_cast(1); - request.direction = static_cast(0); - request.time = 0U; - request.startHue = 0U; - request.optionsMask = 0; - request.optionsOverride = 0; + if (mTestCount == mTestIndex) + { + ChipLogProgress(chipTool, " **** Test Complete: TestSubscribe_OnOff\n"); + SetCommandExitStatus(CHIP_NO_ERROR); + return; + } - auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_7(); - }; + Wait(); + + // Ensure we increment mTestIndex before we start running the relevant + // command. That way if we lose the timeslice after we send the message + // but before our function call returns, we won't end up with an + // incorrect mTestIndex value observed when we get the response. + switch (mTestIndex++) + { + case 0: + ChipLogProgress(chipTool, " ***** Test Step 0 : Set OnOff Attribute to false\n"); + err = TestSetOnOffAttributeToFalse_0(); + break; + case 1: + ChipLogProgress(chipTool, " ***** Test Step 1 : Report: Subscribe OnOff Attribute\n"); + err = TestReportSubscribeOnOffAttribute_1(); + break; + case 2: + ChipLogProgress(chipTool, " ***** Test Step 2 : Subscribe OnOff Attribute\n"); + err = TestSubscribeOnOffAttribute_2(); + break; + case 3: + ChipLogProgress(chipTool, " ***** Test Step 3 : Turn On the light to see attribute change\n"); + err = TestTurnOnTheLightToSeeAttributeChange_3(); + break; + case 4: + ChipLogProgress(chipTool, " ***** Test Step 4 : Check for attribute report\n"); + err = TestCheckForAttributeReport_4(); + break; + case 5: + ChipLogProgress(chipTool, " ***** Test Step 5 : Turn Off the light to see attribute change\n"); + err = TestTurnOffTheLightToSeeAttributeChange_5(); + break; + case 6: + ChipLogProgress(chipTool, " ***** Test Step 6 : Check for attribute report\n"); + err = TestCheckForAttributeReport_6(); + break; + } + + if (CHIP_NO_ERROR != err) + { + ChipLogError(chipTool, " ***** Test Failure: %s\n", chip::ErrorStr(err)); + SetCommandExitStatus(err); + } + } + +private: + std::atomic_uint16_t mTestIndex; + const uint16_t mTestCount = 7; + + chip::Callback::Callback mOnFailureCallback_1{ OnFailureCallback_1, this }; + chip::Callback::Callback mOnSuccessCallback_1{ OnSuccessCallback_1, this }; + chip::Callback::Callback mOnFailureCallback_2{ OnFailureCallback_2, this }; + chip::Callback::Callback mOnSuccessCallback_2{ OnSuccessCallback_2, this }; + chip::Callback::Callback mOnFailureCallback_4{ OnFailureCallback_4, this }; + chip::Callback::Callback mOnSuccessCallback_4{ OnSuccessCallback_4, this }; + chip::Callback::Callback mOnFailureCallback_6{ OnFailureCallback_6, this }; + chip::Callback::Callback mOnSuccessCallback_6{ OnSuccessCallback_6, this }; - auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_7(status); - }; - return cluster.InvokeCommand(request, this, success, failure); + static void OnFailureCallback_1(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_1(status); } - void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } + static void OnSuccessCallback_1(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_1(onOff); + } - void OnSuccessResponse_7() { NextTest(); } + bool mReceivedReport_1 = false; - CHIP_ERROR TestCheckColorLoopActiveValue_8() + static void OnFailureCallback_2(void * context, uint8_t status) { - chip::Controller::ColorControlClusterTest cluster; - cluster.Associate(mDevice, 1); + (static_cast(context))->OnFailureResponse_2(status); + } - return cluster.ReadAttributeColorLoopActive(mOnSuccessCallback_8.Cancel(), mOnFailureCallback_8.Cancel()); + static void OnSuccessCallback_2(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_2(onOff); } - void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } + static void OnFailureCallback_4(void * context, uint8_t status) + { + (static_cast(context))->OnFailureResponse_4(status); + } - void OnSuccessResponse_8(uint8_t colorLoopActive) + static void OnSuccessCallback_4(void * context, bool onOff) { - VerifyOrReturn(CheckValue("colorLoopActive", colorLoopActive, 1)); - NextTest(); + (static_cast(context))->OnSuccessResponse_4(onOff); } - CHIP_ERROR TestColorLoopSetCommandSetDirectionAndTimeWhileRunning_9() + bool mReceivedReport_4 = false; + + static void OnFailureCallback_6(void * context, uint8_t status) { - chip::Controller::ColorControlClusterTest cluster; + (static_cast(context))->OnFailureResponse_6(status); + } + + static void OnSuccessCallback_6(void * context, bool onOff) + { + (static_cast(context))->OnSuccessResponse_6(onOff); + } + + bool mReceivedReport_6 = false; + + // + // Tests methods + // + + CHIP_ERROR TestSetOnOffAttributeToFalse_0() + { + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type; + using requestType = chip::app::Clusters::OnOff::Commands::Off::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type request; - request.updateFlags = static_cast>(6); - request.action = static_cast(0); - request.direction = static_cast(0); - request.time = 3500U; - request.startHue = 0U; - request.optionsMask = 0; - request.optionsOverride = 0; + chip::app::Clusters::OnOff::Commands::Off::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_9(); + (static_cast(context))->OnSuccessResponse_0(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_9(status); + (static_cast(context))->OnFailureResponse_0(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_0(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_9() { NextTest(); } + void OnSuccessResponse_0() { NextTest(); } - CHIP_ERROR TestCheckColorLoopDirectionValue_10() + CHIP_ERROR TestReportSubscribeOnOffAttribute_1() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeColorLoopDirection(mOnSuccessCallback_10.Cancel(), mOnFailureCallback_10.Cancel()); + ReturnErrorOnFailure(cluster.ReportAttributeOnOff(mOnSuccessCallback_1.Cancel())); + return WaitForMs(0); } - void OnFailureResponse_10(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_1(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_10(uint8_t colorLoopDirection) + void OnSuccessResponse_1(bool onOff) { - VerifyOrReturn(CheckValue("colorLoopDirection", colorLoopDirection, 0)); - NextTest(); + VerifyOrReturn(mReceivedReport_1 == false, ChipLogError(chipTool, "Not Fatal: on report called more than once.")); + mReceivedReport_1 = true; + + VerifyOrReturn(CheckValue("onOff", onOff, false)); } - CHIP_ERROR TestCheckColorLoopTimeValue_11() + CHIP_ERROR TestSubscribeOnOffAttribute_2() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeColorLoopTime(mOnSuccessCallback_11.Cancel(), mOnFailureCallback_11.Cancel()); + uint16_t minIntervalArgument = 2; + uint16_t maxIntervalArgument = 10; + + return cluster.SubscribeAttributeOnOff(mOnSuccessCallback_2.Cancel(), mOnFailureCallback_2.Cancel(), minIntervalArgument, + maxIntervalArgument); } - void OnFailureResponse_11(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_2(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_11(uint16_t colorLoopTime) + void OnSuccessResponse_2(bool onOff) { - VerifyOrReturn(CheckValue("colorLoopTime", colorLoopTime, 3500U)); + VerifyOrReturn(mReceivedReport_1, Exit("Initial report not received!")); + NextTest(); } - CHIP_ERROR TestColorLoopSetCommandSetDirectionWhileRunning_12() + CHIP_ERROR TestTurnOnTheLightToSeeAttributeChange_3() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - using requestType = chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type; + using requestType = chip::app::Clusters::OnOff::Commands::On::Type; using responseType = chip::app::DataModel::NullObjectType; - chip::app::Clusters::ColorControl::Commands::ColorLoopSet::Type request; - request.updateFlags = static_cast>(2); - request.action = static_cast(0); - request.direction = static_cast(1); - request.time = 0U; - request.startHue = 0U; - request.optionsMask = 0; - request.optionsOverride = 0; + chip::app::Clusters::OnOff::Commands::On::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_12(); + (static_cast(context))->OnSuccessResponse_3(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_12(status); + (static_cast(context))->OnFailureResponse_3(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_12(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_3(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_12() { NextTest(); } + void OnSuccessResponse_3() { NextTest(); } - CHIP_ERROR TestCheckColorLoopDirectionValue_13() + CHIP_ERROR TestCheckForAttributeReport_4() { - chip::Controller::ColorControlClusterTest cluster; + chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeColorLoopDirection(mOnSuccessCallback_13.Cancel(), mOnFailureCallback_13.Cancel()); + return cluster.ReportAttributeOnOff(mOnSuccessCallback_4.Cancel()); } - void OnFailureResponse_13(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_4(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_13(uint8_t colorLoopDirection) + void OnSuccessResponse_4(bool onOff) { - VerifyOrReturn(CheckValue("colorLoopDirection", colorLoopDirection, 1)); + VerifyOrReturn(mReceivedReport_4 == false, ChipLogError(chipTool, "Not Fatal: on report called more than once.")); + mReceivedReport_4 = true; + + VerifyOrReturn(CheckValue("onOff", onOff, true)); NextTest(); } - CHIP_ERROR TestTurnOffLightThatWeTurnedOn_14() + CHIP_ERROR TestTurnOffTheLightToSeeAttributeChange_5() { chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); @@ -17088,32 +17085,35 @@ class Test_TC_CC_8_1 : public TestCommand chip::app::Clusters::OnOff::Commands::Off::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_14(); + (static_cast(context))->OnSuccessResponse_5(); }; auto failure = [](void * context, EmberAfStatus status) { - (static_cast(context))->OnFailureResponse_14(status); + (static_cast(context))->OnFailureResponse_5(status); }; return cluster.InvokeCommand(request, this, success, failure); } - void OnFailureResponse_14(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_5(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_14() { NextTest(); } + void OnSuccessResponse_5() { NextTest(); } - CHIP_ERROR TestCheckOnOffAttributeValueIsFalseAfterOffCommand_15() + CHIP_ERROR TestCheckForAttributeReport_6() { chip::Controller::OnOffClusterTest cluster; cluster.Associate(mDevice, 1); - return cluster.ReadAttributeOnOff(mOnSuccessCallback_15.Cancel(), mOnFailureCallback_15.Cancel()); + return cluster.ReportAttributeOnOff(mOnSuccessCallback_6.Cancel()); } - void OnFailureResponse_15(uint8_t status) { ThrowFailureResponse(); } + void OnFailureResponse_6(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_15(bool onOff) + void OnSuccessResponse_6(bool onOff) { - VerifyOrReturn(CheckValue("onOff", onOff, 0)); + VerifyOrReturn(mReceivedReport_6 == false, ChipLogError(chipTool, "Not Fatal: on report called more than once.")); + mReceivedReport_6 = true; + + VerifyOrReturn(CheckValue("onOff", onOff, false)); NextTest(); } }; @@ -17123,51 +17123,8 @@ void registerCommandsTests(Commands & commands) const char * clusterName = "Tests"; commands_list clusterCommands = { - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), - make_unique(), make_unique(), make_unique(), make_unique(), @@ -17186,6 +17143,49 @@ void registerCommandsTests(Commands & commands) make_unique(), make_unique(), make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), + make_unique(), }; commands.Register(clusterName, clusterCommands);