Skip to content
thumbs-up

GitHub Action

Puppeteer Headful for Chrome Extension Testing

v1 Latest version

Puppeteer Headful for Chrome Extension Testing

thumbs-up

Puppeteer Headful for Chrome Extension Testing

A GitHub Action / Docker image for testing Chrome extensions using Puppeteer and Node on a Headful instance of Chromium

Installation

Copy and paste the following snippet into your .yml file.

              

- name: Puppeteer Headful for Chrome Extension Testing

uses: djp3/puppeteer-headful@v1

Learn more about this action in djp3/puppeteer-headful

Choose a version

Puppeteer Headful for Chrome Extension Testing

Github Action for Puppeteer that can be ran "headful", or not headless, on a Chromium instance.

Versioning of this container is based on the version of NodeJS in the container

Purpose

This container is available as a Github Action to allow Chrome Extension testing which is not possible in a headless Puppeteer configuration.

Usage

This installs Puppeteer on top of a NodeJS container so you have access to run npm scripts using args. For this hook we hijack the entrypoint of the Dockerfile so we can startup Xvfb before your testing starts.

name: Puppeteer Headful CI
on: push
jobs:
  end_to_end_tests:
    name: Run Headful End-to-End Tests 
    runs-on: ubuntu-latest
    env:
      CI: 'true'
    steps:
    - name: Check out code
      uses: actions/checkout@v2
    - name: Install node 
      uses: actions/setup-node@v2-beta
      with:
        node-version: 12.x
    - name: Install stuff 
      run: npm install 
      env:
        PUPPETEER_SKIP_CHROMIUM_DOWNLOAD: 'true'
    - name: Run headful puppeteer tests
      uses: djp3/puppeteer-headful@master
      with:
        args: npm test

Note: You will need to let Puppeteer know not to download Chromium. By setting the env of your install task to PUPPETEER_SKIP_CHROMIUM_DOWNLOAD = 'true' so it does not install conflicting versions of Chromium.

Then you will need to change the way you launch Puppeteer. The code exports an ENV variable PUPPETEER_EXEC_PATH that you set at your executablePath. This should be undefined locally so it should function perfectly fine locally and on the action.

Below is the minimal bit needed to get a chromium instance launched with the extension for testing. More complete example at: Witness Chrome Extension

	browser = await puppeteer.launch({
		executablePath: process.env.PUPPETEER_EXEC_PATH, 	// set by docker container in github CI environment
		headless: false, 									// extension are allowed only in headful mode
		args: [
			`--no-sandbox`,									//Required for this to work in github CI environment 
			`--disable-extensions-except=${extensionPath}`,
			`--load-extension=${extensionPath}`
		]
        ...
	});