-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs(e2e): contribution guidelines for e2e tests (#1896)
* style more like * add anotation about running on CI * expanding and grouping developer guidelines * add paths ignore for e2e docs * adding Use of External Sources for Validation * reorganization * delete innecessari duplications of principles for new PRs * move e2e contributing file * delete duplicates * +readme.md * relative paths on Update Documentation --------- Co-authored-by: Joseph Kim <joskim@redhat.com>
- Loading branch information
Showing
3 changed files
with
298 additions
and
32 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
# Contributing | ||
|
||
We are excited that you want to be a part of this project by contributing to the end-to-end tests. Here is some information on how to get started, as well as our requirements and guidelines to ensure a smooth contribution process. | ||
|
||
## Getting Started | ||
|
||
Before you begin, please ensure you have followed the general setup instructions in the main [Contributing Guide](../../CONTRIBUTING.md) to clone the repository and install dependencies. | ||
**The [Readme](README.md) file contains practical information about the e2e project** | ||
|
||
## Contribution Guidelines | ||
|
||
We welcome both code and non-code contributions to our project. Non-code contributions can come in the form of documentation updates, enhancement requests, and new test requests. | ||
|
||
### Developer Guidelines | ||
|
||
These principles are valid for new contributions. Some parts of the codebase may not adhere yet to these principles, but improvements should be made in that direction. | ||
|
||
#### Architectural Principles | ||
|
||
1. **Naming Convention** | ||
|
||
A naming convention is enforced for all entities, including variables, functions, and file names. Consistent naming ensures code clarity, maintainability, and ease of navigation throughout the project. | ||
|
||
2. **Code Visibility** | ||
|
||
Carefully consider the visibility of all classes, variables, and functions. Exposed elements should be simple and understandable on the frontend while being versatile and resilient in the background. This promotes a clean and user-friendly API while maintaining robust internal functionality. | ||
|
||
3. **Test Isolation** | ||
|
||
All tests should be written to be as isolated as possible. Even if current constraints (such as GitHub login rate limits) prevent complete independence, strive for maximum isolation. This approach ensures that when blockers are removed, refactoring can proceed smoothly. | ||
|
||
4. **Control Over Test Environment** | ||
|
||
The test framework must have full control over the test environment. All environment configurations should be managed and propagated up to the Node.js layer, when possible. This ensures that the test environtment can be set up in case-to-case bases. | ||
|
||
5. **Team Agreement on Architecture Principles** | ||
|
||
All architecture principles and guidelines must be agreed upon by the team. Every team member's voice is important, and open communication ensures alignment and shared understanding of the project's direction. | ||
|
||
#### Technical Guidelines | ||
|
||
1. **Page Object Model (POM)** | ||
|
||
The Page Object Model (POM) design pattern is required for all test code. Until we find a better-suited standard, we adhere to this well-known and well-tested pattern to promote code reusability and maintainability. | ||
|
||
2. **Playwright Best Practices** | ||
|
||
We follow Playwright best practices, including the use of fixtures. Adhering to these practices ensures that our tests are reliable, efficient, and maintainable. Please refer to the [Playwright Best Practices](https://playwright.dev/docs/best-practices) and [Fixtures](https://playwright.dev/docs/test-fixtures) documentation for guidance. | ||
|
||
3. **Avoid Using `uiHelper` in Spec Files** | ||
|
||
- The `uiHelper` utility should not be used directly in spec files. The reason for that is that some methods in this class are too generic and sometimes it is difficult to point what they are intended. Idellay, they shall be called from inside a POM that states what thay are looking for. | ||
- Use `uiHelper` methods only within the Page Object Model (POM) classes. | ||
- When working with tests that directly use `uiHelper` in spec files, refactor them to move `uiHelper` usage into POM classes. | ||
- This ensures that all UI interactions are encapsulated within page objects, promoting cleaner and more maintainable test code. | ||
|
||
4. **Use External Sources for Validation** | ||
|
||
- **Avoid Hardcoded Data in Tests** | ||
|
||
- When validating frontend results in your end-to-end tests, use external sources of truth such as APIs or databases instead of hardcoded information. | ||
- This approach ensures that tests are more robust and accurately reflect the dynamic nature of the application data. | ||
|
||
### Adding New Tests | ||
|
||
When contributing new tests or modifying existing ones, please adhere to the guidelines. | ||
To open a PR, follow the steps described in the [general contribution guide](../../CONTRIBUTING.md) | ||
|
||
### Collaboration and Communication | ||
|
||
- **Team Consensus:** | ||
|
||
- Engage with the team when introducing significant changes. Ensure that architectural decisions are agreed upon collectively. | ||
|
||
- **Open Communication:** | ||
|
||
- Encourage discussion and feedback. All voices are important in shaping the project's direction. |
Oops, something went wrong.