-
Notifications
You must be signed in to change notification settings - Fork 9.6k
Fix TypeError: "URL.parse is not a function" for Node.js < v22 #13698
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
Conversation
|
Thanks for your pull request! It looks like this may be your first contribution to a Google open source project. Before we can look at your pull request, you'll need to sign a Contributor License Agreement (CLA). View this failed invocation of the CLA check for more information. For the most up to date status, view the checks section at the bottom of the pull request. |
Summary of ChangesHello @macarronesc, I'm Gemini Code Assist1! I'm currently reviewing this pull request and will post my feedback shortly. In the meantime, here's a summary to help you and other reviewers quickly get up to speed! This pull request resolves a critical compatibility issue that caused the CLI to crash on Node.js LTS versions (v18 and v20). By updating the URL parsing logic to use a more widely supported and backward-compatible constructor, the application can now run without errors for users on these older Node.js environments. Highlights
Using Gemini Code AssistThe full guide for Gemini Code Assist can be found on our documentation page, here are some quick tips. Invoking Gemini You can request assistance from Gemini at any point by creating a comment using either
Customization To customize Gemini Code Assist for GitHub experience, repository maintainers can create a configuration file and/or provide a custom code review style guide (such as PEP-8 for Python) by creating and adding files to a Limitations & Feedback Gemini Code Assist may make mistakes. Please leave feedback on any instances where its feedback is incorrect or counter productive. You can react with 👍 and 👎 on @gemini-code-assist comments. If you're interested in giving your feedback about your experience with Gemini Code Assist for Github and other Google products, sign up here. You can also get AI-powered code generation, chat, as well as code reviews directly in the IDE at no cost with the Gemini Code Assist IDE Extension. Footnotes
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Code Review
This pull request correctly addresses a TypeError on older Node.js versions by replacing the non-standard URL.parse() with the new URL() constructor. My review includes one high-severity comment to improve the implementation. The main point is to preserve the function's error contract by continuing to throw a TypeError for invalid URLs, avoiding a potential breaking change. The suggested change also simplifies the code logic.
|
Thanks for fixing! |
Fixes #13615
Summary
Replaces the usage of the static method
URL.parse()with the standardnew URL()constructor (wrapped in a try-catch block). This change fixes theTypeError: URL.parse is not a functioncrash on Node.js LTS versions (v18, v20).Details
The codebase was using
URL.parse(), a static method that was only recently added to the globalURLobject in Node.js v22. Consequently, users running the CLI on current LTS versions (like Node.js v20) experienced immediate crashes when this code path was executed.While other parts of the project might have been updated or patched in later versions to support broader compatibility, this specific instance in
src/modules/extensions/github_download.ts(insidetryParseGithubUrl) remained unchanged, causing the persistent error reported in the issue.The fix involves replacing:
With the standard, backward-compatible approach:
Related Issues
Fixes #13615
How to Validate
TypeError: URL.parse is not a function.Pre-Merge Checklist