CPS Testing
CPS Team Testing Strategy
CPS Test Overview
CPS testing strategy follows best in class quality principles and practices; based on the Testing Pyramid as recommended by Martin Fowler.
credit: https://martinfowler.com/articles/practical-test-pyramid.html
This Diagram shows an overview of the different types of test and their scope related to the architecture layers | Color Coding |
Source Code | |
Unit Test | |
| |
Integration Test |
Over time we have developed an extensive set of tests:
1 | |
2 | Service Test (or Semi-Integration Test) using Spring Boot Test Containers for Postgres and Kafka and Mocked/Stubbed Services for external components like DMI and Policy Executor. These test are written in Groovy & Spock
|
3 | (UI) Integration test (since we don't have a UI these start at the REST layer of our components)
|
4 | Contract Testing (not visible in diagram) |
Integration Test
CSIT Integration Test
Project-specific CSIT structure (non-CPS page)
K6 Test Overview
Grafana k6 is an open-source and extensible load tool. Grafana k6 helps the CPS engineering team prevent breaches of SLI (Service Level Indicators) and SLO (Service Level Objectives).
The k6 tests have been applied for NCMP (Network Config Management Proxy) APIs in the CPS Project.
There are two test profiles for NCMP: kpi and endurance
kpi Profile
The kpi profile is used for load (performance) testing.
It defines various scenarios to test different APIs offered in NCMP, including passthrough read/write operations, cm handle id searches, and legacy batch operations.
Each scenario specifies the executor type, execution function, rate, duration, and other parameters.
Please have a look at the details of NCMP Stone Tablet KPIs from the link: The Stone Tablet KPIs of NCMP
endurance Profile
The endurance profile is used for stability testing over extended periods for the APIs offered in NCMP.
For more details like characteristics and solution design, please have a look at the link: The Characteristics of endurance tests of NCMP
Service / Semi-Integration Test
Persistence Testing
Liquibase Change Log (sets) Testing (test DB Upgrade)
Contract Testing
CPS has developed stubs for clients.
Link to Gerrit patch: https://gerrit.onap.org/r/c/cps/+/129256
Jira Link: CPS-919: PoC Contract Stubs NCMP Rest EndpointsClosed
Performance Testing
Automated Performance Test
Our K6 test now includes automated performance testing for some (NCMP) Test Cases (KPIs). See K6 Test Overview
Performance Test Stubs
NCMP Performance Test With Wiremock (not in use anymore)
TBC DMI Stub
TBC Policy Executor Stub
Performance Test Results
This table tracks once-off performance test exercises/results, preferably on a child page here.
Date | Jira | Report | Notes |
---|---|---|---|
TBD | CPS-2371: Create performance tests and review for subscriptionClosed | CM Data Notification Subscription Create Performance |
|
TBD | CPS-2329: Performance for CM Data Notification Event SchemaClosed | CM Data Notification Forwarding Performance |
|
Jul 2024 |
| NCMP: Read data operation resource API Performance for multiple cm-handles |
|
Mar 2024 |
|
| |
Feb 2024 |
| ||
Sep 2023 |
| ||
Aug 2023 |
|
| |
Apr 2023 |
| Used Data Schema and Samples provides by Wipro | |
Feb 2023 |
| looks like some attachments got lost in the ONAP Wiki Cleanup | |
Jan 2023 |
| ||
Jan 2023 |
|
| |
Sep 2022 |
|
| |
Nov 2021 |
|
Testing Frameworks
Groovy & Spock
OneSummit Groovy & Spock Workshop Nov 2022 (includes sample project & exercises!)
Additional resources:
Other Test / Verification Tools
Read the Docs (RTD)
Prerequisites
Linux Environment (WSL works too)
Python
Tox (see https://tox.wiki/en/3.14.1/install.html)
Steps
(temporary) Modify docs/tox.ini (for example https://gerrit.onap.org/r/c/cps/+/135892/2/docs/tox.ini ) do NOT merge these changes into master!
to use YOUR Python version
If you have a lot of new documentation you can (temporarily) remove the
-W
flag from the first twosphinx-build
commands (sections; tox and docs-linkcheck) so it doesn't stop on the first error
(note there are always a lot of spelling 'warnings' so the third build command should always be run without the -W flag (section; docs-spellcheck)
cd into
<your project location>docs
run
tox
tip: First-time run can take a few minutes! use -V or -VV for more verbose output to see what it is doing
Alternate checks
Windows Subsystem (WSL):
doc8 *.rst --ignore D002 --ignore D004
(need to ignore warnings about CR, trailing whitespace and line length because of different filesystems)Note. If there are unexpected issues with Linelength ie. errors locally that are not causing problems in CI then these can be ignored using
--ignore D001
@Thomas Kulik suspects this might have to do with the doc8 tool version and he will report back to us on this issue
Reference Material
CSIT References