Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Panic with we either navigate top level or have old version of the navigated frame #1341

Closed
1 of 3 tasks
ankur22 opened this issue May 22, 2024 · 4 comments
Closed
1 of 3 tasks
Assignees
Labels
bug Something isn't working

Comments

@ankur22
Copy link
Collaborator

ankur22 commented May 22, 2024

Brief summary

When navigating through certain websites, in some cases an error we either navigate top level or have old version of the navigated frame is reported which stops the test iteration. At the moment it's not clear why this occurs, but in the investigation so far we have found that the frame in question that is causing this panic isn't being tracked by k6 browser.

There are two ways in which a new frame is tracked by k6 browser:

  1. Chrome tells us that a frame is attached (this is where we expect a CDP message);
  2. We attach to the frame(s) by getting the existing frame tree.

We have explored the CDP requests that are made between k6 browser and chrome, but we do not see a frameAttached event being sent from Chrome, but we can see that the frameTree does contain a reference to the new frame as a child.

xk6-browser version

v1.5.1

OS

NA

Chrome version

NA

Docker version and image (if applicable)

NA

Steps to reproduce the problem

Run the script that is causing this issue to replicate the issue.

Expected behaviour

Script passes with no issues.

Actual behaviour

Panics with we either navigate top level or have old version of the navigated frame.

Tasks

Preview Give feedback
  1. 0 of 2
    tests
@ankur22 ankur22 added the bug Something isn't working label May 22, 2024
@ankur22 ankur22 self-assigned this May 22, 2024
@ankur22
Copy link
Collaborator Author

ankur22 commented May 24, 2024

I think I have a better idea of what is happening.

  1. We have the page, which has a frame and a session.
  2. The page has an iframe, which is first attached with page.frameAttached CDP from Chrome.
  3. Eventually we get a target.attachTarget for the iframe, but a new frameSession is also created.
  4. Now we start to receive CDP requests from both the original session and new session for the iframe.
  5. We finally receive a frameDetached CDP event of type "swap" from chrome for the iframe on the original session (not the new session).
  6. We remove the child frames.
    navigation error since the child frame was removed.

I'm not 100% sure how to handle the CDP events incoming from different sessions for the same frame, but I think we can check to see if the incoming detach event's sessionId matches the frame's sessionId, and if they don't match we ignore the event.

Playwright does something similar to what i'm proposing, well, they just check to see if the frame exists with a session.

Puppeteer seems to ignore the swap frameDetach events completely, as in they don't seem to remove any frames 🤷

@inancgumus
Copy link
Member

@ankur22

👍 Makes sense.

Puppeteer seems to ignore the swap frameDetach events completely, as in they don't seem to remove any frames 🤷

Side note: When I look into the Puppeteer's code, they seem to be doing some actions for the frame-swapped events. This and this.

@ankur22
Copy link
Collaborator Author

ankur22 commented May 24, 2024

Side note: When I look into the Puppeteer's code, they seem to be doing some actions for the frame-swapped events. This and this.

Thanks for the links. Yeah, i still don't see them removing the frames, so i feel the solution we're going with (at least for now) is a good one. We might have to change it if we find another edge case with iframe, and bring it more in line with either Playwright or Puppeteer.

@inancgumus
Copy link
Member

inancgumus commented May 24, 2024 via email

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

2 participants