Run chrome with ease from node.
- Support OSX Linux Windows system
- Handle chrome unexpected exit and restart it
- Opens up the browser's
remote-debugging-port
on an available port - Automatic locates a Chrome binary to launch
- Uses a fresh Chrome profile for each launch, and cleans itself up on
kill()
- Support typescript
const {Runner,launch,launchWithoutNoise,launchWithHeadless} = require('chrome-runner');
// launch a chrome, launch return a Runner instance
const runner = await launch();
// read chrome remote debugging port
runner.port;
// kill this chrome
await runner.kill();
launch()
method can pass options by launch({name:value})
. Include:
port
: {number} launch chrome listen on debug port, default will random a free port to usechromePath
: {string} chrome executable full path, default will automatic find a path according to your system. If no executable chrome find, will use env CHROME_PATH as executable full path. If all of the above way can't get a path a Error('no chrome installations found') will throwchromeFlags
: {Array} flags pass to chrome when start chrome, all flags can be find herestartupPage
: {string} open page when chrome start, default isabout:blank
shouldRestartChrome
: {boole} logger to handle log from chrome-runner, interface like console, default use consolemonitorInterval
: {number} in ms, monitor chrome is alive interval, default is 500mschromeDataDir
: {string} chrome data dir, default will create one in system tmpdisableLogging
: {boolean} Controls if Chome stdout and stderr is logged to file, default istrue
.
runner.port
: get chrome remove debug portrunner.kill()
: kill chrome and release all resource and remove temp files
Runner extends EventEmitter, it will emit some events in it's lifecycle, Include:
chromeAlive(port)
: when monitor detect chrome is alivechromeDead(code, signal)
: after monitor detect chrome is not alivechromeRestarted()
: after chrome unexpected exited then runner restart itchromeDataDirPrepared(chromeDataDir)
: after runner create data dir for chromechromeDataDirRemoved(chromeDataDir)
: after remove successful create data dir for chrome
launchWithoutNoise
same with launch
but disables many chrome services that add noise to automated scenarios.
launchWithHeadless
same with launch
but run chrome in headless mode and without noise.
more use case see unit test, API detail see d.ts
After chrome launched, chrome's log and pid file will be pipe to file in chromeDataDir
, Include:
chrome-out.log
chrome info logchrome-err.log
chrome error logchrome.pid
chrome pid file
chrome-runner required chrome installed on your system, it easy to install on OSX and Windows, Linux server see How to install Chrome browser properly via command line?
chrome-runner has been used in many project, e.g:
- chrome-render general server render base on chrome
- chrome-pool headless chrome tabs manage pool
- koa-seo SEO middleware for koa base on chrome-render, a substitute for prerender
- chrome-tester web page automatic tester