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

Declarative PIXITs in python tests #395 #36817

Draft
wants to merge 9 commits into
base: master
Choose a base branch
from

Conversation

asirko-soft
Copy link

project-chip/matter-test-scripts#395

Added a common mechanism for tests to declare their optional and required PIXIT values and override flags and ensure the required values are supplied. Add information about optional override flags with descriptions in the error outputs of tests.

Example:

def pixits_TC_ICDM_3_4(self) -> list[PIXITDefinition]:
        """Declare PIXITs required for this test"""
        return [
            PIXITDefinition(
                name="PIXIT.WAITTIME.REBOOT",
                pixit_type=PIXITType.INT,
                description="Time to wait for device reboot (in seconds)",
                required=True
            )
        ]

Copy link

semanticdiff-com bot commented Dec 12, 2024

Review changes with  SemanticDiff

Changed Files
File Status
  src/python_testing/TestMatterTestingSupport.py  3% smaller
  src/python_testing/matter_testing_infrastructure/chip/testing/matter_testing.py  2% smaller

@github-actions github-actions bot added tests matter-1.4-te2-script-change Script changes before end of Matter 1.4 TE2 labels Dec 12, 2024
def validate_bool(value: Any) -> bool:
if isinstance(value, str):
value_lower = value.lower()
if value_lower not in ('true', 'false', '1', '0', 'yes', 'no'):
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

only true false supported

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed


@staticmethod
def validate_float(value: Any) -> bool:
float(value)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • value is str for all validators
  • validate_xxx --> is_xxx_pixit_value_valid

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed


@staticmethod
def validate_string(value: Any) -> bool:
str(value)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For all these you need to wrap the possibly-failing conversion in a try: except ValueError before true/false returned.

Also, when returning False, you are losing the reason for why it failed validation, which would have come out fo the exception.

Recommend moving all of these validators to raise exceptions rather than be bool return. In that case, it could remain validate_xxx

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed and converted bool returns to exceptions

return True

@classmethod
def validate_value(cls, value: Any, pixit_def: PIXITDefinition) -> tuple[bool, Optional[str]]:
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Avoid raw tuple returns. Raise an exception with message on failure

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for this, I was afraid that with using tuple there readability degrades a bit. Removed tuple return

if missing or invalid:
error = ""
if missing:
error += "\nMissing required PIXITs:\n" + "\n".join(missing)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please avoid multi-line emssages

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed

default: Any = None

@staticmethod
def is_pixit(arg_name: str) -> bool:
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

actually, we probably want to validate all the flags. There are some flags that should be exposed that aren't called PIXIT.whatever

Copy link
Author

@asirko-soft asirko-soft Dec 16, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you suggest to rename all methods to use some more generic words?


# Validate PIXITs before proceeding
validator = PIXITValidator()
valid, error = validator.validate_pixits(test_info[0].pixits, matter_test_config.global_test_params)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does this validate only for the first test in the list?

might be better in the setup_test function for each test.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah, thank you for noticing this issue, I've moved validation to setup_test

@@ -612,6 +612,142 @@ def test_skipped(self, filename: str, name: str):
logging.info(f"Skipping test from {filename}: {name}")


class PIXITType(Enum):
INT = "int"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This approach in general is OK, but I do want to consider this in the larger context of verifying that the test invocations are correct in a broader way. We can land this in stages, but it is important to consider how the other checks are going to be integrated here.

In particular, test authors need an easy way to declare certain other test requirements that also need verification. Ex. Endpoint project-chip/matter-test-scripts#450, which we should consider mandating with no default for tests that are run against a single endpoint, no --endpoint flag for tests that run against the entire node at once. Need a way to declare that a test requires a commissioned device, whether or not that commissioning happens as a part of the test invocation. Some tests require passcodes, discriminators etc, even for tests where the commissioning happens external to the test. Tests that DO use PICS (hopefully fewer and fewer) should have a PICS file specified (and this get extra difficult in the context of the test harness)

Anyway, worth thinking through how these extended checks would fit in with this design. I don't see anything in particular blocking these options right now.

It's also worth thinking through how to expose this properly to test authors. ie, is there a way that we can alert test authors that are using test flags that they should be providing these functions?

@@ -612,6 +612,142 @@ def test_skipped(self, filename: str, name: str):
logging.info(f"Skipping test from {filename}: {name}")


class PIXITType(Enum):
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I know I used PIXIT in the issue, but I think this applies generally to test flags. But I can't think of a great name for just "Flags" that doesn't sound too generic. Ideas welcome.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To be honest, I also don't have many ideas. TestFlag? TestFlagType? TestParamType?

Copy link
Contributor

@cecille cecille left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would you mind adding some tests here that the verifiers are correctly catching errors? We have some examples of how to test these frameworking bits in TestMatterTestingSupport.py et. al.

Copy link

PR #36817: Size comparison from 75ab4c9 to d3976d0

Full report (1 build for stm32)
platform target config section 75ab4c9 d3976d0 change % change
stm32 light STM32WB5MM-DK FLASH 484720 484728 8 0.0
RAM 144880 144880 0 0.0

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
matter-1.4-te2-script-change Script changes before end of Matter 1.4 TE2 tests
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants