Project

General

Profile

action #34486

Updated by okurz over 4 years ago

## Motivation 

 From time to time a request comes up "how to search for test cases in openQA". In many cases the definition of "test cases" is not clear to the person asking or no clear relation to our [openQA terms](http://open.qa/docs/#concepts) exists. However, we should be able to provide an easy search interface which will simply by default return search results matching any of "testsuites", "scenarios", "test modules", "test steps". 


 ## Acceptance criteria 
 * **AC1:** There is a common way to search for "tests" in openQA as a catch-all however ambiguous the term is understood 
 * **AC2:** The user is asked one and only one question, that is the search term, nothing else 
 * **AC3:** Given a generic search term, When that search term matches *any* of test suite, scenario, test module, test steps or just mention in test code, Then *all* definition places are shown 

 ## Acceptance tests 

 * **AT1-1:** manual UX test: An uninformed user can find the search field over the openQA web UI 
 * **AT3-1:** search term "foo" finds a test suite "foo" 
 * **AT3-2:** search term "foo" finds a test suite "123foo456" 
 * **AT3-3:** search term "foo" finds a scenario "openSUSE-textmode@foo" for machine "foo" 
 * **AT3-4:** search term "foo" finds a test module "tests/console/foo.pm" from a test distribution folder within /var/lib/openqa/share/tests/*/ 
 * **AT3-5:** search term "foo" finds a reference to "foo" in code within a test module "tests/console/bar.pm" as in AT3-4 


 ## Suggestion 

 I envision a simple search textfield that queries: 

 * the names in the test suite database 
 * filenames in the test distribution(s), e.g. like https://github.com/os-autoinst/os-autoinst-distri-opensuse/search?q=filename%3Amultipath or `git ls-files "*<search_term>*"` 
   * for multiple distributions, query all or just what is considered the "main" one 
 * search terms within the test distribution files, e.g. like https://github.com/os-autoinst/os-autoinst-distri-opensuse/search?q=multipath or `git grep <search_term>` 
 * Show all of the results, probably a simple table view for all results from the above different queries 


 * https://github.com/okurz/scripts/blob/master/openqa-db_query_last_use_of_module provides an external tool relying on database access but it can help to find out scenarios running a specified test module.

Back