QA/Mobile/FirefoxTVTestPlan: Difference between revisions

From MozillaWiki
< QA
Jump to navigation Jump to search
mNo edit summary
Line 54: Line 54:


== Code Analysis ==
== Code Analysis ==
* [https://codecov.io/gh/mozilla-mobile/focus-android/branch/master Codecov] is added to the github repo, and will display increase/decrease of unit test code coverage
* [https://codecov.io/gh/mozilla-mobile/firefox-tv/branch/master Codecov] will be added to the github repo, and will display increase/decrease of unit test code coverage
* Findbugs addon is added to warn developers against possible code issues, as well as Lint.
* Findbugs addon is added to warn developers against possible code issues, as well as Lint.



Revision as of 17:25, 22 March 2018

This is the Test Plan for Firefox for the Amazon Fire TV Stick (https://github.com/mozilla-mobile/firefox-tv)

Intro/Summary/Notes

Intro and Summary

  • This wiki outlines the test requirements for Firefox for the Amazon Fire TV Stick releases.
  • Use this generalized Test Plan as a starting point for creating Plans, Suites, and Cases

Notes

Feature Lists

For the list of features and its status, please refer to here.

  • NOTE: Firefox for the Amazon Fire TV Stick bugs are maintained in Github

Schedule

  • 2.0 was released in March 2018
  • Future milestones listed: here

Personnel

Program Management

Product Management

Development

QA Team

Resource Plan

  • Each QA person will be 100% allocated to this project

Test Strategy

Process

  • When the development work on github issue is completed, whether it is before/after code freeze, QA-ready label will be applied so that the issue is available for testing. The issue should belong to a correct milestone before the development work can be started.
  • QA will verify the issue, and upon completion, it'll be marked with QA-approved, removing QA-ready label.
  • If an issue is not QA verifiable, or worth the investment for testing time it can be marked with QA-denied
  • After code freeze, ideally, all issues should be marked with either QA-ready, QA-approved, or QA-denied.
  • After the QA signoff, ideally, all issues should be marked with QA-approved, or QA-denied.
  • The issue can be closed after it is marked as QA-approved, or QA-denied
  • This does not apply to metabugs.

Manual Tests

UI Test suite for Focus for Android will be located in [1]. As a minimum, each of the P1 UI features will have corresponding test cases. The test suite will be executed by Aaron for the time being for acceptance testing.

Automated Tests

Automation tests will be mainly used for quick regression check of key UI features. Overall, automation tests will be added to the same Github repo, and executed locally for the time being (at this time there is no supported Android TV CI). While the unit tests will be run for each commit, UI Tests (in Espresso/UIAutomator framework) will be executed in master branch only. The test result will be inspected for new failures, and github issue will be raised for tracking.

Automation tests are located here.

In addition to regularly run automated tests, QA will also generate screenshots for l10n verification.

Code Analysis

  • Codecov will be added to the github repo, and will display increase/decrease of unit test code coverage
  • Findbugs addon is added to warn developers against possible code issues, as well as Lint.

Outside Scope

Following tests are outside the scope of the QA:

  • Unit Tests
  • Performance Tests
  • Localization Tests
  • Beta testing with a wider audience

Test Deliverables

  • Completed TestRail Test suite which covers all features with UI aspects
  • Automated Test suite in master branch, running on every checkin
  • Github issues for every issue found
  • Manual acceptance test report
  • Signoff Decision

Testing Days

Dependencies/Risks

  • Since the blocking status of trackers is not exposed via adb log or UI, its validation will rely on unit tests
  • The performance of Focus for Android is not measured precisely, will rely on the tester feedback
  • The tester pool for a preliminary first release will be extremely small
  • The automation/manual test suites will be built incrementally as new features are added to Github, and the late features may not be exposed to validation as much as earlier ones. The acceptance test after the feature completion date will be performed with the special emphasis on 1. key features and 2. most recently added features

Signoff/Exit Criteria

  • No critical or major UI bugs
  • No easily reproducible crashes