This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision Next revision | Previous revision | ||
| uls:testsuite:version_180 [2014-01-23 11:46] uls | uls:testsuite:version_180 [2014-01-29 08:14] (current) uls [Test Scenarios] | ||
|---|---|---|---|
| Line 2: | Line 2: | ||
| This is the test suite for version 1.8.0 of ULS. | This is the test suite for version 1.8.0 of ULS. | ||
| + | |||
| + | |||
| + | ==== Test Environment ==== | ||
| + | |||
| + | The stage environment is used for all tests. | ||
| Line 14: | Line 19: | ||
| **boundary tests** are made to verify the correct processing of e.g. very small and very large values.  | **boundary tests** are made to verify the correct processing of e.g. very small and very large values.  | ||
| - | The **general tests** are based on values derived from the current number of seconds | + | **continuous tests** are based on values derived from the current number of seconds | 
| - | * of the current hour | + | * within the current hour | 
| - | * of the current day and | + | * within the current day | 
| - | * of the current week (since 00:00 of last monday) | + | * within the current week (since 00:00 of last monday) and | 
| + | * within the current month | ||
| - | These values are specifically converted and calculated to cover the most common scenarios.  | + | These values are specifically prepared and calculated to cover the most common scenarios.  | 
| In combination with **threshold** definitions they are used to test the firing of **notifications** for threshold violations  | In combination with **threshold** definitions they are used to test the firing of **notifications** for threshold violations  | ||
| The notifications will contain replaced static and dynamically calculated embedded **placeholders** in their message bodies. | The notifications will contain replaced static and dynamically calculated embedded **placeholders** in their message bodies. | ||
| - | These values will also be used for the check of the **aggregation** of values. | + | These values will also be used for the check of the **aggregation** or **compression** of values. | 
| Reports are used to check the different expected results and to check the **report** functionality itself. | Reports are used to check the different expected results and to check the **report** functionality itself. | ||
| Line 29: | Line 35: | ||
| * do the necessary [[uls:testsuite:version_180:preparations]] | * do the necessary [[uls:testsuite:version_180:preparations]] | ||
| - | ---- | + | The test cases are separated by function in different sections: | 
| - | + | ||
| - | + | ||
| - | ==== Test Cases ==== | + | |
| - | + | ||
| - | This section describes all test cases. | + | |
| * administrative settings and tests in [[uls:testsuite:version_180:admin_settings]] | * administrative settings and tests in [[uls:testsuite:version_180:admin_settings]] | ||
| * basic values, one execution in [[uls:testsuite:version_180:basic_values]] | * basic values, one execution in [[uls:testsuite:version_180:basic_values]] | ||
| * continuous values generation in [[uls:testsuite:version_180:continuous_values]] | * continuous values generation in [[uls:testsuite:version_180:continuous_values]] | ||
| + | * special values generation in [[uls:testsuite:version_180:special_values]] | ||
| * aggregations in [[uls:testsuite:version_180:aggregations]] | * aggregations in [[uls:testsuite:version_180:aggregations]] | ||
| * notifications in [[uls:testsuite:version_180:notifications]] | * notifications in [[uls:testsuite:version_180:notifications]] | ||
| + | * deletion of values after elapsed [[uls:testsuite:version_180:retention]] | ||
| + | |||
| ---- | ---- | ||
| - | === VAL 0100: Continuous Values === | ||
| - | |||
| - | Several values of all supported value type are created and transferred to ULS | ||
| - | in regular time intervals (each minute) | ||
| - | |||
| - | Create a crontab to make the "continuous_values" script execute every minute. The script  | ||
| - | |||
| - | <code bash> | ||
| - | cd /etc/cron.d/ | ||
| - | vi uls_test_suite | ||
| - | </code> | ||
| - | |||
| - | <file cron uls_test_suite> | ||
| - | * * * * * uls /home/uls/testsuite/test_suite_1_8_0/continuous_values > /home/uls/testsuite/test_suite_1_8_0/continuous_values.log 2>&1 | ||
| - | </file> | ||
| - | |||
| - | Verify, that the generated ULS value files are transferred to the ULS-server | ||
| - | and that their content is stored correctly. | ||
| - | |||
| - | Use a webbrowser, login as ULS user "AmieAction" (full rights on "ULS", read-only on "Woodlark"),  | ||
| - | chose the correct time interval (yesterday if the script runs already for more than a day | ||
| - | or explicit iso time interval) and check all values for domain "ULS": | ||
| - | |||
| - | <file> | ||
| - | ULS | ||
| - | └─► testsrv11 | ||
| - | └─► VAL 0110: Continuous Hourly Values  | ||
| - | └─► 110 Integer Values  (1 value) | ||
| - | └─► 120 Float Values  (1 value) | ||
| - | └─► 130 Text Expressions  (2 values) | ||
| - | └─► testsrv12 | ||
| - | └─► VAL 0110: Continuous Hourly Values | ||
| - | └─► 110 Integer Values  (2 values) | ||
| - | └─► 120 Float Values  (1 value) | ||
| - | └─► 140 Files (1 image, 1 file "spiro.png") | ||
| - | </file> | ||
| - | |||
| - | and for domain "Woodlark" | ||
| - | <file> | ||
| - | Woodlark | ||
| - | └─► testsrv21 | ||
| - | └─► VAL 0110: Continuous Hourly Values | ||
| - | └─► 120 Float Values  (1 value) | ||
| - | └─► 130 Text Expressions  (2 expressions, 3 words, each 20 characters) | ||
| - | └─► 140 Files (1 image with different contents, 1 file "trw.jpg"') | ||
| - | └─► testsrv22 | ||
| - | └─► VAL 0110: Continuous Hourly Values | ||
| - | └─► 120 Float Values  (1 value) | ||
| - | </file> | ||
| - | |||
| - | Generate a report, //administration >> edit reports// and enter "VAL 0110: Continuous Hourly Values" as report name | ||
| - | and press {{:uls:testsuite:version_180:ok_button.png?nolink}}. | ||
| - | |||
| - | Use //edit// and {{:uls:testsuite:version_180:append_autodetails.png?nolink}} to create a report detail. | ||
| - | |||
| - | {| | ||
| - | | name: | ||
| - | | Show Last Values | ||
| - | |- | ||
| - | | groups: | ||
| - | | Database | ||
| - | |- | ||
| - | | server: | ||
| - | | testsrv* | ||
| - | |- | ||
| - | | section: | ||
| - | | VAL 0110: Continuous Hourly Values | ||
| - | |- | ||
| - | | separate by: | ||
| - | | [x] server, [x] teststep | ||
| - | |- | ||
| - | | period: | ||
| - | | yesterday ((be sure, that the script is already running longer than a day!)) | ||
| - | |- | ||
| - | | display: | ||
| - | | last values | ||
| - | |} | ||
| - | |||
| - | or use a specific time interval like: | ||
| - | |||
| - | {| | ||
| - | | from: | ||
| - | | 2014-01-15 00:00:00 | ||
| - | |- | ||
| - | | to: | ||
| - | | 2014-01-15 23:59:59 | ||
| - | |} | ||
| - | |||
| - | |||
| - | All other specifications remain unchanged. | ||
| - | |||
| - | Click {{:uls:testsuite:version_180:ok_button.png?nolink}} and | ||
| - | {{:uls:testsuite:version_180:show_report.png?nolink}} to show the report.  | ||
| - | |||
| - | Go to //administration >> edit mail reports// and send the | ||
| - | "VAL 0110: Continuous Hourly Values" report to your e-mail address.  | ||
| - | Use | ||
| - | * (x) landscape | ||
| - | * [x] send now | ||
| - | |||
| - | The report should look like {{:uls:testsuite:version_180:val_0110_continuous_hourly_values_2014-01-22.pdf|this}} | ||
| - | |||
| - | ----- | ||
| - | |||
| - | |||
| - | === AGR 0200: Aggregations === | ||
| - | |||
| - | Aggregations are defined on continuously generated values. | ||
| - | Connect as "AmieAction" to ULS and go to | ||
| - | //administration >> compression >> set auto-compression// and chose domain "ULS"  | ||
| - | (AmieAction has enough rights **only** for domain "ULS"). | ||
| - | |||
| - | * set section to "VAL 0110: Continuous Hourly Values" | ||
| - | * activate all checkboxes of "hourly" and {{:uls:testsuite:version_180:ok_button.png?nolink|}} | ||
| - | * continue with {{:uls:testsuite:version_180:textmode_button.png?nolink|}} and | ||
| - | * {{:uls:testsuite:version_180:export_button.png?nolink|}} to export the definitions to a new browser tab. | ||
| - | * copy the definition and paste it into the textbox of previous browser tab. | ||
| - | * copy the "hourly" entry to the other lines | ||
| - | |||
| - | It should look like: | ||
| - | |||
| - | <file ini create auto-compression for ULS> | ||
| - | server= | ||
| - | section=VAL 0110: Continuous Hourly Values | ||
| - | teststep= | ||
| - | detail= | ||
| - | unit= | ||
| - | hourly=last,avg,sum,dev,min,max,max-min,last-first,count,grad,first,accel,differ,firstsize,last/avg,lastsize | ||
| - | daily=last,avg,sum,dev,min,max,max-min,last-first,count,grad,first,accel,differ,firstsize,last/avg,lastsize | ||
| - | weekly=last,avg,sum,dev,min,max,max-min,last-first,count,grad,first,accel,differ,firstsize,last/avg,lastsize | ||
| - | monthly=last,avg,sum,dev,min,max,max-min,last-first,count,grad,first,accel,differ,firstsize,last/avg,lastsize | ||
| - | special= | ||
| - | access=all  | ||
| - | </file> | ||
| - | |||
| - | Click {{:uls:testsuite:version_180:ok_button.png?nolink|}} to save that. | ||
| - | A new entry was added, delete the entry created in the first step. | ||
| - | |||
| - | Click on //changes// to verify that the initial change has been logged. | ||
| - | |||
| - | Any compression/aggregation action will be executed in the following night. | ||
| - | |||
| - | == AGR 0210: Propagation of Aggregation Rules == | ||
| - | |||
| - | Verify, that the above rules are propagated correctly. Check: | ||
| - | * //administration >> compression >> set compression >> ULS >> testsrv11 >> 110 Integer Values// | ||
| - | |||
| - | :TODO: does not work currently (2014-01-22) | ||
| - | |||
| - | :NOTE:  When the [E] values are compressed/aggregated, the effective unit with the maximum numbers is used to process the aggregations. | ||
| - | That may (in extreme cases) vary from day to day! | ||
| - | Nevertheless, you may use combi-compressed-details to convert it into your favorite unit. | ||
| - | |||
| - | |||
| - | |||
| - | ----- | ||
| - | |||
| - | === NOT 0100: Notifications === | ||
| - | |||
| - | |||
| - | ----- | ||
| - | |||
| - | |||
| - | === VAL 0300: Special Values === | ||
| - | |||
| - | |||
| - | == VAL 0310: Timing Tuples with Additional Attributes == | ||
| - | |||
| - | |||
| - | == VAL 0330: Boundary Values == | ||
| - | |||
| - | |||
| - | |||
| - | ----- | ||
| - | |||
| - | === NFY 0100: Notification Scenarios === | ||
| - | |||
| - | Threshold violations | ||
| - | |||
| - | Define various possible notification scenarios and verify the correctly generated notifications | ||
| - | |||
| - | ULS ticket tracking: threshold violations generate notifications and tickets. ULS users can work on those tickets and document their actions. | ||
| - | |||
| - | ----- | ||
| - | |||
| - | === NFY 0300: Notification Scenarios on Aggregated Values === | ||
| - | |||
| - | Threshold violations | ||
| - | |||
| - | Define various possible notification scenarios on aggregated values and verify the correctly generated notifications | ||
| - | |||
| - | ULS ticket tracking: threshold violations generate notifications and tickets. ULS users can work on those tickets and document their actions. | ||
| - | |||
| - | |||
| - | |||
| - | === Continue Here === | ||
| - | |||
| - | :NOTE: Continue here | ||
| - | |||
| - | |||
| - | |||
| - | |||
| - | |||
| - | |||
| - | the correct storage of all value types: | ||
| - | |||
| - | * including boundary tests to assure the covered value ranges | ||
| - | * checked by interactive analysis | ||
| - | * checked by reports | ||
| - | * deletion of values after the retention time has elapsed | ||
| - | |||
| - | |||
| - | |||
| - | === Boundary Tests === | ||
| - | |||
| - | |||
| - | === General Tests === | ||
| - | |||
| - | values, thresholds, aggregation, ... | ||
| - | |||
| - | * threshold violations | ||
| - | |||
| - | * numeric, string and file-like values | ||
| - | * different functions combined with number of values and/or time range | ||
| - | * including message bodies of notifications with replaced static and dynamically calculated embedded placeholders | ||
| - | |||
| - | * aggregation of values | ||
| - | |||
| - | * check the different possible aggregation functions on different data types | ||
| - | |||
| - | * reports | ||
| - | |||
| - | * check the expected results | ||
| - | * check the creation and modification of reports | ||
| - | * user-defined headers, separators, descriptions and logo | ||
| - | * PDF generation | ||
| - | |||
| - | |||
| - | |||
| - | |||
| - | ==== Test Procedure Specification ==== | ||
| - | |||
| - | |||
| - | detailing how to run each test, including any set-up preconditions and the steps that need to be followed | ||
| - | |||
| - | Test Script is a program written to test the functionality of the application. It is a set of system readable instructions to automate the testing with the advantage of doing repeatable and regression testing easily. | ||
| - | |||
| - | ==== Test Environment ==== | ||
| - | |||
| - | It is the Hardware and Software Environment where is the testing is going to be done. It also explains whether the software under test interacts with Stubs and Drivers. | ||
| - | |||
| - | Create a mock business. Treat it as real and process its data. | ||
| - | |||
| - | ==== Test Procedure ==== | ||
| - | |||
| - | Test Procedure is a document with the detailed instruction for step by step execution of one or more test cases. Test procedure is used in Test Scenario and Test Scripts. | ||
| - | |||
| - | |||
| - | ==== Test Log ==== | ||
| - | |||
| - | Test Log contains the details of test case execution and the output information. | ||
| - | |||
| - | recording which tests cases were run, who ran them, in what order, and whether each test passed or failed | ||
| - | |||
| - | |||
| - | ==== Test Incident Report ==== | ||
| - | |||
| - | detailing, for any test that failed, the actual versus expected result, and other information intended to throw light on why a test has failed. This document is deliberately named as an incident report, and not a fault report. The reason is that a discrepancy between expected and actual results can occur for a number of reasons other than a fault in the system. These include the expected results being wrong, the test being run wrongly, or inconsistency in the requirements meaning that more than one interpretation could be made. The report consists of all details of the incident such as actual and expected results, when it failed, and any supporting evidence that will help in its resolution. The report will also include, if possible, an assessment of the impact of an incident upon testing. | ||
| - | ==== Test Summary Report ==== | ||
| - | A management report providing any important information uncovered by the tests accomplished, and including assessments of the quality of the testing effort, the quality of the software system under test, and statistics derived from Incident Reports. The report also records what testing was done and how long it took, in order to improve any future test planning. This final document is used to indicate whether the software system under test is fit for purpose according to whether or not it has met acceptance criteria defined by project stakeholders. | ||