blob: 809a1276e85e4f81e24dc4b5923d14f1748fa2e9 [file] [log] [blame]
# Copyright 2019 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""Provide a TestCase to facilitate testing LegacyPageTest instances."""
import shutil
import tempfile
import unittest
from telemetry.internal.results import results_options
from telemetry.internal import story_runner
from import legacy_page_test
from telemetry.testing import options_for_unittests
from telemetry.testing import test_stories
class LegacyPageTestCase(unittest.TestCase):
"""A helper class to write tests for LegacyPageTest clients."""
def setUp(self):
self.options = options_for_unittests.GetRunOptions(
self.test_result = None
def tearDown(self):
def CreateStorySetForTest(url):
# Subclasses can override this method to customize the page used for tests.
return test_stories.SinglePageStorySet(url)
def RunPageTest(self, page_test, url, expect_status='PASS'):
"""Run a legacy page_test on a test url and return its measurements.
page_test: A legacy_page_test.LegacyPageTest instance.
url: A URL for the test page to load, usually a local 'file://' URI to be
served from telemetry/internal/testing. Clients can override the
static method CreateStorySetForTestFile to change this behavior.
expect_status: A string with the expected status of the test run.
A dictionary with measurements recorded by the legacy_page_test.
self.assertIsInstance(page_test, legacy_page_test.LegacyPageTest)
story_set = self.CreateStorySetForTest(url)
self.assertEqual(len(story_set), 1)
with results_options.CreateResults(self.options) as results:
story_runner.RunStorySet(page_test, story_set, self.options, results)
test_results = results_options.ReadTestResults(
self.assertEqual(len(test_results), 1)
self.test_result = test_results[0]
self.assertEqual(self.test_result['status'], expect_status)
return results_options.ReadMeasurements(self.test_result)