Setting specific chrome flags in puppeteer (enable and disable)

14,605

Solution 1

Follow these steps, please.

  1. puppeteer.defaultArgs() will provide you all default flags. You this method to get them, then filter the array to remove flags that you want to. https://github.com/GoogleChrome/puppeteer/blob/master/docs/api.md#puppeteerdefaultargs

    const args = puppeteer.defaultArgs().filter(arg => arg !== '--enable-asm-webassembly')

  2. Now, add some flags to the array.

    args.push('--enable-webgl-draft-extensions', '--shared-array-buffer')

  3. Enable ignoreDefaultArgs flag when launch a new instance of browser. Also, provide the list of arguments we made above.

    const browser = await puppeteer.launch({ ignoreDefaultArgs: true, args })

Solution 2

await puppeteer.launch({
      args: [
        '--disable-features=LookalikeUrlNavigationSuggestionsUI'
      ]
})

Try something like this.

You can launch Chromium, switch your flag and then go "chrome://version/", to see what has changed in the command line.

In my case, when i switch "Navigation suggestions for lookalike URLs" to disabled,relaunch Chrommium, then i found --disable-features=LookalikeUrlNavigationSuggestionsUI in the command line。

Solution 3

Previous answer already points in the right direction, but it can be made simpler. The key point is that you need to split your arguments into an array. The code can simply be:

const browser = await puppeteer.launch({args:["--flag-switches-begin", "--enable-webgl-draft-extensions", "--enable-features=SharedArrayBuffer", "--disable-features=AsmJsToWebAssembly", "--flag-switches-end"]});
Share:
14,605
zeev_r
Author by

zeev_r

Updated on June 07, 2022

Comments

  • zeev_r
    zeev_r almost 2 years

    I'm trying to add specific flags of chrome (flags that are found in "chrome://flags/") to the running of my browser in the tests.

    The flags I'm trying to enable are:

    • "#enable-webgl-draft-extensions"
    • "#shared-array-buffer"

    and to disable:

    • "#enable-asm-webassembly"

    In the regular chrome command line it looks like this:

    "--flag-switches-begin --enable-webgl-draft-extensions --enable-features=SharedArrayBuffer --disable-features=AsmJsToWebAssembly --flag-switches-end"
    

    If i add these criteria in

    puppeteer.launch({args});
    

    I receive them before the "--flag-switches-begin" line (I'm watching the command that chrome was ran with in: "chrome://version").

    Thank you very much!

  • Matthew
    Matthew over 3 years
    "You can launch Chromium, switch your flag and then go "chrome://version/", to see what has changed in the command line." BRILLIANT! Thank you. It looks like some of the possible command line directives for controlling flags are not documented. But using this method you can figure out what they are. (Note: you have to relaunch the browser after changing the flag to update the chrome://version page).