From 0907ad5aace1ca72b7c355a8916ba737ed095f8b Mon Sep 17 00:00:00 2001 From: ankur22 Date: Thu, 12 Sep 2024 11:13:51 +0100 Subject: [PATCH] Refactor TestNavigationSpanCreation Adding better ways of waiting for API to end with the use of waitUntil and waitForNavigation. Now comparing the elements within the slices and not worrying about the order since the order can change on every test run. --- tests/tracing_test.go | 27 +++++++++++++++++++-------- 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/tests/tracing_test.go b/tests/tracing_test.go index ffde8b1f2..22e82451a 100644 --- a/tests/tracing_test.go +++ b/tests/tracing_test.go @@ -201,7 +201,7 @@ func TestNavigationSpanCreation(t *testing.T) { name: "goto", js: fmt.Sprintf(` page = await browser.newPage(); - await page.goto('%s'); + await page.goto('%s', {waitUntil:'networkidle'}); page.close(); `, ts.URL), expected: []string{ @@ -219,8 +219,8 @@ func TestNavigationSpanCreation(t *testing.T) { name: "reload", js: fmt.Sprintf(` page = await browser.newPage(); - await page.goto('%s'); - await page.reload(); + await page.goto('%s', {waitUntil:'networkidle'}); + await page.reload({waitUntil:'networkidle'}); page.close(); `, ts.URL), expected: []string{ @@ -240,8 +240,11 @@ func TestNavigationSpanCreation(t *testing.T) { name: "go_back", js: fmt.Sprintf(` page = await browser.newPage(); - await page.goto('%s'); - await page.evaluate(() => window.history.back()); + await page.goto('%s', {waitUntil:'networkidle'}); + await Promise.all([ + page.waitForNavigation(), + page.evaluate(() => window.history.back()), + ]); page.close(); `, ts.URL), expected: []string{ @@ -252,6 +255,7 @@ func TestNavigationSpanCreation(t *testing.T) { "navigation", // created when a new page is created "page.goto", "navigation", // created when a navigation occurs after goto + "page.waitForNavigation", "navigation", // created when going back to the previous page "page.close", }, @@ -260,8 +264,11 @@ func TestNavigationSpanCreation(t *testing.T) { name: "same_page_navigation", js: fmt.Sprintf(` page = await browser.newPage(); - await page.goto('%s'); - await page.locator('a[id=\"top\"]').click(); + await page.goto('%s', {waitUntil:'networkidle'}); + await Promise.all([ + page.waitForNavigation(), + page.locator('a[id=\"top\"]').click(), + ]); page.close(); `, ts.URL), expected: []string{ @@ -272,6 +279,7 @@ func TestNavigationSpanCreation(t *testing.T) { "navigation", // created when a new page is created "page.goto", "navigation", // created when a navigation occurs after goto + "page.waitForNavigation", "locator.click", "navigation", // created when navigating within the same page "page.close", @@ -291,7 +299,10 @@ func TestNavigationSpanCreation(t *testing.T) { assertJSInEventLoop(t, vu, tc.js) got := tracer.getOrderedSpan() - assert.Equal(t, tc.expected, got, fmt.Sprintf("%s failed", tc.name)) + // We can't use assert.Equal since the order of the span creation + // changes slightly on every test run. Instead we're going to make + // sure that the slice matches but not the order. + assert.ElementsMatch(t, tc.expected, got, fmt.Sprintf("%s failed", tc.name)) }() } }