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

fix: do not override electron debug port if previously set #27169

Merged
merged 5 commits into from
Jun 30, 2023

Conversation

warrensplayer
Copy link
Contributor

Additional details

PR #26573 added logic to assign a random available port for Electron to use as the debugging port to connect to CDP. This PR adds a check to make sure if a port has been passed in via setting an environment variable (i.e. ELECTRON_EXTRA_LAUNCH_ARGS=--remote-debugging-port=9222) as documented here (https://docs.cypress.io/api/plugins/browser-launch-api#Modify-Electron-app-switches) that it will not get overridden with a random port.

Steps to test

  • Look at unit test added
  • Run test with example repo in reported issue
    • Clone NeuraLegion/cypress-har-generator
    • cd to example directory
    • install Cypress 12.12.0 - npm i -D Cypress@12.12.0
    • install rest of dependencies - npm i
    • run tests - ELECTRON_EXTRA_LAUNCH_ARGS=--remote-debugging-port=9222 npm run test
    • view failure
     CypressError: `cy.task('recordHar')` failed with the following error:

> Failed to connect to Chrome Debugging Protocol

Possible reasons for failure:
  - Chrome not running in headless mode
  - Using Chrome version 58 or earlier
  - Inconsistent RDP configuration settings.
  • View fix in this branch
    • in the example repo in the example directory, run npm run start to start the example server
    • switch to this branch in the Cypress project
    • cd packages/app
    • run ELECTRON_EXTRA_LAUNCH_ARGS=--remote-debugging-port=9222 yarn cypress:run-cypress-in-cypress node ../../scripts/cypress run --project {path_to}/cypress-har-generator/example and switch out path to the reproduction repo where it says path_to in this command
    • Tests should run successfully

How has the user experience changed?

N/A

PR Tasks

@cypress
Copy link

cypress bot commented Jun 29, 2023

30 flaky tests on run #48517 ↗︎

0 27937 1349 0 Flakiness 30

Details:

Merge branch 'develop' into stokes/26711_electron_debug_port
Project: cypress Commit: 0b4f68584f
Status: Passed Duration: 21:51 💡
Started: Jun 30, 2023 6:34 PM Ended: Jun 30, 2023 6:56 PM
Flakiness  commands/net_stubbing.cy.ts • 1 flaky test • 5x-driver-firefox

View Output Video

Test Artifacts
network stubbing > intercepting request > can delay and throttle a StaticResponse Output
Flakiness  e2e/origin/commands/assertions.cy.ts • 1 flaky test • 5x-driver-firefox

View Output Video

Test Artifacts
cy.origin assertions > #consoleProps > .should() and .and() Output
Flakiness  cypress/cypress.cy.js • 3 flaky tests • 5x-driver-firefox

View Output Video

Test Artifacts
... > correctly returns currentRetry Output
... > correctly returns currentRetry Output
... > correctly returns currentRetry Output
Flakiness  create-from-component.cy.ts • 1 flaky test • app-e2e

View Output Video

Test Artifacts
... > runs generated spec Output Screenshots Video
Flakiness  cypress-in-cypress.cy.ts • 1 flaky test • app-e2e

View Output Video

Test Artifacts
Cypress in Cypress > scales the AUT correctly in e2e Output Screenshots Video

The first 5 flaky specs are shown, see all 17 specs in Cypress Cloud.

This comment has been generated by cypress-bot as a result of this project's GitHub integration settings.

@warrensplayer warrensplayer requested review from a team and ryanthemanuel June 29, 2023 19:46
Comment on lines 29 to 40
// if port was already set via passing from environment variable ELECTRON_EXTRA_LAUNCH_ARGS,
// then just keep the supplied value
if (app.commandLine.getSwitchValue('remote-debugging-port')) {
return
}

const port = await getPort()

// set up remote debugging port
app.commandLine.appendSwitch('remote-debugging-port', String(port))

return app.commandLine.appendSwitch
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// if port was already set via passing from environment variable ELECTRON_EXTRA_LAUNCH_ARGS,
// then just keep the supplied value
if (app.commandLine.getSwitchValue('remote-debugging-port')) {
return
}
const port = await getPort()
// set up remote debugging port
app.commandLine.appendSwitch('remote-debugging-port', String(port))
return app.commandLine.appendSwitch
// if port was already set via passing from environment variable ELECTRON_EXTRA_LAUNCH_ARGS,
// then just keep the supplied value
if (!app.commandLine.getSwitchValue('remote-debugging-port')) {
const port = await getPort()
// set up remote debugging port
app.commandLine.appendSwitch('remote-debugging-port', String(port))
}
return app.commandLine.appendSwitch

Should we preserve the existing return value for either path?

Copy link
Contributor Author

@warrensplayer warrensplayer Jun 30, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I was the one that added the return value when trying to debug my unit test. It is not used so I just removed it.

cli/CHANGELOG.md Outdated Show resolved Hide resolved
@lmiller1990 lmiller1990 self-requested a review June 30, 2023 00:06
Copy link
Contributor

@lmiller1990 lmiller1990 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code seems fine. I followed the repro instructions but I did not encounter an error, though 🤔

warrensplayer and others added 2 commits June 30, 2023 08:14
Co-authored-by: Mike Plummer <mike-plummer@users.noreply.github.com>
@warrensplayer warrensplayer merged commit e65a3e3 into develop Jun 30, 2023
@warrensplayer warrensplayer deleted the stokes/26711_electron_debug_port branch June 30, 2023 19:01
@cypress-bot
Copy link
Contributor

cypress-bot bot commented Jul 6, 2023

Released in 12.17.0.

This comment thread has been locked. If you are still experiencing this issue after upgrading to
Cypress v12.17.0, please open a new issue.

@cypress-bot cypress-bot bot locked as resolved and limited conversation to collaborators Jul 6, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Failed to connect to Chrome Debugging Protocol
4 participants