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

How to write good tests for parallel environments #2182

Merged
merged 5 commits into from
Jan 3, 2025

Conversation

williamlardier
Copy link
Contributor

What does this PR do, and why do we need it?

With 10 rules, ensure the new tests in CTST are following a set of rule to ensure their quality.

Which issue does this PR fix?

Fixes ZENKO-4944.

Special notes for your reviewers:

Please feel free to suggest changes or new rules, or start a discussion if you disagree with a rule.

@bert-e
Copy link
Contributor

bert-e commented Dec 12, 2024

Hello williamlardier,

My role is to assist you with the merge of this
pull request. Please type @bert-e help to get information
on this process, or consult the user documentation.

Available options
name description privileged authored
/after_pull_request Wait for the given pull request id to be merged before continuing with the current one.
/bypass_author_approval Bypass the pull request author's approval
/bypass_build_status Bypass the build and test status
/bypass_commit_size Bypass the check on the size of the changeset TBA
/bypass_incompatible_branch Bypass the check on the source branch prefix
/bypass_jira_check Bypass the Jira issue check
/bypass_peer_approval Bypass the pull request peers' approval
/bypass_leader_approval Bypass the pull request leaders' approval
/approve Instruct Bert-E that the author has approved the pull request. ✍️
/create_pull_requests Allow the creation of integration pull requests.
/create_integration_branches Allow the creation of integration branches.
/no_octopus Prevent Wall-E from doing any octopus merge and use multiple consecutive merge instead
/unanimity Change review acceptance criteria from one reviewer at least to all reviewers
/wait Instruct Bert-E not to run until further notice.
Available commands
name description privileged
/help Print Bert-E's manual in the pull request.
/status Print Bert-E's current status in the pull request TBA
/clear Remove all comments from Bert-E from the history TBA
/retry Re-start a fresh build TBA
/build Re-start a fresh build TBA
/force_reset Delete integration branches & pull requests, and restart merge process from the beginning.
/reset Try to remove integration branches unless there are commits on them which do not appear on the source branch.

Status report is not available.

@bert-e
Copy link
Contributor

bert-e commented Dec 12, 2024

Incorrect fix version

The Fix Version/s in issue ZENKO-4944 contains:

  • None

Considering where you are trying to merge, I ignored possible hotfix versions and I expected to find:

  • 2.10.12

Please check the Fix Version/s of ZENKO-4944, or the target
branch of this pull request.

@bert-e
Copy link
Contributor

bert-e commented Dec 12, 2024

Incorrect fix version

The Fix Version/s in issue ZENKO-4944 contains:

  • 2.10.11

Considering where you are trying to merge, I ignored possible hotfix versions and I expected to find:

  • 2.10.12

Please check the Fix Version/s of ZENKO-4944, or the target
branch of this pull request.

Copy link
Contributor

Choose a reason for hiding this comment

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

should this instead go in a more "natural" location, e.g. docs/writing-ctst-tests.md ?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

The current docs folder is used with tox, it's a real doc we used to render as html pages, putting it here is logical but it doesn't look good...


**Rule #1**

> Tests must be idempotent.
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
> Tests must be idempotent.
> Tests should be idempotent.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Why "should" and not "must"? it is not supposed to be a suggestion.

- Location creation;
- Bucket Website endpoints.

... must be created before the test start, or in a dedicated set of test.
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
... must be created before the test start, or in a dedicated set of test.
... should be created before the test start, or in a dedicated set of test.

Copy link
Contributor

@rachedbenmustapha rachedbenmustapha left a comment

Choose a reason for hiding this comment

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

General formatting/presentation remarks:

  • It would be more straightforward for readers to just name the rules as titles prefixed by their number. I find the bold rule number followed by the rule itself as a quote a bit distracting.
  • The word please is not needed in this sort of document (or any documentation or UI really) and sets a tone of asking for a favor vs giving directions that everyone needs to follow. A former tech writer on the team made sure that we removed all pleases from docs (even internal/technical) and UIs for consistency.

tests/ctst/HOW_TO_WRITE_TESTS.md Outdated Show resolved Hide resolved
tests/ctst/HOW_TO_WRITE_TESTS.md Outdated Show resolved Hide resolved
tests/ctst/HOW_TO_WRITE_TESTS.md Show resolved Hide resolved
> Teardown resources.

If a test creates resources, ensure they are deleted at the end of the test.
Do not delete the resources in case of error, to ease debugging.
Copy link
Contributor

Choose a reason for hiding this comment

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

I both agree and disagree: tearing down resources should always be done and be reliable, and also we need to be able to debug. A middle ground would be to skip teardown on failure only if in debug mode (the one with tmate active), otherwise always do it.

This would make rule #9 redundant as tests relying on other tests to have run would just not work.

Copy link
Contributor Author

@williamlardier williamlardier Dec 17, 2024

Choose a reason for hiding this comment

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

Thank you for all the feedback. I updated the page accordingly - I agree with everything but this. I updated as you suggested though.

I think we should not cleanup resources in case of error even if we're not running debug. The reason is that as each test uses a partitioned set of resources (bucket/objects, possibly account), not cleaning in case of error (or flaky) helps us finding the root cause much more easily, by having access to the metadata in the mongodb dumps, as well as the logs of all operations done by CTST for the failing test (identifiable with a single id). The overhead is minimal and it should not affect other tests in any way, even if the bucket is still here.

In parallel, the tests can run in any order. It's not because a test works at a
given time, that it will work if the test order changes after adding new ones
or renaming files. You must ensure the scenarios are fully idempotent.
"Flakies" are mostly due to non-idempotent tests, then bugs. It is rarely due
Copy link
Contributor

Choose a reason for hiding this comment

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

it is rarely due to the platform

Even though it's actually true, I'm not sure we want to write that in the documentation, as the test are made to verify that the platform works..

Copy link
Contributor Author

Choose a reason for hiding this comment

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

By platform I mean the CI environment, I will make it clearer that we cannot always think it's due to limited resources in the CI, or some sort of slowness we cannot explain

@williamlardier
Copy link
Contributor Author

/approve

@scality scality deleted a comment from bert-e Jan 3, 2025
@bert-e
Copy link
Contributor

bert-e commented Jan 3, 2025

I have successfully merged the changeset of this pull request
into targetted development branches:

  • ✔️ development/2.10

The following branches have NOT changed:

  • development/2.5
  • development/2.6
  • development/2.7
  • development/2.8
  • development/2.9

Please check the status of the associated issue ZENKO-4944.

Goodbye williamlardier.

The following options are set: approve

@bert-e bert-e merged commit 73eb56d into development/2.10 Jan 3, 2025
14 checks passed
@bert-e bert-e deleted the improvement/ZENKO-4944 branch January 3, 2025 15:29
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants