From 9f1ad39f38f152be439d2e4b37f8d8e5800886ae Mon Sep 17 00:00:00 2001 From: Boris Zbarsky Date: Thu, 28 Oct 2021 14:29:38 -0400 Subject: [PATCH] Add support for null in yaml tests. (#11139) Adds support for sending null as a command argument and for null in the expected value. --- .../chip-tool/commands/tests/TestCommand.h | 24 ++++++++ .../templates/partials/test_cluster.zapt | 20 +++++-- .../partials/test_cluster_command_value.zapt | 16 +++-- .../test-cluster-server.cpp | 2 + .../tests/suites/TestClusterComplexTypes.yaml | 7 ++- .../common/ClusterTestGeneration.js | 17 ++++++ .../zcl/data-model/chip/test-cluster.xml | 4 +- .../java/zap-generated/CHIPClusters-JNI.cpp | 6 +- .../chip/devicecontroller/ChipClusters.java | 2 +- .../devicecontroller/ClusterInfoMapping.java | 3 +- .../python/chip/clusters/Objects.py | 3 + .../CHIP/zap-generated/CHIPCallbackBridge.mm | 3 +- .../CHIPCallbackBridge_internal.h | 2 +- .../app-common/zap-generated/callback.h | 3 +- .../zap-generated/cluster-objects.cpp | 4 ++ .../zap-generated/cluster-objects.h | 9 ++- .../zap-generated/cluster/Commands.h | 1 + .../chip-tool/zap-generated/test/Commands.h | 59 +++++++++++++++++-- .../zap-generated/CHIPClientCallbacks.cpp | 6 +- .../zap-generated/CHIPClientCallbacks.h | 4 +- .../zap-generated/IMClusterCommandHandler.cpp | 16 +++-- 21 files changed, 170 insertions(+), 41 deletions(-) diff --git a/examples/chip-tool/commands/tests/TestCommand.h b/examples/chip-tool/commands/tests/TestCommand.h index 998f86bf965550..25eaaa5e5c9506 100644 --- a/examples/chip-tool/commands/tests/TestCommand.h +++ b/examples/chip-tool/commands/tests/TestCommand.h @@ -206,6 +206,30 @@ class TestCommand : public CHIPCommand return false; } + template + bool CheckValueNull(const char * itemName, const chip::app::DataModel::Nullable & value) + { + if (value.IsNull()) + { + return true; + } + + Exit(std::string(itemName) + " expected to be null but isn't"); + return false; + } + + template + bool CheckValueNonNull(const char * itemName, const chip::app::DataModel::Nullable & value) + { + if (!value.IsNull()) + { + return true; + } + + Exit(std::string(itemName) + " expected to not be null but is"); + return false; + } + chip::Callback::Callback mOnDeviceConnectedCallback; chip::Callback::Callback mOnDeviceConnectionFailureCallback; diff --git a/examples/chip-tool/templates/partials/test_cluster.zapt b/examples/chip-tool/templates/partials/test_cluster.zapt index 3ff426f2a28923..bf65435ceedb7e 100644 --- a/examples/chip-tool/templates/partials/test_cluster.zapt +++ b/examples/chip-tool/templates/partials/test_cluster.zapt @@ -172,18 +172,26 @@ class {{filename}}: public TestCommand {{/if}} {{#chip_tests_item_response_parameters}} {{~#*inline "item"}}{{asLowerCamelCase name}}{{#if isOptional}}.Value(){{/if}}{{/inline}} + {{~#*inline "itemValue"}}{{>item}}{{#if isNullable}}.Value(){{/if}}{{/inline}} {{#if hasExpectedValue}} {{#if isOptional}} {{~#*inline "item"}}{{asLowerCamelCase name}}{{/inline}} VerifyOrReturn(CheckValuePresent("{{> item}}", {{> item}})); {{/if}} - VerifyOrReturn(CheckValue - {{~#if isList}}AsListLength("{{>item}}", {{>item}}, {{expectedValue.length}}) - {{else if isArray}}AsList("{{>item}}", {{>item}}, {{expectedValue}}) - {{else if (isString type)}}AsString("{{>item}}", {{>item}}, "{{expectedValue}}") - {{else}}<{{chipType}}>("{{>item}}", {{>item}}, {{expectedValue}}{{asTypeLiteralSuffix type}}) + {{#if (isLiteralNull expectedValue)}} + VerifyOrReturn(CheckValueNull("{{> item}}", {{> item}})); + {{else}} + {{#if isNullable}} + VerifyOrReturn(CheckValueNonNull("{{> item}}", {{> item}})); {{/if}} - ); + VerifyOrReturn(CheckValue + {{~#if isList}}AsListLength("{{>itemValue}}", {{>itemValue}}, {{expectedValue.length}}) + {{else if isArray}}AsList("{{>itemValue}}", {{>itemValue}}, {{expectedValue}}) + {{else if (isString type)}}AsString("{{>itemValue}}", {{>itemValue}}, "{{expectedValue}}") + {{else}}<{{chipType}}>("{{>itemValue}}", {{>itemValue}}, {{expectedValue}}{{asTypeLiteralSuffix type}}) + {{/if}} + ); + {{/if}} {{/if}} {{#if hasExpectedConstraints}} {{#if isOptional}} diff --git a/examples/chip-tool/templates/partials/test_cluster_command_value.zapt b/examples/chip-tool/templates/partials/test_cluster_command_value.zapt index de99a1553ae79d..7c8b74e0d07f06 100644 --- a/examples/chip-tool/templates/partials/test_cluster_command_value.zapt +++ b/examples/chip-tool/templates/partials/test_cluster_command_value.zapt @@ -2,13 +2,17 @@ {{#if ignore}} {{>commandValue ns=ns container=(concat container ".Emplace()") definedValue=definedValue type=type isOptional=false ignore=true}} {{else}} - {{>commandValue ns=ns container=(concat container "." label ".Emplace()") definedValue=definedValue type=type isOptional=false ignore=true}} + {{>commandValue ns=ns container=(concat container "." (asLowerCamelCase label) ".Emplace()") definedValue=definedValue type=type isOptional=false ignore=true}} {{/if}} {{else if isNullable}} - {{#if ignore}} - {{>commandValue ns=ns container=(concat container ".SetNonNull()") definedValue=definedValue type=type isNullable=false ignore=true}} + {{#if (isLiteralNull definedValue)}} + {{container}}{{#unless ignore}}.{{asLowerCamelCase label}}{{/unless}}.SetNull(); {{else}} - {{>commandValue ns=ns container=(concat container "." label ".SetNonNull()") definedValue=definedValue type=type isNullable=false ignore=true}} + {{#if ignore}} + {{>commandValue ns=ns container=(concat container ".SetNonNull()") definedValue=definedValue type=type isNullable=false ignore=true}} + {{else}} + {{>commandValue ns=ns container=(concat container "." (asLowerCamelCase label) ".SetNonNull()") definedValue=definedValue type=type isNullable=false ignore=true}} + {{/if}} {{/if}} {{else if isArray}} @@ -26,9 +30,9 @@ {{#zcl_struct_items_by_struct_name type}} {{#if ../ignore}} - {{>commandValue ns=parent.ns container=(concat parent.container "." label) definedValue=(lookup parent.definedValue name) ignore=../ignore}} + {{>commandValue ns=parent.ns container=(concat parent.container "." (asLowerCamelCase label)) definedValue=(lookup parent.definedValue name) ignore=../ignore}} {{else}} - {{>commandValue ns=parent.ns container=(concat parent.container "." parent.label) definedValue=(lookup parent.definedValue name) ignore=../ignore}} + {{>commandValue ns=parent.ns container=(concat parent.container "." (asLowerCamelCase parent.label)) definedValue=(lookup parent.definedValue name) ignore=../ignore}} {{/if}} {{/zcl_struct_items_by_struct_name}} diff --git a/src/app/clusters/test-cluster-server/test-cluster-server.cpp b/src/app/clusters/test-cluster-server/test-cluster-server.cpp index adad9add1e7ac7..44075196b30534 100644 --- a/src/app/clusters/test-cluster-server/test-cluster-server.cpp +++ b/src/app/clusters/test-cluster-server/test-cluster-server.cpp @@ -444,6 +444,8 @@ bool emberAfTestClusterClusterTestNullableOptionalRequestCallback( { response.value.SetValue(commandData.arg1.Value().Value()); } + + response.originalValue.Emplace(commandData.arg1.Value()); } CHIP_ERROR err = commandObj->AddResponseData(commandPath, response); diff --git a/src/app/tests/suites/TestClusterComplexTypes.yaml b/src/app/tests/suites/TestClusterComplexTypes.yaml index 577fc1fa1fde6c..3eb1f6d4d81c9b 100644 --- a/src/app/tests/suites/TestClusterComplexTypes.yaml +++ b/src/app/tests/suites/TestClusterComplexTypes.yaml @@ -407,6 +407,8 @@ tests: value: false - name: "value" value: 5 + - name: "originalValue" + value: 5 - label: "Send Test Command without its optional arg." command: "testNullableOptionalRequest" @@ -416,7 +418,6 @@ tests: value: false - label: "Send Test Command with optional arg set to null." - disabled: true command: "testNullableOptionalRequest" arguments: values: @@ -427,4 +428,6 @@ tests: - name: "wasPresent" value: true - name: "wasNull" - value: false + value: true + - name: "originalValue" + value: null diff --git a/src/app/zap-templates/common/ClusterTestGeneration.js b/src/app/zap-templates/common/ClusterTestGeneration.js index de8b509440299a..4e276995a159a1 100644 --- a/src/app/zap-templates/common/ClusterTestGeneration.js +++ b/src/app/zap-templates/common/ClusterTestGeneration.js @@ -42,6 +42,13 @@ const kResponseName = 'response'; const kDisabledName = 'disabled'; const kResponseErrorName = 'error'; +class NullObject { + toString() + { + return "YOU SHOULD HAVE CHECKED (isLiteralNull definedValue)" + } +}; + function throwError(test, errorStr) { console.error('Error in: ' + test.filename + '.yaml for test with label: "' + test.label + '"\n'); @@ -417,6 +424,8 @@ function chip_tests_item_parameters(options) } value[key] = attachGlobal(global, value[key]); } + } else if (value === null) { + value = new NullObject(); } else { switch (typeof value) { case 'number': @@ -487,6 +496,13 @@ function chip_tests_item_response_parameters(options) return asBlocks.call(this, promise, options); } +function isLiteralNull(value, options) +{ + // Literal null might look different depending on whether it went through + // attachGlobal or not. + return (value === null) || (value instanceof NullObject); +} + // // Module exports // @@ -496,3 +512,4 @@ exports.chip_tests_item_parameters = chip_tests_item_parameters; exports.chip_tests_item_response_type = chip_tests_item_response_type; exports.chip_tests_item_response_parameters = chip_tests_item_response_parameters; exports.isTestOnlyCluster = isTestOnlyCluster; +exports.isLiteralNull = isLiteralNull; diff --git a/src/app/zap-templates/zcl/data-model/chip/test-cluster.xml b/src/app/zap-templates/zcl/data-model/chip/test-cluster.xml index 4e5abf22ee027c..7d751f3dbd543d 100644 --- a/src/app/zap-templates/zcl/data-model/chip/test-cluster.xml +++ b/src/app/zap-templates/zcl/data-model/chip/test-cluster.xml @@ -367,11 +367,13 @@ limitations under the License. - Delivers information about the argument TestNullableOptionalRequest had. + Delivers information about the argument TestNullableOptionalRequest had, + and the original value if there was one. + diff --git a/src/controller/java/zap-generated/CHIPClusters-JNI.cpp b/src/controller/java/zap-generated/CHIPClusters-JNI.cpp index 382c99b6d9adf7..8b75b5cf19c4cc 100644 --- a/src/controller/java/zap-generated/CHIPClusters-JNI.cpp +++ b/src/controller/java/zap-generated/CHIPClusters-JNI.cpp @@ -6070,7 +6070,7 @@ class CHIPTestClusterClusterTestNullableOptionalResponseCallback env->DeleteGlobalRef(javaCallbackRef); }; - static void CallbackFn(void * context, bool wasPresent, bool wasNull, uint8_t value) + static void CallbackFn(void * context, bool wasPresent, bool wasNull, uint8_t value, uint8_t originalValue) { chip::DeviceLayer::StackUnlock unlock; CHIP_ERROR err = CHIP_NO_ERROR; @@ -6087,11 +6087,11 @@ class CHIPTestClusterClusterTestNullableOptionalResponseCallback javaCallbackRef = cppCallback->javaCallbackRef; VerifyOrExit(javaCallbackRef != nullptr, err = CHIP_NO_ERROR); - err = JniReferences::GetInstance().FindMethod(env, javaCallbackRef, "onSuccess", "(ZZI)V", &javaMethod); + err = JniReferences::GetInstance().FindMethod(env, javaCallbackRef, "onSuccess", "(ZZII)V", &javaMethod); SuccessOrExit(err); env->CallVoidMethod(javaCallbackRef, javaMethod, static_cast(wasPresent), static_cast(wasNull), - static_cast(value)); + static_cast(value), static_cast(originalValue)); exit: if (err != CHIP_NO_ERROR) diff --git a/src/controller/java/zap-generated/chip/devicecontroller/ChipClusters.java b/src/controller/java/zap-generated/chip/devicecontroller/ChipClusters.java index 1929e58ca6ff59..e976ce1a475608 100644 --- a/src/controller/java/zap-generated/chip/devicecontroller/ChipClusters.java +++ b/src/controller/java/zap-generated/chip/devicecontroller/ChipClusters.java @@ -6042,7 +6042,7 @@ void onSuccess( } public interface TestNullableOptionalResponseCallback { - void onSuccess(boolean wasPresent, boolean wasNull, int value); + void onSuccess(boolean wasPresent, boolean wasNull, int value, int originalValue); void onError(Exception error); } diff --git a/src/controller/java/zap-generated/chip/devicecontroller/ClusterInfoMapping.java b/src/controller/java/zap-generated/chip/devicecontroller/ClusterInfoMapping.java index 4f493a542f3b6d..bfc01892ee35f9 100644 --- a/src/controller/java/zap-generated/chip/devicecontroller/ClusterInfoMapping.java +++ b/src/controller/java/zap-generated/chip/devicecontroller/ClusterInfoMapping.java @@ -1870,11 +1870,12 @@ public void setCallbackDelegate(ClusterCommandCallback callback) { } @Override - public void onSuccess(boolean wasPresent, boolean wasNull, int value) { + public void onSuccess(boolean wasPresent, boolean wasNull, int value, int originalValue) { List responseValues = new ArrayList<>(); responseValues.add(wasPresent); responseValues.add(wasNull); responseValues.add(value); + responseValues.add(originalValue); callback.onSuccess(responseValues); } diff --git a/src/controller/python/chip/clusters/Objects.py b/src/controller/python/chip/clusters/Objects.py index 6920c0aa0b3639..6b8cb384ed1c38 100644 --- a/src/controller/python/chip/clusters/Objects.py +++ b/src/controller/python/chip/clusters/Objects.py @@ -20871,11 +20871,14 @@ def descriptor(cls) -> ClusterObjectDescriptor: Label="wasNull", Tag=1, Type=bool), ClusterObjectFieldDescriptor( Label="value", Tag=2, Type=uint), + ClusterObjectFieldDescriptor( + Label="originalValue", Tag=3, Type=uint), ]) wasPresent: 'bool' = None wasNull: 'bool' = None value: 'uint' = None + originalValue: 'uint' = None @dataclass class TestStructArgumentRequest(ClusterCommand): diff --git a/src/darwin/Framework/CHIP/zap-generated/CHIPCallbackBridge.mm b/src/darwin/Framework/CHIP/zap-generated/CHIPCallbackBridge.mm index ea71f7b12863b0..a52e71564494d9 100644 --- a/src/darwin/Framework/CHIP/zap-generated/CHIPCallbackBridge.mm +++ b/src/darwin/Framework/CHIP/zap-generated/CHIPCallbackBridge.mm @@ -1336,12 +1336,13 @@ }; void CHIPTestClusterClusterTestNullableOptionalResponseCallbackBridge::OnSuccessFn( - void * context, bool wasPresent, bool wasNull, uint8_t value) + void * context, bool wasPresent, bool wasNull, uint8_t value, uint8_t originalValue) { DispatchSuccess(context, @ { @"wasPresent" : [NSNumber numberWithBool:wasPresent], @"wasNull" : [NSNumber numberWithBool:wasNull], @"value" : [NSNumber numberWithUnsignedChar:value], + @"originalValue" : [NSNumber numberWithUnsignedChar:originalValue], }); }; diff --git a/src/darwin/Framework/CHIP/zap-generated/CHIPCallbackBridge_internal.h b/src/darwin/Framework/CHIP/zap-generated/CHIPCallbackBridge_internal.h index 5e401e22dea36b..6fc46dddefc907 100644 --- a/src/darwin/Framework/CHIP/zap-generated/CHIPCallbackBridge_internal.h +++ b/src/darwin/Framework/CHIP/zap-generated/CHIPCallbackBridge_internal.h @@ -1335,7 +1335,7 @@ class CHIPTestClusterClusterTestNullableOptionalResponseCallbackBridge CHIPCallbackBridge(queue, handler, action, OnSuccessFn, keepAlive){}; - static void OnSuccessFn(void * context, bool wasPresent, bool wasNull, uint8_t value); + static void OnSuccessFn(void * context, bool wasPresent, bool wasNull, uint8_t value, uint8_t originalValue); }; class CHIPTestClusterClusterTestSpecificResponseCallbackBridge diff --git a/zzz_generated/app-common/app-common/zap-generated/callback.h b/zzz_generated/app-common/app-common/zap-generated/callback.h index 8555176f51251b..1af1282031ab56 100644 --- a/zzz_generated/app-common/app-common/zap-generated/callback.h +++ b/zzz_generated/app-common/app-common/zap-generated/callback.h @@ -14093,7 +14093,8 @@ bool emberAfTestClusterClusterTestStructArrayArgumentRequestCallback( * @brief Test Cluster Cluster TestNullableOptionalResponse Command callback (from server) */ bool emberAfTestClusterClusterTestNullableOptionalResponseCallback(chip::EndpointId endpoint, chip::app::CommandSender * commandObj, - bool wasPresent, bool wasNull, uint8_t value); + bool wasPresent, bool wasNull, uint8_t value, + uint8_t originalValue); /** * @brief Test Cluster Cluster TestStructArgumentRequest Command callback (from client) */ diff --git a/zzz_generated/app-common/app-common/zap-generated/cluster-objects.cpp b/zzz_generated/app-common/app-common/zap-generated/cluster-objects.cpp index c13c1d0bf235ad..eb883679323656 100644 --- a/zzz_generated/app-common/app-common/zap-generated/cluster-objects.cpp +++ b/zzz_generated/app-common/app-common/zap-generated/cluster-objects.cpp @@ -16461,6 +16461,7 @@ CHIP_ERROR Type::Encode(TLV::TLVWriter & writer, TLV::Tag tag) const ReturnErrorOnFailure(DataModel::Encode(writer, TLV::ContextTag(to_underlying(Fields::kWasPresent)), wasPresent)); ReturnErrorOnFailure(DataModel::Encode(writer, TLV::ContextTag(to_underlying(Fields::kWasNull)), wasNull)); ReturnErrorOnFailure(DataModel::Encode(writer, TLV::ContextTag(to_underlying(Fields::kValue)), value)); + ReturnErrorOnFailure(DataModel::Encode(writer, TLV::ContextTag(to_underlying(Fields::kOriginalValue)), originalValue)); ReturnErrorOnFailure(writer.EndContainer(outer)); return CHIP_NO_ERROR; } @@ -16485,6 +16486,9 @@ CHIP_ERROR DecodableType::Decode(TLV::TLVReader & reader) case to_underlying(Fields::kValue): ReturnErrorOnFailure(DataModel::Decode(reader, value)); break; + case to_underlying(Fields::kOriginalValue): + ReturnErrorOnFailure(DataModel::Decode(reader, originalValue)); + break; default: break; } diff --git a/zzz_generated/app-common/app-common/zap-generated/cluster-objects.h b/zzz_generated/app-common/app-common/zap-generated/cluster-objects.h index f621eb402529d1..b5ecdeef8740f4 100644 --- a/zzz_generated/app-common/app-common/zap-generated/cluster-objects.h +++ b/zzz_generated/app-common/app-common/zap-generated/cluster-objects.h @@ -23603,9 +23603,10 @@ struct DecodableType namespace TestNullableOptionalResponse { enum class Fields { - kWasPresent = 0, - kWasNull = 1, - kValue = 2, + kWasPresent = 0, + kWasNull = 1, + kValue = 2, + kOriginalValue = 3, }; struct Type @@ -23618,6 +23619,7 @@ struct Type bool wasPresent; Optional wasNull; Optional value; + Optional> originalValue; CHIP_ERROR Encode(TLV::TLVWriter & writer, TLV::Tag tag) const; }; @@ -23631,6 +23633,7 @@ struct DecodableType bool wasPresent; Optional wasNull; Optional value; + Optional> originalValue; CHIP_ERROR Decode(TLV::TLVReader & reader); }; }; // namespace TestNullableOptionalResponse diff --git a/zzz_generated/chip-tool/zap-generated/cluster/Commands.h b/zzz_generated/chip-tool/zap-generated/cluster/Commands.h index 894aa6f97f73ea..c3d29751c04a47 100644 --- a/zzz_generated/chip-tool/zap-generated/cluster/Commands.h +++ b/zzz_generated/chip-tool/zap-generated/cluster/Commands.h @@ -1924,6 +1924,7 @@ static void OnTestClusterTestNullableOptionalResponseSuccess( ChipLogProgress(Zcl, " wasPresent: %d", data.wasPresent); ChipLogProgress(Zcl, " wasNull: Optional printing is not implemented yet."); ChipLogProgress(Zcl, " value: Optional printing is not implemented yet."); + ChipLogProgress(Zcl, " originalValue: Optional printing is not implemented yet."); ModelCommand * command = static_cast(context); command->SetCommandExitStatus(CHIP_NO_ERROR); diff --git a/zzz_generated/chip-tool/zap-generated/test/Commands.h b/zzz_generated/chip-tool/zap-generated/test/Commands.h index 13f26b14274534..46a2d91e827252 100644 --- a/zzz_generated/chip-tool/zap-generated/test/Commands.h +++ b/zzz_generated/chip-tool/zap-generated/test/Commands.h @@ -22464,6 +22464,10 @@ class TestClusterComplexTypes : public TestCommand ChipLogProgress(chipTool, " ***** Test Step 8 : Send Test Command without its optional arg.\n"); err = TestSendTestCommandWithoutItsOptionalArg_8(); break; + case 9: + ChipLogProgress(chipTool, " ***** Test Step 9 : Send Test Command with optional arg set to null.\n"); + err = TestSendTestCommandWithOptionalArgSetToNull_9(); + break; } if (CHIP_NO_ERROR != err) @@ -22475,7 +22479,7 @@ class TestClusterComplexTypes : public TestCommand private: std::atomic_uint16_t mTestIndex; - const uint16_t mTestCount = 9; + const uint16_t mTestCount = 10; // // Tests methods @@ -22752,7 +22756,8 @@ class TestClusterComplexTypes : public TestCommand request.arg1.Emplace().SetNonNull() = 5; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_7(data.wasPresent, data.wasNull, data.value); + (static_cast(context)) + ->OnSuccessResponse_7(data.wasPresent, data.wasNull, data.value, data.originalValue); }; auto failure = [](void * context, EmberAfStatus status) { @@ -22763,7 +22768,8 @@ class TestClusterComplexTypes : public TestCommand void OnFailureResponse_7(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_7(bool wasPresent, const chip::Optional & wasNull, const chip::Optional & value) + void OnSuccessResponse_7(bool wasPresent, const chip::Optional & wasNull, const chip::Optional & value, + const chip::Optional> & originalValue) { VerifyOrReturn(CheckValue("wasPresent", wasPresent, true)); @@ -22772,6 +22778,10 @@ class TestClusterComplexTypes : public TestCommand VerifyOrReturn(CheckValuePresent("value", value)); VerifyOrReturn(CheckValue("value.Value()", value.Value(), 5)); + + VerifyOrReturn(CheckValuePresent("originalValue", originalValue)); + VerifyOrReturn(CheckValueNonNull("originalValue.Value()", originalValue.Value())); + VerifyOrReturn(CheckValue("originalValue.Value().Value()", originalValue.Value().Value(), 5)); NextTest(); } @@ -22786,7 +22796,8 @@ class TestClusterComplexTypes : public TestCommand chip::app::Clusters::TestCluster::Commands::TestNullableOptionalRequest::Type request; auto success = [](void * context, const responseType & data) { - (static_cast(context))->OnSuccessResponse_8(data.wasPresent, data.wasNull, data.value); + (static_cast(context)) + ->OnSuccessResponse_8(data.wasPresent, data.wasNull, data.value, data.originalValue); }; auto failure = [](void * context, EmberAfStatus status) { @@ -22797,12 +22808,50 @@ class TestClusterComplexTypes : public TestCommand void OnFailureResponse_8(uint8_t status) { ThrowFailureResponse(); } - void OnSuccessResponse_8(bool wasPresent, const chip::Optional & wasNull, const chip::Optional & value) + void OnSuccessResponse_8(bool wasPresent, const chip::Optional & wasNull, const chip::Optional & value, + const chip::Optional> & originalValue) { VerifyOrReturn(CheckValue("wasPresent", wasPresent, false)); NextTest(); } + + CHIP_ERROR TestSendTestCommandWithOptionalArgSetToNull_9() + { + chip::Controller::TestClusterClusterTest cluster; + cluster.Associate(mDevice, 1); + + using requestType = chip::app::Clusters::TestCluster::Commands::TestNullableOptionalRequest::Type; + using responseType = chip::app::Clusters::TestCluster::Commands::TestNullableOptionalResponse::DecodableType; + + chip::app::Clusters::TestCluster::Commands::TestNullableOptionalRequest::Type request; + request.arg1.Emplace().SetNull(); + + auto success = [](void * context, const responseType & data) { + (static_cast(context)) + ->OnSuccessResponse_9(data.wasPresent, data.wasNull, data.value, data.originalValue); + }; + + auto failure = [](void * context, EmberAfStatus status) { + (static_cast(context))->OnFailureResponse_9(status); + }; + return cluster.InvokeCommand(request, this, success, failure); + } + + void OnFailureResponse_9(uint8_t status) { ThrowFailureResponse(); } + + void OnSuccessResponse_9(bool wasPresent, const chip::Optional & wasNull, const chip::Optional & value, + const chip::Optional> & originalValue) + { + VerifyOrReturn(CheckValue("wasPresent", wasPresent, true)); + + VerifyOrReturn(CheckValuePresent("wasNull", wasNull)); + VerifyOrReturn(CheckValue("wasNull.Value()", wasNull.Value(), true)); + + VerifyOrReturn(CheckValuePresent("originalValue", originalValue)); + VerifyOrReturn(CheckValueNull("originalValue.Value()", originalValue.Value())); + NextTest(); + } }; class TestConstraints : public TestCommand diff --git a/zzz_generated/controller-clusters/zap-generated/CHIPClientCallbacks.cpp b/zzz_generated/controller-clusters/zap-generated/CHIPClientCallbacks.cpp index 680cb1cb9487ca..bb42802e80992b 100644 --- a/zzz_generated/controller-clusters/zap-generated/CHIPClientCallbacks.cpp +++ b/zzz_generated/controller-clusters/zap-generated/CHIPClientCallbacks.cpp @@ -1959,18 +1959,20 @@ bool emberAfTestClusterClusterTestListInt8UReverseResponseCallback(EndpointId en } bool emberAfTestClusterClusterTestNullableOptionalResponseCallback(EndpointId endpoint, app::CommandSender * commandObj, - bool wasPresent, bool wasNull, uint8_t value) + bool wasPresent, bool wasNull, uint8_t value, + uint8_t originalValue) { ChipLogProgress(Zcl, "TestNullableOptionalResponse:"); ChipLogProgress(Zcl, " wasPresent: %d", wasPresent); ChipLogProgress(Zcl, " wasNull: %d", wasNull); ChipLogProgress(Zcl, " value: %" PRIu8 "", value); + ChipLogProgress(Zcl, " originalValue: %" PRIu8 "", originalValue); GET_CLUSTER_RESPONSE_CALLBACKS("TestClusterClusterTestNullableOptionalResponseCallback"); Callback::Callback * cb = Callback::Callback::FromCancelable(onSuccessCallback); - cb->mCall(cb->mContext, wasPresent, wasNull, value); + cb->mCall(cb->mContext, wasPresent, wasNull, value, originalValue); return true; } diff --git a/zzz_generated/controller-clusters/zap-generated/CHIPClientCallbacks.h b/zzz_generated/controller-clusters/zap-generated/CHIPClientCallbacks.h index 91189b79b90e4a..90a15f2c138e19 100644 --- a/zzz_generated/controller-clusters/zap-generated/CHIPClientCallbacks.h +++ b/zzz_generated/controller-clusters/zap-generated/CHIPClientCallbacks.h @@ -146,8 +146,8 @@ typedef void (*TestClusterClusterTestAddArgumentsResponseCallback)(void * contex typedef void (*TestClusterClusterTestEnumsResponseCallback)(void * context, chip::VendorId arg1, uint8_t arg2); typedef void (*TestClusterClusterTestListInt8UReverseResponseCallback)(void * context, /* TYPE WARNING: array array defaults to */ uint8_t * arg1); -typedef void (*TestClusterClusterTestNullableOptionalResponseCallback)(void * context, bool wasPresent, bool wasNull, - uint8_t value); +typedef void (*TestClusterClusterTestNullableOptionalResponseCallback)(void * context, bool wasPresent, bool wasNull, uint8_t value, + uint8_t originalValue); typedef void (*TestClusterClusterTestSpecificResponseCallback)(void * context, uint8_t returnValue); // List specific responses diff --git a/zzz_generated/controller-clusters/zap-generated/IMClusterCommandHandler.cpp b/zzz_generated/controller-clusters/zap-generated/IMClusterCommandHandler.cpp index aa269a32a2f479..d6e4378484b48a 100644 --- a/zzz_generated/controller-clusters/zap-generated/IMClusterCommandHandler.cpp +++ b/zzz_generated/controller-clusters/zap-generated/IMClusterCommandHandler.cpp @@ -5364,11 +5364,12 @@ void DispatchClientCommand(CommandSender * apCommandObj, const ConcreteCommandPa break; } case Commands::TestNullableOptionalResponse::Id: { - expectArgumentCount = 3; + expectArgumentCount = 4; bool wasPresent; bool wasNull; uint8_t value; - bool argExists[3]; + uint8_t originalValue; + bool argExists[4]; memset(argExists, 0, sizeof argExists); @@ -5381,7 +5382,7 @@ void DispatchClientCommand(CommandSender * apCommandObj, const ConcreteCommandPa continue; } currentDecodeTagId = TLV::TagNumFromTag(aDataTlv.GetTag()); - if (currentDecodeTagId < 3) + if (currentDecodeTagId < 4) { if (argExists[currentDecodeTagId]) { @@ -5406,6 +5407,9 @@ void DispatchClientCommand(CommandSender * apCommandObj, const ConcreteCommandPa case 2: TLVUnpackError = aDataTlv.Get(value); break; + case 3: + TLVUnpackError = aDataTlv.Get(originalValue); + break; default: // Unsupported tag, ignore it. ChipLogProgress(Zcl, "Unknown TLV tag during processing."); @@ -5423,10 +5427,10 @@ void DispatchClientCommand(CommandSender * apCommandObj, const ConcreteCommandPa TLVError = CHIP_NO_ERROR; } - if (CHIP_NO_ERROR == TLVError && CHIP_NO_ERROR == TLVUnpackError && 3 == validArgumentCount) + if (CHIP_NO_ERROR == TLVError && CHIP_NO_ERROR == TLVUnpackError && 4 == validArgumentCount) { - wasHandled = emberAfTestClusterClusterTestNullableOptionalResponseCallback(aCommandPath.mEndpointId, apCommandObj, - wasPresent, wasNull, value); + wasHandled = emberAfTestClusterClusterTestNullableOptionalResponseCallback( + aCommandPath.mEndpointId, apCommandObj, wasPresent, wasNull, value, originalValue); } break; }