Title: Runaway regular expressions in stack trace parser · Issue #57 · stacktracejs/error-stack-parser · GitHub
Open Graph Title: Runaway regular expressions in stack trace parser · Issue #57 · stacktracejs/error-stack-parser
X Title: Runaway regular expressions in stack trace parser · Issue #57 · stacktracejs/error-stack-parser
Description: This line: error-stack-parser/error-stack-parser.js Line 103 in a3bf972 var functionNameRegex = /((.*".+"[^@]*)?[^@]*)(?:@)/; freezes given the following input: " error("Warning: Received `%s` for a non-boolean attribute `%s`.\n\nIf you ...
Open Graph Description: This line: error-stack-parser/error-stack-parser.js Line 103 in a3bf972 var functionNameRegex = /((.*".+"[^@]*)?[^@]*)(?:@)/; freezes given the following input: " error("Warning: Received `%s` for ...
X Description: This line: error-stack-parser/error-stack-parser.js Line 103 in a3bf972 var functionNameRegex = /((.*".+"[^@]*)?[^@]*)(?:@)/; freezes given the following input: " error("Warning...
Opengraph URL: https://github.com/stacktracejs/error-stack-parser/issues/57
X: @github
Domain: patch-diff.githubusercontent.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"Runaway regular expressions in stack trace parser","articleBody":"This line: https://github.com/stacktracejs/error-stack-parser/blob/a3bf972e399fd39222d97f4dc241a74cc483b4db/error-stack-parser.js#L103 freezes given the following input:\r\n\r\n```\r\n\" error(\"Warning: Received `%s` for a non-boolean attribute `%s`.\\n\\nIf you want to write it to the DOM, pass a string instead: %s=\\\"%s\\\" or %s={value.toString()}.\\n\\nIf you used to conditionally omit it with %s={condition \u0026\u0026 value}, pass %s={condition ? value : undefined} instead.%s\", \"false\", \"loading\", \"loading\", \"false\", \"loading\", \"loading\", \"loading\", \"\\n in button (created by Context.Consumer)\\n in StyledButton (at overrideOptional.tsx:16)\\n in Overridable(StyledButton) (at Button.tsx:108)\\n in Button (created by Context.Consumer)\\n in StyledButton (at Button.tsx:51)\\n in ButtonWithArrow (at overrideOptional.tsx:16)\\n in Overridden(Button) (created by Context.Consumer)\\n in ButtonPrimary (at overrideOptional.tsx:16)\\n in Overridden(Styled(Overridable(Button))) (at Submit.tsx:7)\\n in Submit (at AddToCartForm.tsx:98)\\n in form (created by Form)\\n in FormProvider (created by Form)\\n in Form (at AddToCartForm.tsx:97)\\n in AddToCartForm (at ProductAddToCartForm.tsx:68)\\n in ProductAddToCartForm (at ProductPageInfoSide.tsx:244)\\n in div (created by Context.Consumer)\\n in Card (at ProductPageInfoSide.tsx:153)\\n in div (created by Context.Consumer)\\n in ProductInfo (at ProductPageInfoSide.tsx:152)\\n in ProductPageInfoSide (at ProductPage.tsx:194)\\n in div (created by Context.Consumer)\\n in ProductTop (at ProductPage.tsx:173)\\n in div (created by Context.Consumer)\\n in Wrapper (at Container.tsx:114)\\n in ForwardRef(_c) (at ProductPage.tsx:166)\\n in article (at ProductPage.tsx:165)\\n in main (created by Context.Consumer)\\n in Content (at PageWrapper.tsx:74)\\n in div (created by Context.Consumer)\\n in Page (at PageWrapper.tsx:65)\\n in PortalTarget (at PageWrapper.tsx:64)\\n in PageWrapper (at ProductPage.tsx:156)\\n in ProductPage (at overrideOptional.tsx:16)\\n in Overridable(ProductPage) (at DynamicRouteResolver.tsx:54)\\n in DynamicRouteResolver (created by Context.Consumer)\\n in Route (at AppRouter.tsx:25)\\n in Switch (at AppRouter.tsx:14)\\n in AppRouter (at App.tsx:32)\\n in BreakpointsProvider (at AppProviders.tsx:38)\\n in ApolloProvider (at ApolloConnector.tsx:68)\\n in ApolloConnector (at AppProviders.tsx:30)\\n in Router (at RouterProvider.tsx:18)\\n in RouterProvider (at AppProviders.tsx:29)\\n in StoreViewProvider (at AppProviders.tsx:25)\\n in ErrorBoundary (at RootErrorBoundary.tsx:105)\\n in RootErrorBoundary (at AppProviders.tsx:24)\\n in I18nProvider (at I18nLoader.tsx:19)\\n in I18nLoader (at AppProviders.tsx:23)\\n in AppProviders (at App.tsx:28)\\n in App (at src/index.tsx:30)\") at console.error (http://localhost:3340/__cypress/runner/cypress_runner.js:140661:26)\"\r\n```\r\n\r\n## Expected Behavior\r\nIt should not freeze the browser.\r\n\r\n## Current Behavior\r\nThe regex takes a very long time to parse the string\r\n\r\n## Steps to Reproduce (for bugs)\r\nPaste in the browser console:\r\n```\r\n\" error(\"Warning: Received `%s` for a non-boolean attribute `%s`.\\n\\nIf you want to write it to the DOM, pass a string instead: %s=\\\"%s\\\" or %s={value.toString()}.\\n\\nIf you used to conditionally omit it with %s={condition \u0026\u0026 value}, pass %s={condition ? value : undefined} instead.%s\", \"false\", \"loading\", \"loading\", \"false\", \"loading\", \"loading\", \"loading\", \"\\n in button (created by Context.Consumer)\\n in StyledButton (at overrideOptional.tsx:16)\\n in Overridable(StyledButton) (at Button.tsx:108)\\n in Button (created by Context.Consumer)\\n in StyledButton (at Button.tsx:51)\\n in ButtonWithArrow (at overrideOptional.tsx:16)\\n in Overridden(Button) (created by Context.Consumer)\\n in ButtonPrimary (at overrideOptional.tsx:16)\\n in Overridden(Styled(Overridable(Button))) (at Submit.tsx:7)\\n in Submit (at AddToCartForm.tsx:98)\\n in form (created by Form)\\n in FormProvider (created by Form)\\n in Form (at AddToCartForm.tsx:97)\\n in AddToCartForm (at ProductAddToCartForm.tsx:68)\\n in ProductAddToCartForm (at ProductPageInfoSide.tsx:244)\\n in div (created by Context.Consumer)\\n in Card (at ProductPageInfoSide.tsx:153)\\n in div (created by Context.Consumer)\\n in ProductInfo (at ProductPageInfoSide.tsx:152)\\n in ProductPageInfoSide (at ProductPage.tsx:194)\\n in div (created by Context.Consumer)\\n in ProductTop (at ProductPage.tsx:173)\\n in div (created by Context.Consumer)\\n in Wrapper (at Container.tsx:114)\\n in ForwardRef(_c) (at ProductPage.tsx:166)\\n in article (at ProductPage.tsx:165)\\n in main (created by Context.Consumer)\\n in Content (at PageWrapper.tsx:74)\\n in div (created by Context.Consumer)\\n in Page (at PageWrapper.tsx:65)\\n in PortalTarget (at PageWrapper.tsx:64)\\n in PageWrapper (at ProductPage.tsx:156)\\n in ProductPage (at overrideOptional.tsx:16)\\n in Overridable(ProductPage) (at DynamicRouteResolver.tsx:54)\\n in DynamicRouteResolver (created by Context.Consumer)\\n in Route (at AppRouter.tsx:25)\\n in Switch (at AppRouter.tsx:14)\\n in AppRouter (at App.tsx:32)\\n in BreakpointsProvider (at AppProviders.tsx:38)\\n in ApolloProvider (at ApolloConnector.tsx:68)\\n in ApolloConnector (at AppProviders.tsx:30)\\n in Router (at RouterProvider.tsx:18)\\n in RouterProvider (at AppProviders.tsx:29)\\n in StoreViewProvider (at AppProviders.tsx:25)\\n in ErrorBoundary (at RootErrorBoundary.tsx:105)\\n in RootErrorBoundary (at AppProviders.tsx:24)\\n in I18nProvider (at I18nLoader.tsx:19)\\n in I18nLoader (at AppProviders.tsx:23)\\n in AppProviders (at App.tsx:28)\\n in App (at src/index.tsx:30)\") at console.error (http://localhost:3340/__cypress/runner/cypress_runner.js:140661:26)\".match(/((.*\".+\"[^@]*)?[^@]*)(?:@)/)\r\n```\r\n\r\n## Context\r\nI am running Cypress tests against a React app. React dumps the component stack in the stack trace when it throws an error or warning for a component.\r\n\r\n## Your Environment\r\n* stacktrace.js version: error-stack-parser@2.0.6\r\n* Browser Name and version: Chrome 87, probably reproducible in all browsers.\r\n* Operating System and version (desktop or mobile): MacOS\r\n* Link to your project: N/A\r\n\r\n## Possible Solution\r\nA different RegEx, or no RegEx at all.\r\n","author":{"url":"https://github.com/MartijnHols","@type":"Person","name":"MartijnHols"},"datePublished":"2020-12-14T12:40:50.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":0},"url":"https://github.com/57/error-stack-parser/issues/57"}
| route-pattern | /_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format) |
| route-controller | voltron_issues_fragments |
| route-action | issue_layout |
| fetch-nonce | v2:7e66d63b-24a3-3514-7188-fb50a52b09cf |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | E426:22585E:5689D8:78A788:696F3C83 |
| html-safe-nonce | 7ffe1b77bb793806cd055431f04f203849e4b75b432b897944911dfb4614a868 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiJFNDI2OjIyNTg1RTo1Njg5RDg6NzhBNzg4OjY5NkYzQzgzIiwidmlzaXRvcl9pZCI6Ijg2MzM5NjcxMjY3Njg0NjcwNzUiLCJyZWdpb25fZWRnZSI6ImlhZCIsInJlZ2lvbl9yZW5kZXIiOiJpYWQifQ== |
| visitor-hmac | de1bfbc5fcdd49c28fb8ccbea677a4fa009c39e056ee357508eee03b8785779b |
| hovercard-subject-tag | issue:766387740 |
| github-keyboard-shortcuts | repository,issues,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | / |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/stacktracejs/error-stack-parser/57/issue_layout |
| twitter:image | https://opengraph.githubassets.com/0725d79426258628062a88bc29afe3b9c25fde66a5a740ac172ca804189e4479/stacktracejs/error-stack-parser/issues/57 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/0725d79426258628062a88bc29afe3b9c25fde66a5a740ac172ca804189e4479/stacktracejs/error-stack-parser/issues/57 |
| og:image:alt | This line: error-stack-parser/error-stack-parser.js Line 103 in a3bf972 var functionNameRegex = /((.*".+"[^@]*)?[^@]*)(?:@)/; freezes given the following input: " error("Warning: Received `%s` for ... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | MartijnHols |
| hostname | github.com |
| expected-hostname | github.com |
| None | b278ad162d35332b6de714dfb005de04386c4d92df6475522bef910f491a35ee |
| turbo-cache-control | no-preview |
| go-import | github.com/stacktracejs/error-stack-parser git https://github.com/stacktracejs/error-stack-parser.git |
| octolytics-dimension-user_id | 6131251 |
| octolytics-dimension-user_login | stacktracejs |
| octolytics-dimension-repository_id | 15014773 |
| octolytics-dimension-repository_nwo | stacktracejs/error-stack-parser |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 15014773 |
| octolytics-dimension-repository_network_root_nwo | stacktracejs/error-stack-parser |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | 39aed5006635ab6f45e6b77d23e73b08a00272a3 |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width