blob: b24f515426b55f82d8ed724ba69e6034ef3307a7 [file] [log] [blame]
// Copyright (C) 2024 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
import {test, Page} from '@playwright/test';
import {PerfettoTestHelper} from './perfetto_ui_test_helper';
test.describe.configure({mode: 'serial'});
let pth: PerfettoTestHelper;
let page: Page;
const SQL_QUERY = `select id, ts, dur, name, category, track_id from slices
where category is not null limit 1000`;
test.beforeAll(async ({browser}, _testInfo) => {
page = await browser.newPage();
pth = new PerfettoTestHelper(page);
await pth.openTraceFile('api34_startup_cold.perfetto-trace');
});
test('debug tracks', async () => {
const omnibox = page.locator('input[ref=omnibox]');
await omnibox.focus();
await omnibox.selectText();
await omnibox.press(':');
await pth.waitForPerfettoIdle();
await omnibox.fill(SQL_QUERY);
await pth.waitForPerfettoIdle();
await omnibox.press('Enter');
await pth.waitForPerfettoIdle();
await page.getByRole('button', {name: 'Show debug track'}).click();
await pth.waitForPerfettoIdle();
await page.keyboard.type('debug track'); // The track name
await page.keyboard.press('Enter');
await pth.waitForPerfettoIdle();
await pth.waitForIdleAndScreenshot('debug track added.png');
// Click on a slice on the debug track.
await page.mouse.click(590, 180);
await pth.waitForPerfettoIdle();
await pth.waitForIdleAndScreenshot('debug slice clicked.png');
// Close the debug track.
await pth.locateTrack('debug track').getByText('close').first().click();
await pth.waitForPerfettoIdle();
await pth.waitForIdleAndScreenshot('debug track removed.png');
});
test('debug tracks pivot', async () => {
const omnibox = page.locator('input[ref=omnibox]');
await omnibox.focus();
await omnibox.selectText();
await omnibox.press(':');
await pth.waitForPerfettoIdle();
await omnibox.fill(SQL_QUERY);
await pth.waitForPerfettoIdle();
await omnibox.press('Enter');
await page.getByRole('button', {name: 'Show debug track'}).click();
await pth.waitForPerfettoIdle();
await page.keyboard.type('pivot'); // The track name
await page.locator('.pf-popup-portal #pivot').selectOption('category');
await page.keyboard.press('Enter');
await pth.waitForPerfettoIdle();
await pth.waitForIdleAndScreenshot('debug track pivot.png', {
clip: {
x: (await pth.sidebarSize()).width,
y: 180,
width: 1920,
height: 600,
},
});
});