fix(core): throw error for invalid URL in config file#8159
Conversation
* Also add unit test to check error is thrown
|
Hi @forgeRW! Thank you for your pull request and welcome to our community. Action RequiredIn order to merge any pull request (code, docs, etc.), we require contributors to sign our Contributor License Agreement, and we don't seem to have one on file for you. ProcessIn order for us to review and merge your suggested changes, please sign at https://code.facebook.com/cla. If you are contributing on behalf of someone else (eg your employer), the individual CLA may not be sufficient and your employer may need to sign the corporate CLA. Once the CLA is signed, our tooling will perform checks and validations. Afterwards, the pull request will be tagged with If you have received this in error or have any questions, please contact us at cla@fb.com. Thanks! |
✅ [V2]Built without sensitive environment variables
To edit notification comments on pull requests, go to your Netlify site settings. |
⚡️ Lighthouse report for the deploy preview of this PR
|
|
Thank you for signing our Contributor License Agreement. We can now accept your code for this (and any) Meta Open Source project. Thanks! |
|
Thank you for signing our Contributor License Agreement. We can now accept your code for this (and any) Meta Open Source project. Thanks! |
* Throw error for invalid URL in Docusaurus config file * Perform error check in configValidation.ts * Undo error check in createSitemap.ts
| try { | ||
| const {pathname} = new URL(value); | ||
| if (pathname !== '/') { | ||
| helpers.warn('docusaurus.configValidationWarning', { |
There was a problem hiding this comment.
Thanks
in case you want to follow-up, I think we should make this other case an error instead of a warning
There was a problem hiding this comment.
Thanks for the suggestion! I'll work on this and make a new PR.
* fix: throw error for invalid URL in Docusaurus config file * Also add unit test to check error is thrown * fix: perform error check for invalid URL to configValidation.ts * Throw error for invalid URL in Docusaurus config file * Perform error check in configValidation.ts * Undo error check in createSitemap.ts * Better message Co-authored-by: Joshua Chen <sidachen2003@gmail.com>
Summary: This diff fixes the following warning: ``` [WARNING] Docusaurus config validation warning. Field "url": the url is not supposed to contain a sub-path like '/category/developer-tools/', please use the baseUrl field for sub-paths ``` This warning first becomes an error in `docusaurus` v2.2.0: - https://docusaurus.io/changelog/2.2.0#nail_care-polish - facebook/docusaurus#8159 Given that the publicly-facing site is hosted at https://dotslash-cli.com/, I'm using that as the URL. The fix is necessary before upgrading/unpinning "docusaurus/core". Reviewed By: bigfootjon Differential Revision: D83591987 fbshipit-source-id: a00571dd45b5dc9ca344483fdf16b6ee81acb7ac
Pre-flight checklist
Motivation
The error is uncleared that an invalid URL is provided in the Docusaurus config file. The error is thrown by the normalizeURL function (/path/node_modules/sitemap/dist/lib/utils.js:274:15) so this PR adds code to catch the TypeError from the normalizeURL function and throw an error for an invalid URL.
Test Plan
Test links
I added a unit test to verify my code.
Related issues/PRs
Related to #8116