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

[Bug] RangeError: Maximum call stack size exceeded because of hacks to Function.prototype.toString in puppeteer-extra-plugin-stealth #890

Open
nomagick opened this issue May 13, 2024 · 4 comments
Labels
issue: bug report A bug has been reported needs triage

Comments

@nomagick
Copy link

Describe the bug
With puppeteer-extra-plugin-stealth plugin applied,
open any page in the internet archive, for example https://web.archive.org/web/20240513040624/https://www.google.com/
Then go to the terminal, you will see
RangeError: Maximum call stack size exceeded triggered for .toString() calls to any function.

I've looked into the code a bit and found the plugin making a lot of hacks to Function.prototype in some util function and the util function is used in many other places.

It might be the way-back-machine also hacking the browser environment a bit and some how it created a loop.

TBH I didn't quite get the purpose of the hacking and why it's always applied globally to Function.prototype.

But it might be time to consider refactoring this hack to use some constant WeakMap instead of chaining functions.

Code Snippet

const puppeteer = require('puppeteer-extra')
const StealthPlugin = require('puppeteer-extra-plugin-stealth')
puppeteer.use(StealthPlugin())

;(async () => {
  const browser = await puppeteer.launch({headless: false})
  const page = await browser.newPage()
  await page.goto('https://web.archive.org/web/20240513040624/https://www.google.com/')
  // ...
})()
@Ivanca
Copy link

Ivanca commented Jul 7, 2024

I'm having the same issue in this page:
https://www.liverpool.com.mx/tienda/pdp/honor-x6a-plus-lcd-6.7-pulgadas-desbloqueado/1156981440?skuid=1156981440
Seems like tricks in the function prototype are creating weird issues, I was able to pin down the issue to a call inside lodash:

/** Used to detect if a method is native. */
var reIsNative = RegExp('^' +
  funcToString$1.call(hasOwnProperty$1).replace(reRegExpChar, '\\$&')
  .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$'
);

image

@vladtreny
Copy link

This is because they change toString in their own script.

@vladtreny
Copy link

A very temporary solution

            await page.evaluateOnNewDocument(() => {
                delete Function.prototype.toString
            })

@oiluis
Copy link

oiluis commented Dec 30, 2024

This very temporary solution worked for me @vladtreny :) ... wondering if you or other folks managed to implement a definitive solution for that ...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
issue: bug report A bug has been reported needs triage
Projects
None yet
Development

No branches or pull requests

4 participants