From 2959089c25691132db2fe4c3648d8b454f562c42 Mon Sep 17 00:00:00 2001 From: Boris Zbarsky Date: Tue, 21 Jun 2022 20:23:40 -0400 Subject: [PATCH] Fix detection of negative integers when floating point is expected. (#19821) Our "see if it's an integer and append .0" code for floating point only detected positive integers, so we were ending up with things like "-1f" in generated code, which does not compile. Fixes https://github.com/project-chip/connectedhomeip/issues/19800 --- .../suites/certification/Test_TC_MC_6_4.yaml | 2 - src/app/zap-templates/templates/app/helper.js | 2 +- .../chip-tool/zap-generated/test/Commands.h | 66 +++++++++++++------ 3 files changed, 47 insertions(+), 23 deletions(-) diff --git a/src/app/tests/suites/certification/Test_TC_MC_6_4.yaml b/src/app/tests/suites/certification/Test_TC_MC_6_4.yaml index cd752750a08ef3..3dffe2f9952b14 100644 --- a/src/app/tests/suites/certification/Test_TC_MC_6_4.yaml +++ b/src/app/tests/suites/certification/Test_TC_MC_6_4.yaml @@ -123,7 +123,6 @@ tests: value: 0 - label: "Reads the PlaybackSpeed attribute from the DUT" - disabled: true command: "readAttribute" attribute: "PlaybackSpeed" response: @@ -142,7 +141,6 @@ tests: value: "Verify that the media play has reversed direction" - label: "Reads the PlaybackSpeed attribute from the DUT" - disabled: true command: "readAttribute" attribute: "PlaybackSpeed" response: diff --git a/src/app/zap-templates/templates/app/helper.js b/src/app/zap-templates/templates/app/helper.js index bf22b041e3fc25..66033f0100de5f 100644 --- a/src/app/zap-templates/templates/app/helper.js +++ b/src/app/zap-templates/templates/app/helper.js @@ -349,7 +349,7 @@ async function asTypedLiteral(value, type, cookie) // If the number looks like an integer, append ".0" to the end; // otherwise adding an "f" suffix makes compilers complain. value = value.toString(); - if (value.match(/^[0-9]+$/)) { + if (value.match(/^-?[0-9]+$/)) { value = value + ".0"; } return value + 'f'; diff --git a/zzz_generated/chip-tool/zap-generated/test/Commands.h b/zzz_generated/chip-tool/zap-generated/test/Commands.h index 5157f66391ac87..e21eeb04e29f52 100644 --- a/zzz_generated/chip-tool/zap-generated/test/Commands.h +++ b/zzz_generated/chip-tool/zap-generated/test/Commands.h @@ -76478,7 +76478,7 @@ class Test_TC_MC_6_3Suite : public TestCommand class Test_TC_MC_6_4Suite : public TestCommand { public: - Test_TC_MC_6_4Suite(CredentialIssuerCommands * credsIssuerConfig) : TestCommand("Test_TC_MC_6_4", 22, credsIssuerConfig) + Test_TC_MC_6_4Suite(CredentialIssuerCommands * credsIssuerConfig) : TestCommand("Test_TC_MC_6_4", 24, credsIssuerConfig) { AddArgument("nodeId", 0, UINT64_MAX, &mNodeId); AddArgument("cluster", &mCluster); @@ -76610,26 +76610,42 @@ class Test_TC_MC_6_4Suite : public TestCommand case 15: VerifyOrReturn(CheckValue("status", chip::to_underlying(status.mStatus), 0)); { - chip::app::Clusters::MediaPlayback::Commands::PlaybackResponse::DecodableType value; + float value; VerifyOrReturn(CheckDecodeValue(chip::app::DataModel::Decode(*data, value))); + VerifyOrReturn(CheckValue("playbackSpeed", value, -1.0f)); } break; case 16: VerifyOrReturn(CheckValue("status", chip::to_underlying(status.mStatus), 0)); - shouldContinue = true; + { + chip::app::Clusters::MediaPlayback::Commands::PlaybackResponse::DecodableType value; + VerifyOrReturn(CheckDecodeValue(chip::app::DataModel::Decode(*data, value))); + } break; case 17: + VerifyOrReturn(CheckValue("status", chip::to_underlying(status.mStatus), 0)); + shouldContinue = true; + break; + case 18: + VerifyOrReturn(CheckValue("status", chip::to_underlying(status.mStatus), 0)); + { + float value; + VerifyOrReturn(CheckDecodeValue(chip::app::DataModel::Decode(*data, value))); + VerifyOrReturn(CheckValue("playbackSpeed", value, -2.0f)); + } + break; + case 19: VerifyOrReturn(CheckValue("status", chip::to_underlying(status.mStatus), 0)); { chip::app::Clusters::MediaPlayback::Commands::PlaybackResponse::DecodableType value; VerifyOrReturn(CheckDecodeValue(chip::app::DataModel::Decode(*data, value))); } break; - case 18: + case 20: VerifyOrReturn(CheckValue("status", chip::to_underlying(status.mStatus), 0)); shouldContinue = true; break; - case 19: + case 21: VerifyOrReturn(CheckValue("status", chip::to_underlying(status.mStatus), 0)); { float value; @@ -76637,10 +76653,10 @@ class Test_TC_MC_6_4Suite : public TestCommand VerifyOrReturn(CheckValue("playbackSpeed", value, 1.0f)); } break; - case 20: + case 22: VerifyOrReturn(CheckValue("status", chip::to_underlying(status.mStatus), 4)); break; - case 21: + case 23: VerifyOrReturn(CheckValue("status", chip::to_underlying(status.mStatus), 4)); break; default: @@ -76769,7 +76785,12 @@ class Test_TC_MC_6_4Suite : public TestCommand true, chip::NullOptional); } case 15: { - LogStep(15, "Sends a Rewind command to the DUT"); + LogStep(15, "Reads the PlaybackSpeed attribute from the DUT"); + return ReadAttribute(kIdentityAlpha, GetEndpoint(1), MediaPlayback::Id, MediaPlayback::Attributes::PlaybackSpeed::Id, + true, chip::NullOptional); + } + case 16: { + LogStep(16, "Sends a Rewind command to the DUT"); VerifyOrDo(!ShouldSkip("PICS_SKIP_SAMPLE_APP"), return ContinueOnChipMainThread(CHIP_NO_ERROR)); ListFreer listFreer; chip::app::Clusters::MediaPlayback::Commands::Rewind::Type value; @@ -76778,16 +76799,21 @@ class Test_TC_MC_6_4Suite : public TestCommand ); } - case 16: { - LogStep(16, "log a command"); + case 17: { + LogStep(17, "log a command"); ListFreer listFreer; chip::app::Clusters::LogCommands::Commands::UserPrompt::Type value; value.message = chip::Span("Verify that the media play has reversed directiongarbage: not in length on purpose", 49); return UserPrompt(kIdentityAlpha, value); } - case 17: { - LogStep(17, "Sends a Play command"); + case 18: { + LogStep(18, "Reads the PlaybackSpeed attribute from the DUT"); + return ReadAttribute(kIdentityAlpha, GetEndpoint(1), MediaPlayback::Id, MediaPlayback::Attributes::PlaybackSpeed::Id, + true, chip::NullOptional); + } + case 19: { + LogStep(19, "Sends a Play command"); VerifyOrDo(!ShouldSkip("PICS_SKIP_SAMPLE_APP"), return ContinueOnChipMainThread(CHIP_NO_ERROR)); ListFreer listFreer; chip::app::Clusters::MediaPlayback::Commands::Play::Type value; @@ -76796,22 +76822,22 @@ class Test_TC_MC_6_4Suite : public TestCommand ); } - case 18: { - LogStep(18, "log a command"); + case 20: { + LogStep(20, "log a command"); ListFreer listFreer; chip::app::Clusters::LogCommands::Commands::UserPrompt::Type value; value.message = chip::Span( "Verify that the media is has resumed playing forward at the default speedgarbage: not in length on purpose", 73); return UserPrompt(kIdentityAlpha, value); } - case 19: { - LogStep(19, "Reads the PlaybackSpeed attribute from the DUT"); + case 21: { + LogStep(21, "Reads the PlaybackSpeed attribute from the DUT"); VerifyOrDo(!ShouldSkip("PICS_SKIP_SAMPLE_APP"), return ContinueOnChipMainThread(CHIP_NO_ERROR)); return ReadAttribute(kIdentityAlpha, GetEndpoint(1), MediaPlayback::Id, MediaPlayback::Attributes::PlaybackSpeed::Id, true, chip::NullOptional); } - case 20: { - LogStep(20, "Sends consecutive FastForward commands"); + case 22: { + LogStep(22, "Sends consecutive FastForward commands"); VerifyOrDo(!ShouldSkip("PICS_SKIP_SAMPLE_APP"), return ContinueOnChipMainThread(CHIP_NO_ERROR)); ListFreer listFreer; chip::app::Clusters::MediaPlayback::Commands::FastForward::Type value; @@ -76820,8 +76846,8 @@ class Test_TC_MC_6_4Suite : public TestCommand ); } - case 21: { - LogStep(21, "Sends consecutive Rewind commands"); + case 23: { + LogStep(23, "Sends consecutive Rewind commands"); VerifyOrDo(!ShouldSkip("PICS_SKIP_SAMPLE_APP"), return ContinueOnChipMainThread(CHIP_NO_ERROR)); ListFreer listFreer; chip::app::Clusters::MediaPlayback::Commands::Rewind::Type value;