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

Implement the codegen-data-model Write support #34139

Merged
merged 98 commits into from
Jul 5, 2024
Merged
Changes from 1 commit
Commits
Show all changes
98 commits
Select commit Hold shift + click to select a range
ba43ab7
Initial copy/merge of the codegendatamodel::write support
andy31415 Jun 28, 2024
c13f3ce
Restyle
andy31415 Jun 28, 2024
79f9603
Remove the error translation for ACL checks for attribute writes
andy31415 Jun 28, 2024
3648820
Comment correction after special access error code guarantees were re…
andy31415 Jun 28, 2024
f2911ef
Set the namespace for DataModel to resolve nameclash for android builds
andy31415 Jun 28, 2024
fedfc79
Restyle
andy31415 Jun 28, 2024
2a632f3
Some changes to make darwin builds happy
andy31415 Jun 28, 2024
e22cbf9
Merge branch 'master' into imdm/4-ember-write-attribute
andreilitvin Jul 2, 2024
97490f9
Do not clang-tidy on CodegenDataModel_Write
andreilitvin Jul 2, 2024
a0bdfd2
Update src/app/codegen-data-model/CodegenDataModel_Write.cpp
andy31415 Jul 3, 2024
7f30755
Update src/app/codegen-data-model/CodegenDataModel_Write.cpp
andy31415 Jul 3, 2024
8a158ef
Update src/app/codegen-data-model/CodegenDataModel_Write.cpp
andy31415 Jul 3, 2024
6566f31
Merge branch 'master' into imdm/4-ember-write-attribute
andy31415 Jul 3, 2024
55e45d4
Use little endian encoding for pascal long strings, since this is wha…
andy31415 Jul 3, 2024
1b54c1a
Restyle
andy31415 Jul 3, 2024
53458e4
Merge branch 'imdm/4-ember-write-attribute' of github.com:andy31415/c…
andy31415 Jul 3, 2024
2518cba
Fix code to compile and pass tests
andy31415 Jul 3, 2024
4fd538a
Code review comments
andy31415 Jul 3, 2024
77bc4fe
Comment update
andy31415 Jul 3, 2024
929b5f6
Update based on code review feedback
andy31415 Jul 3, 2024
1c15644
Wrong condition. Fixed
andy31415 Jul 3, 2024
b61b3aa
Return invalid value to match ember-compatibility-functions
andy31415 Jul 3, 2024
0992f6d
switch invalid data point to constraint error for return codes
andy31415 Jul 3, 2024
5b7d536
Fix code review comments: comments and return unsupportedaccess
andy31415 Jul 3, 2024
65baf80
Remove useless comment - error check should be clear enough
andy31415 Jul 3, 2024
76b7e7d
Comment update
andy31415 Jul 3, 2024
1f79a52
Re-arrange code for read only and timed
andy31415 Jul 3, 2024
a629992
Re-format the read only checks a bit
andy31415 Jul 3, 2024
3741c61
Use CHIP_ERROR_NOT_FOUND
andy31415 Jul 3, 2024
e252bb0
Separate out variable names
andy31415 Jul 3, 2024
2b0bc7a
Slight updated code layout
andy31415 Jul 3, 2024
3296766
Updated return value for chip error
andy31415 Jul 3, 2024
16cc088
Updated test to verifyordie instead of just logging errors
andy31415 Jul 3, 2024
682b73a
Update src/app/codegen-data-model/tests/TestCodegenModelViaMocks.cpp
andy31415 Jul 3, 2024
37f4298
Update based on review feedback
andy31415 Jul 3, 2024
d50ac27
Merge branch 'imdm/4-ember-write-attribute' of github.com:andy31415/c…
andy31415 Jul 3, 2024
03bb45f
Fix endianess and copying in test code
andy31415 Jul 3, 2024
8b630b0
Restyle
andy31415 Jul 3, 2024
412d681
Updated comment
andy31415 Jul 3, 2024
413b5e7
Update src/app/codegen-data-model/tests/TestCodegenModelViaMocks.cpp
andy31415 Jul 3, 2024
8b1a1b1
Add unit test for "lowest signed value write"
andy31415 Jul 3, 2024
516a1c9
Restyle
andy31415 Jul 3, 2024
2aed85d
A constraint error update and better tests for AAI returning errors
andy31415 Jul 3, 2024
1a48fc9
One more test for invalid ember usage
andy31415 Jul 3, 2024
6fc8d17
Restyle
andy31415 Jul 3, 2024
e93665b
more tests for more coverage
andy31415 Jul 3, 2024
0e4398b
Comment update
andy31415 Jul 3, 2024
41403a4
Fix comment
andy31415 Jul 3, 2024
39da04f
One more test for more coverage
andy31415 Jul 3, 2024
c5feac7
Also cover writing non-null value to nullable attribute
andy31415 Jul 3, 2024
6b05337
Fix the ember string usage
andy31415 Jul 3, 2024
46a5ad2
Update src/app/codegen-data-model/CodegenDataModel_Read.cpp
andy31415 Jul 3, 2024
8631b41
Update src/app/codegen-data-model/CodegenDataModel_Read.cpp
andy31415 Jul 3, 2024
5a4bd3c
Remove duplicate code
andy31415 Jul 3, 2024
6e0d9d1
Update src/app/codegen-data-model/CodegenDataModel_Write.cpp
andy31415 Jul 3, 2024
4bdc2ee
Remove chip::app:: prefix in unit test since we have a top level using
andy31415 Jul 3, 2024
e6e5b19
Merge branch 'imdm/4-ember-write-attribute' of github.com:andy31415/c…
andy31415 Jul 3, 2024
f6e1bb9
Fix copy & paste encode to decode
andy31415 Jul 3, 2024
4bd7e28
Replace decoded with converted
andy31415 Jul 3, 2024
8e2383c
Update src/app/codegen-data-model/CodegenDataModel_Write.cpp
andy31415 Jul 3, 2024
e921ead
Merge branch 'imdm/4-ember-write-attribute' of github.com:andy31415/c…
andy31415 Jul 3, 2024
575b492
Start using Failure for invalid data type instead of unsupported read…
andy31415 Jul 3, 2024
7b5bb9f
Fix comments
andy31415 Jul 3, 2024
da1aae4
Updated encode/decode comment
andy31415 Jul 3, 2024
dc1c658
Use failure instead of constraint error
andy31415 Jul 3, 2024
4dab89b
Update src/app/codegen-data-model/CodegenDataModel_Write.cpp
andy31415 Jul 3, 2024
e39cb80
Update src/app/codegen-data-model/CodegenDataModel_Write.cpp
andy31415 Jul 3, 2024
f58fee8
Update src/app/codegen-data-model/CodegenDataModel_Write.cpp
andy31415 Jul 3, 2024
380ac9f
Merge branch 'imdm/4-ember-write-attribute' of github.com:andy31415/c…
andy31415 Jul 3, 2024
8e87177
Use dataversion mismatch for write without a version
andy31415 Jul 3, 2024
572a7f3
Add extra IsGlobalAttribute check
andy31415 Jul 3, 2024
84fb496
use external writes for the ember write logic, so that we have extra …
andy31415 Jul 3, 2024
db487b4
Updated comments
andy31415 Jul 3, 2024
2d216ab
more comments
andy31415 Jul 3, 2024
865b80a
Restyle
andy31415 Jul 3, 2024
e542231
Use emberAfWriteAttribute
andy31415 Jul 4, 2024
5664e7b
Add comment about ember-string
andy31415 Jul 4, 2024
1df88a2
Restyle
andy31415 Jul 4, 2024
1475193
Add context to unit tests, make write do the marking of dirty paths
andy31415 Jul 4, 2024
b26edf1
Add some unit tests for dirty path handling
andy31415 Jul 4, 2024
faac4fb
Move the change callback around a bit
andy31415 Jul 4, 2024
56fe685
Restyle
andy31415 Jul 4, 2024
94392d6
Fixed unit tests to support size checks
andy31415 Jul 4, 2024
2ab7dd7
Add unit test for invalid data
andy31415 Jul 4, 2024
ecd4fd4
Restyle
andy31415 Jul 4, 2024
73ff5ae
Fix linter errors
andy31415 Jul 4, 2024
c36c64e
Update to make size enforcement and guarantees clearer
andy31415 Jul 4, 2024
9f1b7de
use size_t for getlength sizes
andy31415 Jul 4, 2024
0eb94b5
Review comments and updated code to compile for android
andy31415 Jul 4, 2024
e5fffd6
make datamodel unambiguous
andy31415 Jul 5, 2024
a379908
More fixes for clang compilation for DataModel scoping
andy31415 Jul 5, 2024
b78f27a
Restyle
andy31415 Jul 5, 2024
e10fefc
Try to make darwin compiler happy ... ssize_t vs size_t
andy31415 Jul 5, 2024
40ae352
Fix typo
andy31415 Jul 5, 2024
a6e2ddb
Restyle
andy31415 Jul 5, 2024
9bbe92a
Merge branch 'master' into imdm/4-ember-write-attribute
andy31415 Jul 5, 2024
1c04a69
Code review updates
andy31415 Jul 5, 2024
08c4fbd
Undo submodule update
andy31415 Jul 5, 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
Prev Previous commit
Next Next commit
One more test for more coverage
andy31415 committed Jul 3, 2024
commit 39da04fc3e836fbef61ea4c2f68776e8fb32f0bd
21 changes: 20 additions & 1 deletion src/app/codegen-data-model/tests/TestCodegenModelViaMocks.cpp
andy31415 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -1958,7 +1958,7 @@ TEST(TestCodegenModelViaMocks, EmberTestWriteReservedNullPlaceholderToNullable)
ASSERT_EQ(model.WriteAttribute(test.request, decoder), CHIP_IM_GLOBAL_STATUS(ConstraintError));
}

