-
Notifications
You must be signed in to change notification settings - Fork 16
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #283 from HewlettPackard/testing_doc_update
Adds TESTING.md
- Loading branch information
Showing
2 changed files
with
63 additions
and
0 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,61 @@ | ||
# Testing 'oneview-sdk' gem source code | ||
The 'oneview-sdk' source code provides a unit, integration/functional, and system testing strategies. It also provides linting tools to ensure its code style. | ||
This document will cover how to execute and implement them. | ||
|
||
## Executing tests | ||
The tests can be executed by `rake` tasks, `guard` watches, and by their original tools, like `rspec`, and `rubocop`. | ||
|
||
### Rake | ||
All the test strategies and checks can be executed by the rake command. | ||
Please use `rake -T` to see a full list of commands. | ||
|
||
### Guard | ||
Guard will watch the changes and execute unit tests and style checks. Just activate it to have real time test execution on every change. | ||
|
||
### Unit tests | ||
All unit tests are inside the spec folder. You can execute them manually by using RSpec and specifying the test files, like `rspec spec/unit/path/to/my/tests`. | ||
|
||
### Integration tests | ||
The integration tests are responsible for checking if the `oneview-sdk` is correctly integrated with the OneView appliance, at the same time it tests its functionalities. | ||
|
||
#### Categories | ||
Each integration test has its own pre-requisites and leaves the appliance in a different post state, and given OneView composable nature, each resource needs other resources configured so it can work. | ||
|
||
The most top-level resources would need the appliance entirely configured, and setting up and tearing it down for each test would cost a lot of time (likely days). So there is a chained dependency among the tests to greatly reduce its execution time. | ||
|
||
The integration tests are split into 3 categories `create`, `update`, and `delete` that can be run separately to allow some level of modularity between them. | ||
|
||
### System tests | ||
System tests are integration-like tests, but they aim to test the whole solution executing more complex interactions (use cases), not just focusing in testing one endpoint. | ||
|
||
### Coverage | ||
The tests issue a coverage report generated by SimpleCov. To see the full coverage report it is needed to run the entire suites for each individual test strategy. For instance, if a full integration coverage report is needed it is necessary to run the three testing categories. | ||
|
||
### Style checking | ||
Style checking is done by `rubocop` for all the checkable code. | ||
|
||
## Implementing tests | ||
All code must have associated tests, be it the already implemented or newly submitted, and this section covers what tests need to be implemented. | ||
|
||
### Unit tests | ||
The unit tests are required for each new resource, bug fix, or enhancement. | ||
|
||
### Integration tests | ||
The integration tests are required for each new resource, bug fix, or enhancement as far the new code modifies or adds an interaction with OneView. | ||
|
||
To avoid incompatibility between tests, the integration has a consolidated configuration file with all the resource names and a dependency matrix called `sequence_and_naming.rb`. | ||
|
||
It is far beyond from not advisable to instantiate a OneView resource in the integration tests that does not use the names in established there, if necessary, add the new names there. | ||
|
||
Add the new resource implemented to the dependency matrix, so the testing requisites will be met. | ||
|
||
Note: It is uncommon for an updated resource to change its dependency order, but it is fairly possible. | ||
|
||
### Shared tests | ||
Some resource methods behave exactly like other ones, so the source code provides a shared tests folder that can be used along multiple resource tests. | ||
|
||
### Unit and Integration acceptance criteria | ||
The necessary amount of testing is dictated by who is implementing and by who is reviewing and accepting the code, however, there is a floor coverage acceptance level defined in the `spec_helper.rb` file. | ||
|
||
### System tests | ||
System tests focus on use cases and they may be implemented to cover specific scenarios not covered by the other test strategies. Different from the unit and integration tests they do not have an acceptance criteria. |