From Fedora Project Wiki
(drop snake (it's ancient and unused), drop python-bugzilla (still active but QA doesn't maintain it any more), update testdays webapp link, update execdb link, make the opening paragraph less scary) |
(link to the actual openqa instance, link to relvalconsumer) |
||
Line 8: | Line 8: | ||
== Test Automation == | == Test Automation == | ||
; [[Taskotron]] : Taskotron is our current framework for automatically executing a number of Fedora related tests. Both Fedora infrastructure generic and Fedora packages specific tests should be supported. Package maintainers should have an easy way of providing tests for their packages. This framework obsoleted [[AutoQA]]. | ; [[Taskotron]] : Taskotron is our current framework for automatically executing a number of Fedora related tests. Both Fedora infrastructure generic and Fedora packages specific tests should be supported. Package maintainers should have an easy way of providing tests for their packages. This framework obsoleted [[AutoQA]]. You can see [https://taskotron.fedoraproject.org/ Taskotron in action]. | ||
; [[ResultsDB]] : A generic storage of (automated) test results. Designed to be lightweight, simple, scalable and fast. It's used by Taskotron. | ; [[ResultsDB]] : A generic storage of (automated) test results. Designed to be lightweight, simple, scalable and fast. It's used by Taskotron. | ||
Line 14: | Line 14: | ||
; [https://bitbucket.org/fedoraqa/execdb ExecDB] : This database with a front-end allows us to track tasks which are scheduled, running and finished in Taskotron. It provides a simple way to navigate people (mostly admin and developer-type folks) into different corners of the Taskotron infrastructure - BuildBot job details, ResultsDB results, logs and artifacts directories. Read some design [https://phab.qadevel.cloud.fedoraproject.org/w/taskotron/planning/execdb_features/ concepts]. | ; [https://bitbucket.org/fedoraqa/execdb ExecDB] : This database with a front-end allows us to track tasks which are scheduled, running and finished in Taskotron. It provides a simple way to navigate people (mostly admin and developer-type folks) into different corners of the Taskotron infrastructure - BuildBot job details, ResultsDB results, logs and artifacts directories. Read some design [https://phab.qadevel.cloud.fedoraproject.org/w/taskotron/planning/execdb_features/ concepts]. | ||
; [https:// | ; [https://openqa.fedoraproject.org openQA] : We use this tool (developed by our friends at [https://www.suse.com/ SUSE], now with contributions from us too) to automate certain release test cases, especially installation with [[Anaconda]]. We develop [https://bitbucket.org/rajcze/openqa_fedora Fedora tests] for openQA, along with a [https://bitbucket.org/rajcze/openqa_fedora_tools scheduler and some other tools]. Also see the [https://os-autoinst.github.io/openQA/ upstream home page]. | ||
; [http://beaker.fedoraproject.org Beaker] : Beaker is an up and coming fully automated test framework that provides bare metal hardware provisioning including console and power management, and job scheduling and execution. Learn more at [http://beaker-project.org/ Beaker homepage]. | ; [http://beaker.fedoraproject.org Beaker] : Beaker is an up and coming fully automated test framework that provides bare metal hardware provisioning including console and power management, and job scheduling and execution. Learn more at [http://beaker-project.org/ Beaker homepage]. | ||
Line 20: | Line 20: | ||
== Release validation testing == | == Release validation testing == | ||
; [https://www.happyassassin.net/wikitcms/ python-wikitcms], [https://www.happyassassin.net/relval/ relval] and [https://www.happyassassin.net/testdays/ testdays]: A Python library and CLI based upon it for performing various [[QA:Release_validation_test_plan|release validation testing]] tasks in the [[Wikitcms]] 'test management system' (the set of wiki pages in which release validation test results are stored). testdays can perform a few basic operations on [[Test_Days|Test Day]] pages. | ; [https://www.happyassassin.net/wikitcms/ python-wikitcms], [https://www.happyassassin.net/relval/ relval] and [https://www.happyassassin.net/testdays/ testdays]: A Python library and CLI based upon it for performing various [[QA:Release_validation_test_plan|release validation testing]] tasks in the [[Wikitcms]] 'test management system' (the set of wiki pages in which release validation test results are stored). testdays can perform a few basic operations on [[Test_Days|Test Day]] pages. [https://git.fedorahosted.org/cgit/fedora-qa.git/tree/relvalconsumer relvalconsumer] is a [https://www.fedmsg.com Fedmsg] consumer which creates validation test events. | ||
== Test case reporting == | == Test case reporting == |
Revision as of 06:50, 26 April 2016
The QA team develops tools to make testing easier and more repeatable. We have several projects ranging from some that are pretty simple and new developer friendly to complex and challenging stuff at the cutting edge of the field. Contact Tim Flink or the qa-devel mailing list if you're interesting in helping to build new tools for Fedora QA.
QA tools
Test Automation
- Taskotron
- Taskotron is our current framework for automatically executing a number of Fedora related tests. Both Fedora infrastructure generic and Fedora packages specific tests should be supported. Package maintainers should have an easy way of providing tests for their packages. This framework obsoleted AutoQA. You can see Taskotron in action.
- ResultsDB
- A generic storage of (automated) test results. Designed to be lightweight, simple, scalable and fast. It's used by Taskotron.
- ExecDB
- This database with a front-end allows us to track tasks which are scheduled, running and finished in Taskotron. It provides a simple way to navigate people (mostly admin and developer-type folks) into different corners of the Taskotron infrastructure - BuildBot job details, ResultsDB results, logs and artifacts directories. Read some design concepts.
- openQA
- We use this tool (developed by our friends at SUSE, now with contributions from us too) to automate certain release test cases, especially installation with Anaconda. We develop Fedora tests for openQA, along with a scheduler and some other tools. Also see the upstream home page.
- Beaker
- Beaker is an up and coming fully automated test framework that provides bare metal hardware provisioning including console and power management, and job scheduling and execution. Learn more at Beaker homepage.
Release validation testing
- python-wikitcms, relval and testdays
- A Python library and CLI based upon it for performing various release validation testing tasks in the Wikitcms 'test management system' (the set of wiki pages in which release validation test results are stored). testdays can perform a few basic operations on Test Day pages. relvalconsumer is a Fedmsg consumer which creates validation test events.
Test case reporting
- Test Days Frontend
- A web application for providing results from Test Days events. It uses ResultsDB (legacy) as a backend.
Bug reporting
- Blocker Bugs App
- A web application to display current blocker bugs during our pre-release cycle.
Test update feedback
- Fedora Gooey Karma
- A graphical tool that makes it easy to report feedback for any updates-testing packages currently installed.
- Fedora Easy Karma
- A command line tool that makes it easy to report feedback for any updates-testing packages currently installed.
Mixed bag
- Fedora QA scripts
- A git repository containing various small scripts.
Infrastructure tools
These tools we use as our support infrastructure during QA tools development.
- Bitbucket team repository
- A list of repositories that are related to our tools and needs.
- Phabricator
- Our main issue and code review tracker for most of our projects.