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

Mvd 3rd fix rvc crash due to countdowntime #26

Merged

Conversation

erwinpan1
Copy link
Owner

Cherry-pick project-chip#35271 to support GetCountdownTime in OperationalState cluster and related PRs

tcarmelveilleux and others added 5 commits November 11, 2024 23:20
…34266)

* Introduce a building block usable for all Q attributes

- Q quality requires marking attributes as dirty for the purposes of reporting
  only when certain conditions arise.
- This PR introduces a building block attribute value wrapper compatible with
  any nullable or non-nullable numerical attribute, which allows applying
  the necessary policies, and all complex policies that currently exist in the
  Matter spec (e.g. any CountdownTime, CurrentLevel, etc).

Testing done:

- Added unit tests. Integration in existing clusters will follow in a different
  PR.

* Reword examples

* Restyled by clang-format

* Address review comments

* Restyled by clang-format

* Restyled by gn

* Address more review comments

* Restyled by clang-format

* Add clang-tidy exclusion due to clang-tidy bug

See llvm/llvm-project#97426

* Apply review comments

* Restyled by clang-format

* Fix Darwin clang-tidy crash by adding an override

---------

Co-authored-by: Restyled.io <commits@restyled.io>
…34353)

These are serious footguns because:

1.  They don't do checks that there is actually a value, and will silently
    produce garbage.
2.  They are really easy to accidentally use without a IsNull() check
    (especially operator->).

I've now reviewed several PRs where people were misusing these and helped a few
other people who were misusing them and then not getting expected behavior, so
it would be better if we just didn't have these at all.  Nullable is not a
pointer and people shouldn't treat it like one.
…roject-chip#34416)

* Fix post-review comments on Q quality utils from project-chip#34266

- PR project-chip#34266 had post review comments
  See: project-chip#34266 (review)
- Fix 0->0 case
- Introduce `Timestamp` more places where it makes sense
- Simplify some code lines

Fixes project-chip#34334

Testing done:

- Added unit test for 0->0
- Tests still pass

* Restyled by clang-format

* Address review comments

* Restyled by clang-format

---------

Co-authored-by: Restyled.io <commits@restyled.io>
* add state transition feature

* device running cycle dont deduct pause time

* Restyled by clang-format

* update countdown time

---------

Co-authored-by: Restyled.io <commits@restyled.io>
* Fix post-review comments on Q quality utils from project-chip#34266

- PR project-chip#34266 had post review comments
  See: project-chip#34266 (review)
- Fix 0->0 case
- Introduce `Timestamp` more places where it makes sense
- Simplify some code lines

Fixes project-chip#34334

Testing done:

- Added unit test for 0->0
- Tests still pass

* Restyled by clang-format

* Address review comments

* Restyled by clang-format

* Add Q quality to OperationalState CountdownTIme

- Update operational state cluster server to report countdown time at edges.
- Add a way for cluster delegate to request an update of time.

Issue project-chip#34421

Testing done:

- Existing tests still pass
- Will add cert test when the text is finalized (week of July 22)

* Restyled by clang-format

* Address review comments

* Address review comments

* Update src/app/clusters/operational-state-server/operational-state-server.cpp

* Fix several Opstate test cases

* Restyled by autopep8

* Fix minor grammar typo

* Restyled by autopep8

* Fix TC-OPSTATE-2.2

---------

Co-authored-by: Restyled.io <commits@restyled.io>
@GinyWang GinyWang merged commit 346a3df into v1.3-branch-mvd-master Nov 12, 2024
13 of 88 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

5 participants