TEST(TestCodegenModelViaMocks, EmberTestWriteOutOfRepresentableRangeOddInteger)
TEST(TestCodegenModelViaMocks, EmberTestWriteOutOfRepresentableRangeOddIntegerNonNullable)
{
UseMockNodeConfig config(gTestNodeConfig);
chip::app::CodegenDataModel model;
@@ -1977,6 +1977,25 @@ TEST(TestCodegenModelViaMocks, EmberTestWriteOutOfRepresentableRangeOddInteger)
ASSERT_EQ(model.WriteAttribute(test.request, decoder), CHIP_ERROR_INVALID_ARGUMENT);
}

TEST(TestCodegenModelViaMocks, EmberTestWriteOutOfRepresentableRangeOddIntegerNullable)
{
UseMockNodeConfig config(gTestNodeConfig);
chip::app::CodegenDataModel model;
ScopedMockAccessControl accessControl;

TestWriteRequest test(kAdminSubjectDescriptor,
ConcreteAttributePath(kMockEndpoint3, MockClusterId(4),
MOCK_ATTRIBUTE_ID_FOR_NULLABLE_TYPE(ZCL_INT24U_ATTRIBUTE_TYPE)));

using NumericType = NumericAttributeTraits<uint32_t>;
using NullableType = chip::app::DataModel::Nullable<typename NumericType::WorkingType>;
AttributeValueDecoder decoder = test.DecoderFor<NullableType>(0x1223344);

// write should fail: written value is not in range
// NOTE: this matches legacy behaviour, however realistically maybe ConstraintError would be more correct
ASSERT_EQ(model.WriteAttribute(test.request, decoder), CHIP_ERROR_INVALID_ARGUMENT);
}

TEST(TestCodegenModelViaMoceNullValueToNullables, EmberAttributeWriteBasicTypesLowestValue)
{
TestEmberScalarTypeWrite<int8_t, ZCL_INT8S_ATTRIBUTE_TYPE>(-127);