BSP Test Process: Difference between revisions
(Created page with "= Summary = Given the resulttool command line tool was ready to replace Testopia and Wiki Page role in QA Testing. New BSP test process was needed to integrate BSP testing wi...") |
No edit summary |
||
(28 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
= Summary = | = Summary = | ||
Given the resulttool command line tool was ready to replace Testopia and Wiki Page | Given the resulttool command line tool was ready to replace Testopia and Wiki Page in QA Testing for execution and test result management. New BSP test process was needed to integrate BSP testing with resulttool. | ||
The resulttool is currently only available for 2.7, and it will be ported to 2.6 (thud) and 2.5 (sumo). | |||
New BSP test | = BSP Test Process = | ||
New BSP test process consists of: | |||
- Test Triggering | - Test Triggering | ||
Line 14: | Line 16: | ||
- Decision | - Decision | ||
= Roles = | |||
- Test Executor - Intel and WindRiver test team | |||
- Overall QA Owner - Intel (2.7) | |||
- QA Stakeholder - Team that owned final release decision | |||
== Test Triggering == | |||
=== ROLE: Test Executor === | |||
Intel and WindRiver test team request subscribe to QA notification by contacting Linux Foundation (Michael Halstead mhalstead@linuxfoundation.org), once QA notification received then each test team will start preparing for BPS testing. | |||
== Test Setup== | |||
=== ROLE: Test Executor === | |||
Intel and WindRiver test team will setup test hardware and environment for BSP testing. | |||
== Test Execution == | |||
=== ROLE: Test Executor === | |||
Intel and WindRiver test team will execute BSP runtime testing on related hardware accordingly. | |||
For runtime tests available from oeqa/runtime, once executed this runtime tests, collect the "testresults.json" file contain the configuration and status from the <build-dir>/tmp/log/oeqa/ directory. | |||
For runtime tests inside oeqa/manual, use "resulttool manualexecution" to execute these tests (refer to https://wiki.yoctoproject.org/wiki/Resulttool#manualexecution for more detail), collect the "testresults.json" file from the <build-dir>/tmp/log/manual/ directory. | |||
== | === Defect management === | ||
Once a test case failed during execution, create a bug ticket at Bugzilla. | |||
To map the bug ticket to the failed test case executed, provide below information inside bug ticket. | |||
Information needed to trace bug to testcase inside yocto-testresults: | |||
1. git tag - tag used to store the failed test case (eg. "{branch}/{commit_number}-g{commit}/{tag_number}") | |||
2. result id - unique id inside testresults.json file that used to identify a test result set consist of a list of test cases executed | |||
(eg. manual_bsps-hw_20190311160844) | |||
3. test case id - unique id inside testresults.json file used to identify a specific test case executed | |||
(eg. bsp-hw.bsps-oe-core.Test_Run_Integrity_-_Check_that_image_is_buildable) | |||
== Test Result Store == | |||
== Test | === ROLE: Test Executor === | ||
Intel and WindRiver team will request write access to https://git.yoctoproject.org/git/yocto-testresults remote repository by contacting Linux Foundation (Michael Halstead mhalstead@linuxfoundation.org). | |||
Intel and WindRiver test team will store the testresults.json files collected in previous section to the yocto-testresults git repository (http://git.yoctoproject.org/cgit/cgit.cgi/yocto-testresults/). | |||
== Test Reporting and Regression== | 1. Git clone https://git.yoctoproject.org/git/yocto-testresults to local machine. | ||
2. Use "resulttool store" to store testresults.json files to local yocto-testresults git repository (refer to https://wiki.yoctoproject.org/wiki/Resulttool#store for more detail). | |||
3. Once verified the results are saved properly to local git repository, push the commit & tag to remote repository. | |||
Make sure the git tag created (branch and commit) was correct and the correct testresults.json file was stored inside the local yocto-testresults git repository before push to remote. | |||
Intel and WindRiver team will notifiy the Overall QA Owner on completion of BSP testing. | |||
== Test Reporting and Regression== | |||
=== ROLE: Overall QA Owner === | |||
Overall QA Owner team will re-run “resulttool report” & “resulttool regression-git” to create report and regression for both automated and BSP test result (refer to https://wiki.yoctoproject.org/wiki/Resulttool#report and https://wiki.yoctoproject.org/wiki/Resulttool#regression-git for more detail). | |||
== Decision == | == Decision == | ||
=== ROLE: QA Stakeholder === | |||
QA Stakeholder will review test report and regression information created in previous section to make the release decision. |
Latest revision as of 05:55, 12 March 2019
Summary
Given the resulttool command line tool was ready to replace Testopia and Wiki Page in QA Testing for execution and test result management. New BSP test process was needed to integrate BSP testing with resulttool.
The resulttool is currently only available for 2.7, and it will be ported to 2.6 (thud) and 2.5 (sumo).
BSP Test Process
New BSP test process consists of:
- Test Triggering - Test Setup - Test Execution - Test Result Store - Test Reporting and Regression - Decision
Roles
- Test Executor - Intel and WindRiver test team
- Overall QA Owner - Intel (2.7)
- QA Stakeholder - Team that owned final release decision
Test Triggering
ROLE: Test Executor
Intel and WindRiver test team request subscribe to QA notification by contacting Linux Foundation (Michael Halstead mhalstead@linuxfoundation.org), once QA notification received then each test team will start preparing for BPS testing.
Test Setup
ROLE: Test Executor
Intel and WindRiver test team will setup test hardware and environment for BSP testing.
Test Execution
ROLE: Test Executor
Intel and WindRiver test team will execute BSP runtime testing on related hardware accordingly.
For runtime tests available from oeqa/runtime, once executed this runtime tests, collect the "testresults.json" file contain the configuration and status from the <build-dir>/tmp/log/oeqa/ directory.
For runtime tests inside oeqa/manual, use "resulttool manualexecution" to execute these tests (refer to https://wiki.yoctoproject.org/wiki/Resulttool#manualexecution for more detail), collect the "testresults.json" file from the <build-dir>/tmp/log/manual/ directory.
Defect management
Once a test case failed during execution, create a bug ticket at Bugzilla. To map the bug ticket to the failed test case executed, provide below information inside bug ticket.
Information needed to trace bug to testcase inside yocto-testresults:
1. git tag - tag used to store the failed test case (eg. "{branch}/{commit_number}-g{commit}/{tag_number}") 2. result id - unique id inside testresults.json file that used to identify a test result set consist of a list of test cases executed
(eg. manual_bsps-hw_20190311160844)
3. test case id - unique id inside testresults.json file used to identify a specific test case executed
(eg. bsp-hw.bsps-oe-core.Test_Run_Integrity_-_Check_that_image_is_buildable)
Test Result Store
ROLE: Test Executor
Intel and WindRiver team will request write access to https://git.yoctoproject.org/git/yocto-testresults remote repository by contacting Linux Foundation (Michael Halstead mhalstead@linuxfoundation.org).
Intel and WindRiver test team will store the testresults.json files collected in previous section to the yocto-testresults git repository (http://git.yoctoproject.org/cgit/cgit.cgi/yocto-testresults/).
1. Git clone https://git.yoctoproject.org/git/yocto-testresults to local machine.
2. Use "resulttool store" to store testresults.json files to local yocto-testresults git repository (refer to https://wiki.yoctoproject.org/wiki/Resulttool#store for more detail).
3. Once verified the results are saved properly to local git repository, push the commit & tag to remote repository.
Make sure the git tag created (branch and commit) was correct and the correct testresults.json file was stored inside the local yocto-testresults git repository before push to remote.
Intel and WindRiver team will notifiy the Overall QA Owner on completion of BSP testing.
Test Reporting and Regression
ROLE: Overall QA Owner
Overall QA Owner team will re-run “resulttool report” & “resulttool regression-git” to create report and regression for both automated and BSP test result (refer to https://wiki.yoctoproject.org/wiki/Resulttool#report and https://wiki.yoctoproject.org/wiki/Resulttool#regression-git for more detail).
Decision
ROLE: QA Stakeholder
QA Stakeholder will review test report and regression information created in previous section to make the release decision.