Integration Tests

The aim of the telemetry-tests-client suite is to verify Firefox collects telemetry probes, aggregates that data, and submits telemetry pings containing the data to a HTTP server. The integration tests try to make no assumptions about the internal workings of Firefox and use automation to mimic user behavior.

The integration test suite for Firefox Client Telemetry runs on CI tier 1 with treeherder symbol tt(c) and is checked in to version control at mozilla-central under toolkit/components/telemetry/tests/marionette/tests/client.

Test Main Tab Scalars

  • PATH: telemetry/tests/marionette/tests/client/test_main_tab_scalars.py

  • This test opens and closes a number of browser tabs, restarts the browser in a new session and then verifies the correctness of scalar data in the resulting main ping.

Test Search Counts

  • PATH: toolkit/telemetry/tests/marionette/tests/client/test_search_counts_across_subsessions.py

  • This test performs a search in a new tab, restarts Firefox in a new session and verifies the correctness of client, session and subsession IDs, as well as scalar and keyed histogram data in the shutdown ping, installs an addon, verifies the environment-change ping, and performs three additional search actions before restarting and verifying the new main ping.

Test Deletion Request Ping

  • PATH: toolkit/telemetry/tests/marionette/tests/client/test_deletion_request_ping.py

  • This test installs an addon and verifies a ping is received. The test takes note of the client ID. It then disables telemetry and checks for a deletion-request ping. After it receives the correct ping it makes sure that no other pings are sent. Telemetry is then re-enabled and the main ping is checked to see if the client ID has changed. The test asserts that the user has opted back in to telemetry.

Test Event Ping

  • PATH: toolkit/telemetry/tests/marionette/tests/client/test_event_ping.py

  • This test checks for a basic event ping. It opens firefox, performs a search and checks the event ping for the correct number of searches performed (1) and the correct search engine.

Test Fog Custom Ping

  • PATH: toolkit/telemetry/tests/marionette/tests/client/test_fog_custom_ping.py

  • This test creates a custom ping using the Glean API and asserts this ping is sent correctly.

Test Fog Deletion Request Ping

  • PATH: toolkit/telemetry/tests/marionette/tests/client/test_fog_deletion_request_ping.py

  • This test opens the browser, performs a search and disables telemetry after the search. It asserts that the telemetry is disabled and no pings exist. The browser is restarted and telemetry is then re-enabled. Then we set a debug tag which is attached to the ping. Telemetry is then disabled again to trigger a deletion-request ping. We verify that 1) The debug tag is present; and 2) that the client ID in the second deletion-request ping is different from the first client ID.

Test Fog User Activity

  • PATH: toolkit/telemetry/tests/marionette/tests/client/test_fog_user_activity.py

  • This test checks that a baseline ping is sent when the user starts or stops using Firefox.

Test Background Update Ping

  • PATH: toolkit/telemetry/tests/marionette/tests/client/test_fog_user_activity.py

  • In this test we launch Firefox to prepare a profile and to disable the background update setting. We exit Firefox, leaving the (unlocked) profile to be used as the default profile for the background update task (and not having multiple instances running). The task will not try to update, but it will send a ping. Then we restart Firefox to unwind the background update setting and allow shutdown to proceed cleanly.

Running the tests locally

You can run the tests on your local machine using mach:

./mach telemetry-tests-client

Running the tests on try

You can run the tests across all platforms on the try server using mach:

./mach try fuzzy -q "'telemetry-tests-client"

Disabling an individual failing test

The telemetry-tests-client suite is implemented in Python and uses Marionette for browser automation and wptserve for the HTTP ping server. The integration tests are based on Python’s unittest testing library and can be disabled by calling self.skipTest(“reason”) in a test method.

The example below demonstrates how to disable test_main_ping2:

import unittest

from telemetry_harness.testcase import TelemetryTestCase

class TestMainPingExample(TelemetryTestCase):
    """Example tests for the telemetry main ping."""

    def test_main_ping1(self):
        """Example test that we want to run."""

        self.search_in_new_tab("mozilla firefox")

    def test_main_ping2(self):
        """Example test that we want to skip."""

        self.skipTest("demonstrating skipping")

        self.search_in_new_tab("firefox telemetry")

Who to contact for help

  • The test cases are owned by Chris Hutten-Czapski (chutten on matrix) from the Firefox Telemetry team (#telemetry on matrix)

  • The test harness is owned by Raphael Pierzina (raphael on matrix) from the Ecosystem Test Engineering team (#telemetry on matrix)

Bugzilla

Bugs can be filed under the Toolkit product for the Telemetry component.