Skip to content

Commit

Permalink
Merge main into experimental (#10462)
Browse files Browse the repository at this point in the history
* [RUN-3292] separately targetable steps for e2e on linux-x86_64 and macos-arm64 (#10392)

Support running the e2e tests on both platforms, since we've had issues affecting only macos-arm64 in the past.

In an effort to not wait on both chromium builds before starting the tests, make each step targetable using env vars.  The corresponding PR in chromium (replayio/chromium#1142) waits on a single build and then triggers this pipeline with the proper env vars.  This could also be done with multiple buildkite pipelines and/or multiple .yml files, but this seemed the best choice to keep things together.

* Migrate more e2e examples to Chromium (#10396)

* Add ReplayWall.sendAtPauseId() (#10399)

* Replace declarative Video component with imperative code (#10393)

Using a suspense cache for this was a mistake. Renders need to happen too quickly, and mixing rapid updates with suspense leads to starvation problems (renders that don't finish and update the DOM). I rewrote this to use imperative logic, which is how it was before (in a way) though I think this code is more consolidated.

* Warn if hit counts can't be loaded for the outline panel (#10400)

* Fixed timeline tooltip edge positioning (#10401)

* Update @replayio/protocol to version 0.70.0 (#10402)

* [RUN-3224] Remove `authenticated/comments-03` from blacklist (#10403)

* Upgrade suspense (#10404)

* Don't reset page title after a root-level error (#10406)

* Don't try to load computed properties if no element is selected (#10409)

* Show picker loading state until bounding rects are loaded (#10410)

* Improve detection of DOM elements (#10411)

* Redirect mobile clients to warning page (#10407)

* Revert "Redirect mobile clients to warning page (#10407)" (#10412)

This reverts commit e0b0aab because of FE-2346

* Remove default roles for new members (#10370)

* Remove default roles for new members

* fix toggling roles instead of setting them

* refactor role selection for clarity

* ensure viewer role is added

* Redirect mobile clients to warning page (#10413)

* Redirect mobile clients to warning page (FE-2342)
* Make test suites test-runs 2 less flaky (FE-2346)

* Improve getDimensions() method error message (#10414)

* Pass testScope through GraphQL Subscription Request

In order to properly scope comments we need to have the testScope
available on the websocket request. Headers on websocket requests are
weird, you are not really supposed to use them, so we pass it through
the same way we do the auth details.

This is a noop on the backend right now, but soon it will be used.

* Fix iteration in TestStepSourceLocationCache (#10417)

* Don't override null fallback in InlineErrorBoundary (#10416)

* Remove cloning and user-reset from e2e tests (#10418)

Resolves FE-2347 and BAC-4754.

This was originally added in #9497 as a way to avoid parallel tests from interfering with each other but has since proved to be difficult to maintain on the backend side. Our tests will now use unique "scopes" instead to isolate comments, points, and nags between runs.

I've tested this locally by...
- Running tests in parallel, multiple times
- Killing tests in the middle (leaving stranded comments) and then re-running them

* Improve repaint/graphics e2e test stability (#10419)

I noticed some repaint e2e test failures recently. They aren't common, but when they occur, it seems like our logic of waiting for a screenshot to change is not robust enough to handle a delay in loading the initial screenshot, which can cause subsequent comparisons to fail.

To reduce the likelihood of this, I've updated our test helpers to explicitly wait for the current screenshot to finish loading before returning the graphics content. I think this should improve the stability of the various repaint related tests.

* Fix timing problem with elements-panel helper (#10420)

* Redirect Gecko recordings to legacy.replay.io (#10421)

Resolves FE-2107, FE-2132, and FE-2133

- Dashboard links directly to legacy.replay.io
- If a Gecko recording is opened on app.replay.io, show a redirect UI
- Update e2e test recording scripts to remove "firefox" as a target
- Temporarily disabled the last remaining Firefox e2e test (inspector-rules-02)

* Disable repaint-01 e2e test (#10423)

* Remove legacy (Gecko) Elements panel (#10424)

- Delete legacy replay-next/components/elements code
  - Copied over the two Suspense caches and three util methods that were referenced by external code
- Rename replay-next/components/elements-new to replay-next/components/elements
- Update all references

This is a prerequisite for making use of persistent ids in this panel.

* Remove legacy (Gecko) React DevTools panel (#10425)

* Rename legacy replay-next/components/elements package to replay-next/components/elements-old

* Remove legacy elements panel; update references

* Rename replay-next/components/elements-new to replay-next/components/elements

* Udpate imperative API comment

* Remove legacy, Gecko React DevTools

* Harden Timeline event handlers (#10426)

- Fixed a logic error in stopPlayback that caused it to null out playback state before checking if it was null (🤡)
  - I think this was the core of the bugfix
- Move Timeline move-move and mouse-up handlers to the body element, to ensure that dragging past the timeline's boundaries updates the current time appropriately
  - This was making it difficult to scrub the playback time to the beginning of a recording, for example
- Remove no-longer-used "dragging" state from Redux
- Remove no-longer-used updateTime param to Redux stopPlayback action

* Auto-redirect to legacy.replay.io (#10427)

* Fix handling of Control key in KeyboardModifiersContext (#10432)

* Allow internal users to create teams without trials (#10430)

* Update doc_control_flow.html to include more precise logging (#10433)

* Add switch accounts interstitial to login flow (#10431)

* Add missing useEffect dependency (#10436)

* Update TypeScript dep from 5.3.3 to 5.4.2 (latest) (#10428)

* Update TypeScript dep from 5.3.3 to 5.4.2 (latest)

* Remove `typescript` dependency from `replay-next` package

* Fixed used semver range fro the `typescript` dependency

* Remove redundant `typescript` dev dependency from packages

* Revert "Remove redundant `typescript` dev dependency from packages"

This reverts commit 8d38b36.

* Unify TypeScript version used across all contained packages

* Revert "Add switch accounts interstitial to login flow (#10431)" (#10437)

This reverts commit 3c81069.

* Delete unused replay-next test harness code (#10434)

These views were useful in the initial development of replay-next components because they gave me isolated test harnesses. In more recent times, they were only exercised by the "Delta" screenshot tests, which were themselves removed in #10243.

I also noticed we were running yarn test in that package as a GitHub Workflow, even though the main "Unit tests" workflow already includes these tests.

* package.json and yarn.lock file auto changes

* Fix tilt config to allow running deps in parallel (#10438)

Allows devtools to be started sooner in the cloud dev flow. It currently
waits until all other resources have completed before starting the devtools
steps.

* Revert "Update TypeScript dep from 5.3.3 to 5.4.2 (latest) (#10428)" (#10439)

This reverts commit f5dc68b.

* Update doc_rr_objects and doc_control_flow and re-enable repaint-01 (#10441)

* Fix repaint-05 e2e test flakiness (#10443)

* Re-enable the inspector-computed-02 e2e test (#10444)

* Report session timeouts in e2e tests (#10445)

* Update TypeScript dep from 5.3.3 to 5.4.2 (latest) - take 2 (#10442)

* Revert "Revert "Update TypeScript dep from 5.3.3 to 5.4.2 (latest) (#10428)" (#10439)"

This reverts commit 3ca214b.

* Fixed the import style of `testFunction` in the Redux example

* Add extra validation for a custom `playwrightScript`

* Fix the inspect_element nag and the passport-02 test (#10446)

* Add switch accounts interstitial to login flow (take 2) (#10440)

* Reapply "Add switch accounts interstitial to login flow (#10431)" (#10437)

This reverts commit 2a470e0.

* fix handling auth requests coming from the browser

* add comments

* fix connection parsing; hide switch accounts on replay browser

* Dont swallow error when recording e2e tests (#10447)

* Reimplement some e2e tests (#10448)

* Use different network request in authenticated/comments-03 test (#10450)

* Add readme docs for playwright plugin test example (#10451)

* Add more checks to passport-01 e2e test (#10452)

* Improve paint/repaint behavior (#10449)

Makes several small changes to graphics related code to improve interruption and better handle caching edge cases

* Consider repaint graphics when finding the nearest paint (#10453)

We have many layers of Suspense caching:
1. `PaintsCache` - caches results from one-time call to `Graphics.findPaints` (array of timestamps and paint hashes)
2. `RepaintGraphicsCache` - caches results from all calls to `DOM.repaintGraphics` (screenshots)
3. `screenshotCache` - caches results from all calls to `Graphics.getPaintContents` (screenshots for the paint hashes cached in the `PaintsCache`)
4. `paintHashCache` - caches screenshot data for paint hash (screenshots from `RepaintGraphicsCache` and `screenshotCache`) since the `DOM.repaintGraphics` API only sends screenshot data once per paint hash

This commit merges cached paints and repaint data into a single, sorted list and updates all of the various _findClosest_ and _findMostRecent_ methods to use the merged data source. This results in less flickering when stepping between cached paint points.

### Before

Graphics "flickers" when stepping because the most recent cached paint is displayed while a repaint is being fetched.

https://github.com/replayio/devtools/assets/29597/10eb506a-abe4-443f-be08-e21ebdeccd87

### After

No "flicker" when stepping because the nearest paint is now the recently loaded repaint.

https://github.com/replayio/devtools/assets/29597/87c18646-2758-4951-a321-842c209ffa29

* Add messages for the most common sources of e2e flakiness (#10454)

* Update node picker e2e test logic to handle DPR > 1 (#10455)

* Fix the passport-02 and inspector-elements-02 tests (#10456)

* Ensure the test step details panel doesn't get stuck in loading state (#10457)

* Fix selection in filtered list of tests (#10459)

* Add message to addCommentHelper() (#10460)

---------

Co-authored-by: Chris Toshok <[email protected]>
Co-authored-by: Holger Benl <[email protected]>
Co-authored-by: Brian Vaughn <[email protected]>
Co-authored-by: Domi <[email protected]>
Co-authored-by: Ryan Duffy <[email protected]>
Co-authored-by: Josh Morrow <[email protected]>
Co-authored-by: Mateusz Burzyński <[email protected]>
  • Loading branch information
8 people authored Mar 25, 2024
1 parent 75d0a1f commit 0b049de
Show file tree
Hide file tree
Showing 295 changed files with 2,924 additions and 8,208 deletions.
37 changes: 32 additions & 5 deletions .buildkite/runtime-tests.yml
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
steps:
- label: "Runtime e2e tests (linux-x86_64)"
if: (build.env("OS") == "linux" && build.env("ARCH") == "x86_64") || (build.env("OS") == null && build.env("ARCH") == null)
timeout_in_minutes: 60
key: "runtime-fe-e2e-tests-linux_x86_64"
commands:
- "mkdir -p /mnt/data/replay"
- "be_cmd install_yarn -- npm i -g yarn"
- "be_cmd node_deps -- yarn install"
- "be_cmd node_deps -- npx yarn install"
- "be_cmd run_tests -- ts-node ./packages/e2e-tests/scripts/buildkite_run_fe_tests_from_artifact-linux-x86_64.ts"
agents:
- "deploy=true"
Expand All @@ -29,7 +28,7 @@ steps:
RUNTIME_TEAM_API_KEY: runtime-replay-api-key
BUILDEVENT_APIKEY: honeycomb-api-key
BUILDEVENT_BUILDKITE_API_TOKEN: buildkite-api-token-honeycomb-build-events
- replayio/buildevents#76b6f57: ~
- replayio/buildevents#0c2adb2: ~
- "ssh://[email protected]/replayio/fly-buildkite-plugin.git#v0.77":
# This image's source code is here https://github.com/replayio/backend-e2e-base-image
image: "registry.fly.io/buildkite-backend-e2e-tests:v14"
Expand All @@ -48,9 +47,37 @@ steps:
AUTOMATED_TEST_SECRET: AUTOMATED_TEST_SECRET
RECORD_REPLAY_API_KEY: RECORD_REPLAY_API_KEY
RUNTIME_TEAM_API_KEY: RUNTIME_TEAM_API_KEY

env:
DISPLAY: ":1"
PLAYWRIGHT_HEADLESS: "true"
PLAYWRIGHT_CHROMIUM: "true"
RECORD_REPLAY_DIRECTORY: "/mnt/data/replay"

- label: "Runtime e2e tests (macos-arm64)"
if: build.env("OS") == "macos" && build.env("ARCH") == "arm64"
timeout_in_minutes: 60
commands:
- "be_cmd node_deps -- npx yarn install"
- "be_cmd run_tests -- ts-node ./packages/e2e-tests/scripts/buildkite_run_fe_tests_from_artifact-macos-arm64.ts"
agents:
- "os=macos"
- "arch=arm64"
- "queue=runtime"
- "runtimeType=test"
plugins:
- seek-oss/aws-sm#v2.3.1:
region: us-east-2
env:
BUILDKITE_AGENT_TOKEN: "prod/buildkite-agent-token"
AUTOMATED_TEST_SECRET: "graphql-automated-test-secret"
RECORD_REPLAY_API_KEY: "runtime-record-replay-api-key"
HASURA_ADMIN_SECRET: "prod/hasura-admin-secret"
RUNTIME_TEAM_API_KEY: runtime-replay-api-key
BUILDEVENT_APIKEY: honeycomb-api-key
BUILDEVENT_BUILDKITE_API_TOKEN: buildkite-api-token-honeycomb-build-events
- replayio/buildevents#0c2adb2: ~
env:
DISPLAY: ":1"
PLAYWRIGHT_HEADLESS: "true"
PLAYWRIGHT_CHROMIUM: "true"
ARCHITECTURE: "arm64"
1 change: 1 addition & 0 deletions .eslintrc.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

41 changes: 0 additions & 41 deletions .github/workflows/bvaughn-jest.yml

This file was deleted.

6 changes: 3 additions & 3 deletions Tiltfile
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
def devtools(working_directory=config.main_dir, api='https://api.replay.io/v1/graphql', subscriptions='wss://api.replay.io/v1/graphql', dispatch='wss://dispatch.replay.io'):
local_resource("devtools deps", "yarn install", deps=["package.json"], dir=working_directory)
local_resource("devtools webpack", serve_cmd="rm -rf .next && yarn dev", deps=[], resource_deps=["devtools deps"], serve_dir=working_directory, serve_env={"NEXT_PUBLIC_API_URL": api, "NEXT_PUBLIC_DISPATCH_URL": dispatch, "NEXT_PUBLIC_API_SUBSCRIPTION_URL": subscriptions})
def devtools(working_directory=config.main_dir, api='https://api.replay.io/v1/graphql', subscriptions='wss://api.replay.io/v1/graphql', dispatch='wss://dispatch.replay.io', resource_deps=[]):
local_resource("devtools deps", "yarn install", deps=["package.json"], dir=working_directory, allow_parallel=True)
local_resource("devtools webpack", serve_cmd="rm -rf .next && yarn dev", deps=[], resource_deps=["devtools deps"] + resource_deps, serve_dir=working_directory, serve_env={"NEXT_PUBLIC_API_URL": api, "NEXT_PUBLIC_DISPATCH_URL": dispatch, "NEXT_PUBLIC_API_SUBSCRIPTION_URL": subscriptions})
25 changes: 25 additions & 0 deletions middleware.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import type { NextRequest } from "next/server";
import { NextResponse, userAgent } from "next/server";

export function middleware(request: NextRequest) {
const { ua } = userAgent(request);

if (isMobile(ua)) {
// If the user is attempting to visit Replay on a mobile device for the first time,
// show them a message that it has not been optimized for mobile
// If they have already confirmed this message (detectable via a cookie) then let them through
const cookie = request.cookies.get("mobile-warning-dismissed");
if (cookie == null && request.nextUrl.pathname !== "/mobile-warning") {
return NextResponse.redirect(new URL("/mobile-warning", request.url));
}
}
}

// Which routes should this middleware respond to
export const config = {
matcher: ["/", "/team/:path*", "/recording/:path*"],
};

function isMobile(ua: string) {
return /iP(hone|ad|od)/.test(ua) || /Android/.test(ua);
}
8 changes: 4 additions & 4 deletions package.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 3 additions & 1 deletion packages/e2e-tests/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ Our old E2E test suite re-recorded those examples every time the test suite ran.
The tests themselves are written using a set of "page object"-style helper functions that abstract specific pieces of DOM interaction. This allows the tests themselves to be written in a more readable style and focus on the sequence of operations:

```ts
import test from "../testFixtureCloneRecording";
import test from "../testFixture";

test(`Test stepping forward through breakpoints when rewound before the first one.`, async ({
pageWithMeta: { page, recordingId },
Expand Down Expand Up @@ -148,6 +148,8 @@ If you want to update those to fresher recording IDs, open up the team workspace

You'll also probably need to specifically share that recording as "Public", especially since it's in a Test Suites workspace that would normally not allow anonymous users to view recordings.

We use 1 specific Playwright test recording which is a replay of the breakpoints-05 test from this repo. Similar to the instructions above, to update this to a more recent version, you can visit the dashboard for FE E2E Tests and select a more recent recording ID for that test.

We also now have a "golden recording" of one of our own `breakpoints-01` E2E test runs. This serves as a testbed for checking more advanced behaviors like the React and Redux routines. If we ever need to update this, just copy-paste the recording ID from a test run in our "Frontend E2E tests" workspace.

### Test Suite Dashboard Tests
Expand Down
2 changes: 1 addition & 1 deletion packages/e2e-tests/authenticated/comments-01.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { openDevToolsTab, startTest } from "../helpers";
import { E2E_USER_1 } from "../helpers/authentication";
import { addSourceCodeComment, deleteComment, editComment } from "../helpers/comments";
import { openSource } from "../helpers/source-explorer-panel";
import test from "../testFixtureCloneRecording";
import test from "../testFixture";

test.use({ exampleKey: "authenticated_comments.html", testUsers: [E2E_USER_1] });

Expand Down
2 changes: 1 addition & 1 deletion packages/e2e-tests/authenticated/comments-02.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import {
replyToComment,
} from "../helpers/comments";
import { openSource } from "../helpers/source-explorer-panel";
import test, { Page } from "../testFixtureCloneRecording";
import test, { Page } from "../testFixture";

const url = "authenticated_comments.html";

Expand Down
8 changes: 4 additions & 4 deletions packages/e2e-tests/authenticated/comments-03.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import {
} from "../helpers/comments";
import { openNetworkPanel } from "../helpers/network-panel";
import { openSource } from "../helpers/source-explorer-panel";
import test, { expect } from "../testFixtureCloneRecording";
import test, { expect } from "../testFixture";

test.use({ exampleKey: "authenticated_comments.html", testUsers: [E2E_USER_1] });

Expand All @@ -36,13 +36,13 @@ test(`authenticated/comments-03: Comment previews`, async ({
await openNetworkPanel(page);
const networkRequestComment = await addNetworkRequestComment(page, {
method: "GET",
name: "favicon.ico",
status: 404,
name: "authenticated_comments.html",
status: 200,
text: "network request",
});
const networkRequestCommentPreviewText =
(await networkRequestComment.locator('[data-test-name="CommentPreview"]').textContent()) ?? "";
await expect(networkRequestCommentPreviewText.trim()).toBe("[GET] favicon.ico");
await expect(networkRequestCommentPreviewText.trim()).toBe("[GET] authenticated_comments.html");

// Add and verify visual comment
const visualComment = await addVisualComment(page, {
Expand Down
2 changes: 1 addition & 1 deletion packages/e2e-tests/authenticated/logpoints-01.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import {
import { openSource } from "../helpers/source-explorer-panel";
import { addLogpoint, editLogPoint, removeAllLogpoints } from "../helpers/source-panel";
import { waitForRecordingToFinishIndexing } from "../helpers/utils";
import test, { Page, expect } from "../testFixtureCloneRecording";
import test, { Page, expect } from "../testFixture";

const url = "authenticated_logpoints.html";
const lineNumber = 14;
Expand Down
34 changes: 28 additions & 6 deletions packages/e2e-tests/authenticated/passport-01.test.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
import { openDevToolsTab, startTest } from "../helpers";
import { E2E_USER_1 } from "../helpers/authentication";
import { warpToMessage } from "../helpers/console-panel";
import { openEventsPanel } from "../helpers/info-event-panel";
import { openNetworkPanel } from "../helpers/network-panel";
import { isPassportItemCompleted, showPassport } from "../helpers/passport";
import { enablePassport } from "../helpers/settings";
import { addLogpoint, removeAllLogpoints } from "../helpers/source-panel";
import { waitFor } from "../helpers/utils";
import test, { expect } from "../testFixtureCloneRecording";
import test, { expect } from "../testFixture";

test.use({ exampleKey: "doc_rr_console.html", testUsers: [E2E_USER_1] });
test.use({ exampleKey: "redux-fundamentals/dist/index.html", testUsers: [E2E_USER_1] });

test(`authenticated/passport-01: Time travel`, async ({
pageWithMeta: { page, recordingId, testScope },
Expand All @@ -20,27 +22,47 @@ test(`authenticated/passport-01: Time travel`, async ({

expect(await isPassportItemCompleted(page, "Console time travel")).toBeFalsy();
expect(await isPassportItemCompleted(page, "Add a console log")).toBeFalsy();
expect(await isPassportItemCompleted(page, "Jump to code")).toBeFalsy();
expect(await isPassportItemCompleted(page, "Jump to event")).toBeFalsy();
expect(await isPassportItemCompleted(page, "Jump to network request")).toBeFalsy();

await openDevToolsTab(page);

await warpToMessage(page, "Iteration 1");
await warpToMessage(page, "Found an issue?");

await waitFor(async () =>
expect(await isPassportItemCompleted(page, "Console time travel")).toBeTruthy()
);

await addLogpoint(page, { lineNumber: 13, saveAfterEdit: true });
await addLogpoint(page, { lineNumber: 499, saveAfterEdit: true });
await removeAllLogpoints(page);

await waitFor(async () =>
expect(await isPassportItemCompleted(page, "Add a console log")).toBeTruthy()
);

await page.locator('[data-test-name="ToolbarButton-ReplayInfo"]').click();
await page.locator('[data-test-name="Event"]').click();
await openEventsPanel(page);
const event = page.locator('[data-test-name="Event"]:has-text("Key Press W")');
await event.hover();
await event.locator('[data-test-name="JumpToCode"]').click();

await waitFor(async () =>
expect(await isPassportItemCompleted(page, "Jump to code")).toBeTruthy()
);

await openEventsPanel(page);
await event.click();

await waitFor(async () =>
expect(await isPassportItemCompleted(page, "Jump to event")).toBeTruthy()
);

await openNetworkPanel(page);
const request = page.locator('[data-test-name="Network-RequestRow"]:has-text("todos")').first();
await request.hover();
await request.locator('[data-test-name="Network-RequestRow-SeekButton"]').click();

await waitFor(async () =>
expect(await isPassportItemCompleted(page, "Jump to network request")).toBeTruthy()
);
});
17 changes: 4 additions & 13 deletions packages/e2e-tests/authenticated/passport-02.test.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@
import { openDevToolsTab, startTest } from "../helpers";
import { E2E_USER_1 } from "../helpers/authentication";
import { showCommentsPanel } from "../helpers/comments";
import { warpToMessage } from "../helpers/console-panel";
import {
activateInspectorTool,
findElementCoordinates,
inspectCanvasCoordinates,
openElementsPanel,
waitForElementsToLoad,
Expand All @@ -14,7 +13,7 @@ import { openReactDevtoolsPanel } from "../helpers/new-react-devtools-panel";
import { isPassportItemCompleted } from "../helpers/passport";
import { enablePassport } from "../helpers/settings";
import { waitFor } from "../helpers/utils";
import test, { expect } from "../testFixtureCloneRecording";
import test, { expect } from "../testFixture";

test.use({ exampleKey: "cra/dist/index.html", testUsers: [E2E_USER_1] });

Expand All @@ -29,19 +28,14 @@ test(`authenticated/passport-02: Infrared inspection`, async ({
expect(await isPassportItemCompleted(page, "Inspect UI elements")).toBeFalsy();
expect(await isPassportItemCompleted(page, "Inspect network requests")).toBeFalsy();
expect(await isPassportItemCompleted(page, "Inspect React components")).toBeFalsy();
expect(await isPassportItemCompleted(page, "Jump to code")).toBeFalsy();

await openDevToolsTab(page);
await warpToMessage(page, "Added an entry");

await openElementsPanel(page);
await waitForElementsToLoad(page);
await activateInspectorTool(page);
await inspectCanvasCoordinates(page, 0.05, 0.01);

// Clicking the canvas will add a comment which can cause timing complications with the passport check below
// Easiest way to avoid this is to explicitly wait for the comments panel to be shown before continuing
await showCommentsPanel(page);
const { x, y } = await findElementCoordinates(page, '<div id="root"');
await inspectCanvasCoordinates(page, x, y);

await waitFor(async () =>
expect(await isPassportItemCompleted(page, "Inspect UI elements")).toBeTruthy()
Expand All @@ -61,7 +55,4 @@ test(`authenticated/passport-02: Infrared inspection`, async ({
await waitFor(async () =>
expect(await isPassportItemCompleted(page, "Inspect React components")).toBeTruthy()
);

// TODO add test for the "Jump to code" item.
// Currently we can't make example recordings containing mouse or keyboard events...
});
2 changes: 1 addition & 1 deletion packages/e2e-tests/authenticated/passport-03.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import { enablePassport } from "../helpers/settings";
import { addLogpoint, editLogPoint, removeAllLogpoints } from "../helpers/source-panel";
import { enterFocusMode, saveFocusRange } from "../helpers/timeline";
import { clearTextArea, getCommandKey, waitFor } from "../helpers/utils";
import test, { expect } from "../testFixtureCloneRecording";
import test, { expect } from "../testFixture";

test.use({ exampleKey: "doc_rr_console.html", testUsers: [E2E_USER_1] });

Expand Down
2 changes: 1 addition & 1 deletion packages/e2e-tests/authenticated/passport-04.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { addSourceCodeComment, deleteComment } from "../helpers/comments";
import { isPassportItemCompleted } from "../helpers/passport";
import { enablePassport } from "../helpers/settings";
import { waitFor } from "../helpers/utils";
import test, { expect } from "../testFixtureCloneRecording";
import test, { expect } from "../testFixture";

test.use({ exampleKey: "doc_rr_console.html", testUsers: [E2E_USER_1] });

Expand Down
Loading

0 comments on commit 0b049de

Please sign in to comment.