Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[HVAC] Handle null BuiltIn field on Preset write according to spec #35161

Merged
merged 159 commits into from
Aug 27, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
159 commits
Select commit Hold shift + click to select a range
46d9098
Add support for Presets attributes and commands to the Thermostat clu…
nivi-apple Jul 26, 2024
5d2c740
Restyled by whitespace
restyled-commits Jul 26, 2024
f14e43e
Restyled by clang-format
restyled-commits Jul 26, 2024
dfe9f7c
Restyled by gn.
restyled-commits Jul 26, 2024
3dad3f3
Fix build error for Linux configure build of all-clusters-app
nivi-apple Jul 26, 2024
8e6db6e
Fix Darwin CI issues
nivi-apple Jul 26, 2024
362ca12
Restyled by clang-format
restyled-commits Jul 26, 2024
cb96615
More fixes
nivi-apple Jul 26, 2024
07e78e0
Restyled by clang-format
restyled-commits Jul 26, 2024
9c511bf
BUILD.gn fixes for CI
nivi-apple Jul 26, 2024
f027069
Apply suggestions from code review
nivi-apple Jul 26, 2024
a2bb5d6
Address review comments.
nivi-apple Jul 27, 2024
0147c71
Restyled by clang-format
restyled-commits Jul 27, 2024
029e9a4
Regenerate Thermostat XML from spec
hasty Jul 28, 2024
48ac309
Move atomic enum to global-enums.xml, actually
hasty Jul 26, 2024
5216415
Regenerate XML and convert thermostat-server to atomic writes
hasty Jul 28, 2024
72d114f
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 29, 2024
38d14fc
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 29, 2024
8511469
Pull in ACCapacityFormat typo un-fix
hasty Jul 29, 2024
dabf994
Update Test_TC_TSTAT_1_1 to know about AtomicResponse command.
bzbarsky-apple Jul 29, 2024
0212f7c
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 29, 2024
90a20c1
Restyled patch
hasty Jul 29, 2024
a567de4
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Jul 29, 2024
1c49a80
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 29, 2024
aef165e
Fix weird merge with upstream
hasty Jul 29, 2024
9efed86
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Jul 29, 2024
4c457a9
Fix emberAfIsTypeSigned not understanding temperature type
hasty Jul 29, 2024
1257477
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 29, 2024
c34a9cb
Merge fixes from atomic write branch
hasty Jul 30, 2024
4665050
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
6d2fda4
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Jul 30, 2024
7acd5d4
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
8dbabb1
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
704c544
Relocate thermostat-manager sample code to all-clusters-common
hasty Jul 30, 2024
9d89cfe
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
7a4f4fd
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Jul 30, 2024
6de046a
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
d67f988
Fix g++ build error on linux
hasty Jul 30, 2024
449379b
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Jul 30, 2024
4c8e0a0
Fix C formatter for long int, cast whole expression
hasty Jul 30, 2024
c76e768
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
3f40391
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Jul 30, 2024
5ce2df1
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
cf780e3
Sync cast fix with master
hasty Jul 30, 2024
af25396
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
c80f42d
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Jul 30, 2024
b4f50f6
Add thermostat-common dependency to thermostat app under linux
hasty Jul 30, 2024
51d8aaa
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
5abc22d
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Jul 30, 2024
637db40
Remove MatterPostAttributeChangeCallback from thermostat-manager, as …
hasty Jul 30, 2024
fadce3b
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
c6e07d0
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Jul 30, 2024
4b03da7
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
0c1b853
Convert Atomic enums and structs to global
hasty Jul 30, 2024
c41d02c
Restyled patch
hasty Jul 30, 2024
924ad8f
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 30, 2024
7d8df6e
Merge branch 'master' into add_presets_to_Sdk
hasty Jul 31, 2024
31ebe9d
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Jul 31, 2024
2740112
Apply suggestions from code review
hasty Jul 31, 2024
dabc3a0
Regen with alchemy 0.6.1
hasty Aug 1, 2024
f08c0cf
Updates based on comments
hasty Aug 1, 2024
77c0dca
Add TC_MCORE_FS_1_3.py test implementation (#34650)
tehampson Jul 31, 2024
608d034
Fix most TC-SWTCH-2.4 remaining issues (#34677)
tcarmelveilleux Jul 31, 2024
dc312d7
Initial test script for Fabric Sync TC_MCORE_FS_1_2 (#34675)
cletnick Jul 31, 2024
ad792f1
Test automation for FabricSync ICD BridgedDeviceBasicInfoCluster (#34…
rochaferraz Jul 31, 2024
60d0429
ServiceArea test scripts (#34548)
plauric Jul 31, 2024
78dab72
Remove manual tests for Thermostat presets (#34679)
nivi-apple Jul 31, 2024
d7cadf9
Dump details about leaked ExchangeContexts before aborting (#34617)
ksperling-apple Jul 31, 2024
153c398
[TI] CC13x4_26x4 build fixes (#34682)
abiradarti Aug 1, 2024
b2e22c7
[ICD] Add missing polling function to NoWifi connectivity manager (#3…
mkardous-silabs Aug 1, 2024
12d0123
[OPSTATE] Add Q test script for CountdownTime (#34632)
rbultman Aug 1, 2024
9351279
YAML update to BRBINFO, ProductId (#34513)
rochaferraz Aug 1, 2024
08cb38b
Fix simplified Linux tv-casting-app gn build error. (#34692)
shaoltan-amazon Aug 1, 2024
ee27016
adding parallel execution to restyle-diff (#34663)
Alami-Amine Aug 1, 2024
aebaedb
Add some bits to exercise global structs/enums to Unit Testing cluste…
bzbarsky-apple Aug 1, 2024
1a7352f
[Silabs] Port platform specific Multi-Chip OTA work (#34440)
mykrupp Aug 1, 2024
eb59fc3
Add python tests for Thermostat presets feature (#34693)
nivi-apple Aug 1, 2024
5c6312b
removing unneccessary git fetch (#34698)
Alami-Amine Aug 1, 2024
687b1ac
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Aug 1, 2024
6cb787b
Merge branch 'master' into add_presets_to_Sdk
hasty Aug 1, 2024
b815bbd
Restyle patch
hasty Aug 1, 2024
cf97803
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Aug 1, 2024
d424a77
Regen to fix ordering of global structs
hasty Aug 1, 2024
b5410d3
Apply suggestions from code review
hasty Aug 1, 2024
353c9c1
Return correct AtomicResponse when committing or rolling back
hasty Aug 1, 2024
c58ab73
Merge branch 'master' of github.com:project-chip/connectedhomeip into…
hasty Aug 1, 2024
f0b8e7d
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Aug 1, 2024
be7ca99
Patch tests for atomic write of presets
hasty Aug 2, 2024
23f3063
Fix tests to work with the new setup.
bzbarsky-apple Aug 2, 2024
ed59a01
Merge pull request #1 from bzbarsky-apple/pr-34570-fixup
hasty Aug 2, 2024
627e3f6
Merge branch 'master' of github.com:project-chip/connectedhomeip into…
hasty Aug 4, 2024
0966a01
Merge branch 'master' into add_presets_to_Sdk
hasty Aug 4, 2024
c37228c
Fix PICS values for atomic requests
hasty Aug 4, 2024
ba877a8
Remove PresetsSchedulesEditable and QueuedPreset from various places
hasty Aug 4, 2024
1106e1f
Restyled patch
hasty Aug 4, 2024
18d202a
Restyled patch, again
hasty Aug 4, 2024
18325f4
Remove PICS value for PresetsSchedulesEditable
hasty Aug 4, 2024
11eda5a
clang-tidy fixes
hasty Aug 5, 2024
0478b52
clang-tidy fixes
hasty Aug 5, 2024
9a4d415
Merge branch 'add_presets_to_Sdk' of github.com:hasty/connectedhomeip…
hasty Aug 5, 2024
12aa64f
Clear associated atomic writes when fabric is removed
hasty Aug 6, 2024
520eb2f
Add tests for fabric removal and lockout of clients outside of atomic…
hasty Aug 6, 2024
62f75c4
Merge branch 'master' of github.com:project-chip/connectedhomeip into…
hasty Aug 6, 2024
c09f01e
Python linter
hasty Aug 6, 2024
f9141fb
Restyled patch
hasty Aug 6, 2024
9fc8882
Merge branch 'master' into granbery/preset_atomic_write_fabric_index
hasty Aug 6, 2024
3d5abb5
Merge branch 'granbery/preset_atomic_write_fabric_index' of github.co…
hasty Aug 6, 2024
4c26dd4
Clear timer when fabric is removed
hasty Aug 6, 2024
2a84acb
Check for open atomic write before resetting
hasty Aug 6, 2024
98e8e2c
Merge branch 'master' into granbery/preset_atomic_write_fabric_index
hasty Aug 6, 2024
bdc747e
Revert auto delegate declaration on lines where there's no collision
hasty Aug 6, 2024
2f9a711
Allow Thermostat delegate to provide timeout for atomic requests
hasty Aug 6, 2024
1b7c152
Merge branch 'master' into granbery/preset_atomic_write_timeout
hasty Aug 6, 2024
0a5d2b8
Relocate thermostat example code to thermostat-common
hasty Aug 6, 2024
cc7f6e5
Remove thermostat-manager code, replace with thermostat delegate
hasty Aug 6, 2024
2a15976
Sync atomic write error order with spec
hasty Aug 8, 2024
c683088
Merge branch 'master' into granbery/preset_atomic
hasty Aug 12, 2024
1ea2a9a
Restyle patch
hasty Aug 12, 2024
b105a27
Drop memset of atomic write sessions
hasty Aug 12, 2024
5f2db17
Add PreCommit stage to allow rollback of multiple attributes when onl…
hasty Aug 13, 2024
04bdb52
Separate OnTimerExpired method, vs ResetWrite
hasty Aug 13, 2024
b40ad4e
Method documentation
hasty Aug 13, 2024
6eb3031
Merge branch 'master' of github.com:project-chip/connectedhomeip into…
hasty Aug 13, 2024
c19c321
Apply suggestions from code review
hasty Aug 13, 2024
802c60c
Remove unused InWrite check
hasty Aug 13, 2024
344e28c
Drop imcode alias
hasty Aug 13, 2024
b4fc09e
Switch AtomicWriteState to enum class
hasty Aug 14, 2024
e9fa63d
DRY up atomic write manager
hasty Aug 14, 2024
c522171
Apply suggestions from code review
hasty Aug 14, 2024
23b8ec2
Drop duplicate doc comments
hasty Aug 14, 2024
345efa3
Rename GetAtomicWriteScopedNodeId to GetAtomicWriteOriginatorScopedNo…
hasty Aug 14, 2024
84ddee2
Updates based on comments
hasty Aug 14, 2024
08190ae
Merge branch 'granbery/preset_atomic' of github.com:hasty/connectedho…
hasty Aug 14, 2024
7cec405
Add MatterReportingAttributeChangeCallback calls for updated attributes
hasty Aug 14, 2024
69a41e9
Merge branch 'master' into granbery/preset_atomic
hasty Aug 16, 2024
2ecf2db
Relocate thermostat example code to thermostat-common, and remove the…
hasty Aug 21, 2024
62a9b4d
Merge atomic write code back into thermostat-server
hasty Aug 21, 2024
186630f
Merge branch 'granbery/preset_atomic_status' into granbery/preset_atomic
hasty Aug 21, 2024
dad5709
Merge remote-tracking branch 'upstream/master' into granbery/preset_a…
hasty Aug 21, 2024
a2f3500
Apply suggestions from code review
hasty Aug 22, 2024
9663f30
Fix build after suggestions
hasty Aug 22, 2024
98051bc
Actually track attribute IDs associated with atomic write
hasty Aug 22, 2024
f6ccf2e
Only commit presets if all attribute precommits were successful
hasty Aug 22, 2024
e1b7033
Fix scope on err
hasty Aug 22, 2024
1b89c4a
Add documentation to methods
hasty Aug 22, 2024
bd82243
Remove duplicate preset check.
hasty Aug 22, 2024
78c0f22
Move various functions into anonymous namespaces, or Thermostat names…
hasty Aug 22, 2024
0c395c1
Drop impossible non-atomic attribute status after rollback
hasty Aug 22, 2024
6538809
Allow null BuiltIn field when saving Presets
hasty Aug 22, 2024
127a00b
Namespace workaround for compilers on other platforms
hasty Aug 22, 2024
179ceba
Merge branch 'master' of github.com:project-chip/connectedhomeip into…
hasty Aug 22, 2024
dfdaf3d
Merge branch 'granbery/preset_atomic' into granbery/preset_builtin
hasty Aug 22, 2024
3008c9a
Merge branch 'master' of github.com:project-chip/connectedhomeip into…
hasty Aug 24, 2024
6c2d5ef
Fix bad merge
hasty Aug 24, 2024
2f8c46f
Fix readability issue
hasty Aug 26, 2024
9672910
Merge branch 'master' into granbery/preset_builtin
hasty Aug 26, 2024
f299484
Force built-in to false on new presets
hasty Aug 26, 2024
faa63a4
Merge branch 'master' into granbery/preset_builtin
bzbarsky-apple Aug 27, 2024
ed8a2fa
Merge branch 'master' into granbery/preset_builtin
hasty Aug 27, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ class ThermostatDelegate : public Delegate

void InitializePendingPresets() override;

CHIP_ERROR AppendToPendingPresetList(const Structs::PresetStruct::Type & preset) override;
CHIP_ERROR AppendToPendingPresetList(const PresetStructWithOwnedMembers & preset) override;

CHIP_ERROR GetPendingPresetAtIndex(size_t index, PresetStructWithOwnedMembers & preset) override;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -177,17 +177,17 @@ void ThermostatDelegate::InitializePendingPresets()
}
}

CHIP_ERROR ThermostatDelegate::AppendToPendingPresetList(const PresetStruct::Type & preset)
CHIP_ERROR ThermostatDelegate::AppendToPendingPresetList(const PresetStructWithOwnedMembers & preset)
{
if (mNextFreeIndexInPendingPresetsList < ArraySize(mPendingPresets))
{
mPendingPresets[mNextFreeIndexInPendingPresetsList] = preset;
if (preset.presetHandle.IsNull())
if (preset.GetPresetHandle().IsNull())
{
// TODO: #34556 Since we support only one preset of each type, using the octet string containing the preset scenario
// suffices as the unique preset handle. Need to fix this to actually provide unique handles once multiple presets of
// each type are supported.
const uint8_t handle[] = { static_cast<uint8_t>(preset.presetScenario) };
const uint8_t handle[] = { static_cast<uint8_t>(preset.GetPresetScenario()) };
mPendingPresets[mNextFreeIndexInPendingPresetsList].SetPresetHandle(DataModel::MakeNullable(ByteSpan(handle)));
}
mNextFreeIndexInPendingPresetsList++;
Expand Down
2 changes: 1 addition & 1 deletion src/app/clusters/thermostat-server/thermostat-delegate.h
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,7 @@ class Delegate
* @return CHIP_NO_ERROR if the preset was appended to the list successfully.
* @return CHIP_ERROR if there was an error adding the preset to the list.
*/
virtual CHIP_ERROR AppendToPendingPresetList(const Structs::PresetStruct::Type & preset) = 0;
virtual CHIP_ERROR AppendToPendingPresetList(const PresetStructWithOwnedMembers & preset) = 0;

/**
* @brief Get the Preset at a given index in the pending presets list.
Expand Down
52 changes: 35 additions & 17 deletions src/app/clusters/thermostat-server/thermostat-server-presets.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -38,16 +38,16 @@ namespace {
* @return true If the preset is valid i.e the PresetHandle (if not null) fits within size constraints and the presetScenario enum
* value is valid. Otherwise, return false.
*/
bool IsValidPresetEntry(const PresetStruct::Type & preset)
bool IsValidPresetEntry(const PresetStructWithOwnedMembers & preset)
{
// Check that the preset handle is not too long.
if (!preset.presetHandle.IsNull() && preset.presetHandle.Value().size() > kPresetHandleSize)
if (!preset.GetPresetHandle().IsNull() && preset.GetPresetHandle().Value().size() > kPresetHandleSize)
{
return false;
}

// Ensure we have a valid PresetScenario.
return (preset.presetScenario != PresetScenarioEnum::kUnknownEnumValue);
return (preset.GetPresetScenario() != PresetScenarioEnum::kUnknownEnumValue);
}

/**
Expand Down Expand Up @@ -123,7 +123,7 @@ bool MatchingPendingPresetExists(Delegate * delegate, const PresetStructWithOwne
*
* @return true if a matching entry was found in the presets attribute list, false otherwise.
*/
bool GetMatchingPresetInPresets(Delegate * delegate, const PresetStruct::Type & presetToMatch,
bool GetMatchingPresetInPresets(Delegate * delegate, const DataModel::Nullable<ByteSpan> & presetHandle,
PresetStructWithOwnedMembers & matchingPreset)
{
VerifyOrReturnValue(delegate != nullptr, false);
Expand All @@ -143,7 +143,7 @@ bool GetMatchingPresetInPresets(Delegate * delegate, const PresetStruct::Type &
}

// Note: presets coming from our delegate always have a handle.
if (presetToMatch.presetHandle.Value().data_equal(matchingPreset.GetPresetHandle().Value()))
if (presetHandle.Value().data_equal(matchingPreset.GetPresetHandle().Value()))
{
return true;
}
Expand Down Expand Up @@ -351,53 +351,71 @@ Status ThermostatAttrAccess::SetActivePreset(EndpointId endpoint, DataModel::Nul
return Status::Success;
}

CHIP_ERROR ThermostatAttrAccess::AppendPendingPreset(Thermostat::Delegate * delegate, const PresetStruct::Type & preset)
CHIP_ERROR ThermostatAttrAccess::AppendPendingPreset(Thermostat::Delegate * delegate, const PresetStruct::Type & newPreset)
{
PresetStructWithOwnedMembers preset = newPreset;
if (!IsValidPresetEntry(preset))
{
return CHIP_IM_GLOBAL_STATUS(ConstraintError);
}

if (preset.presetHandle.IsNull())
if (preset.GetPresetHandle().IsNull())
{
if (IsBuiltIn(preset))
{
return CHIP_IM_GLOBAL_STATUS(ConstraintError);
}
// Force to be false, if passed as null
preset.SetBuiltIn(false);
}
bzbarsky-apple marked this conversation as resolved.
Show resolved Hide resolved
else
{
auto & presetHandle = preset.presetHandle.Value();

// Per spec we need to check that:
// (a) There is an existing non-pending preset with this handle.
PresetStructWithOwnedMembers matchingPreset;
if (!GetMatchingPresetInPresets(delegate, preset, matchingPreset))
if (!GetMatchingPresetInPresets(delegate, preset.GetPresetHandle().Value(), matchingPreset))
{
return CHIP_IM_GLOBAL_STATUS(NotFound);
}

// (b) There is no existing pending preset with this handle.
if (CountPresetsInPendingListWithPresetHandle(delegate, presetHandle) > 0)
if (CountPresetsInPendingListWithPresetHandle(delegate, preset.GetPresetHandle().Value()) > 0)
{
return CHIP_IM_GLOBAL_STATUS(ConstraintError);
}

const auto & presetBuiltIn = preset.GetBuiltIn();
const auto & matchingPresetBuiltIn = matchingPreset.GetBuiltIn();
// (c)/(d) The built-in fields do not have a mismatch.
// TODO: What's the story with nullability on the BuiltIn field?
if (!preset.builtIn.IsNull() && !matchingPreset.GetBuiltIn().IsNull() &&
preset.builtIn.Value() != matchingPreset.GetBuiltIn().Value())
if (presetBuiltIn.IsNull())
{
return CHIP_IM_GLOBAL_STATUS(ConstraintError);
if (matchingPresetBuiltIn.IsNull())
{
// This really shouldn't happen; internal presets should alway have built-in set
return CHIP_IM_GLOBAL_STATUS(InvalidInState);
}
preset.SetBuiltIn(matchingPresetBuiltIn.Value());
}
else
{
if (matchingPresetBuiltIn.IsNull())
{
// This really shouldn't happen; internal presets should alway have built-in set
return CHIP_IM_GLOBAL_STATUS(InvalidInState);
}
if (presetBuiltIn.Value() != matchingPresetBuiltIn.Value())
{
return CHIP_IM_GLOBAL_STATUS(ConstraintError);
}
}
}

if (!PresetScenarioExistsInPresetTypes(delegate, preset.presetScenario))
if (!PresetScenarioExistsInPresetTypes(delegate, preset.GetPresetScenario()))
{
return CHIP_IM_GLOBAL_STATUS(ConstraintError);
}

if (preset.name.HasValue() && !PresetTypeSupportsNames(delegate, preset.presetScenario))
if (preset.GetName().HasValue() && !PresetTypeSupportsNames(delegate, preset.GetPresetScenario()))
{
return CHIP_IM_GLOBAL_STATUS(ConstraintError);
}
Expand Down
12 changes: 10 additions & 2 deletions src/python_testing/TC_TSTAT_4_2.py
Original file line number Diff line number Diff line change
Expand Up @@ -246,8 +246,12 @@ async def test_TC_TSTAT_4_2(self):
if self.pics_guard(self.check_pics("TSTAT.S.F08") and self.check_pics("TSTAT.S.A0050") and self.check_pics("TSTAT.S.Cfe.Rsp")):
await self.send_atomic_request_begin_command()

# Set the new preset to a null built-in value; will be replaced with false on reading
test_presets = copy.deepcopy(new_presets)
test_presets[2].builtIn = NullValue

# Write to the presets attribute after calling AtomicRequest command
status = await self.write_presets(endpoint=endpoint, presets=new_presets)
status = await self.write_presets(endpoint=endpoint, presets=test_presets)
status_ok = (status == Status.Success)
asserts.assert_true(status_ok, "Presets write did not return Success as expected")

Expand All @@ -268,8 +272,12 @@ async def test_TC_TSTAT_4_2(self):
# Send the AtomicRequest begin command
await self.send_atomic_request_begin_command()

# Set the existing preset to a null built-in value; will be replaced with true on reading
test_presets = copy.deepcopy(new_presets)
bzbarsky-apple marked this conversation as resolved.
Show resolved Hide resolved
test_presets[0].builtIn = NullValue

# Write to the presets attribute after calling AtomicRequest command
await self.write_presets(endpoint=endpoint, presets=new_presets)
await self.write_presets(endpoint=endpoint, presets=test_presets)

# Send the AtomicRequest commit command
await self.send_atomic_request_commit_command()
Expand Down
Loading