2022-10-06 13:45:22 +00:00
|
|
|
#!/usr/bin/env bash
|
2020-04-22 14:33:36 +00:00
|
|
|
set -e
|
|
|
|
|
2022-05-09 11:17:24 +00:00
|
|
|
# All tests are headed by a echo 'Test'.
|
|
|
|
# The general schema is:
|
|
|
|
# 1. Check we can install from the tarball.
|
|
|
|
# 2. The install script works and correctly exits without errors
|
|
|
|
# 3. Requiring/importing Puppeteer from Node works.
|
|
|
|
|
2022-10-06 13:45:22 +00:00
|
|
|
# MacOS doesn't support realpath
|
|
|
|
realpath() {
|
|
|
|
[[ $1 = /* ]] && echo "$1" || echo "$PWD/${1#./}"
|
|
|
|
}
|
|
|
|
|
2020-06-29 15:13:24 +00:00
|
|
|
ROOTDIR="$(pwd)"
|
2022-10-06 13:45:22 +00:00
|
|
|
if [[ -z $(realpath puppeteer-[0-9]*.tgz) ]]; then
|
|
|
|
npm pack --workspaces
|
|
|
|
fi
|
2022-10-05 12:17:03 +00:00
|
|
|
puppeteer_tarball=$(realpath puppeteer-[0-9]*.tgz)
|
|
|
|
puppeteer_core_tarball=$(realpath puppeteer-core-*.tgz)
|
|
|
|
|
|
|
|
echo "Puppeteer Core Test Suite"
|
|
|
|
|
|
|
|
echo "Testing... CommonJS"
|
|
|
|
TMPDIR="$(mktemp -d)"
|
|
|
|
cd $TMPDIR
|
|
|
|
npm install --loglevel silent "${puppeteer_core_tarball}"
|
|
|
|
node --eval="require('puppeteer-core')"
|
|
|
|
node --eval="require('puppeteer-core/lib/cjs/puppeteer/revisions.js');"
|
|
|
|
|
|
|
|
echo "Testing... ES Modules"
|
|
|
|
TMPDIR="$(mktemp -d)"
|
|
|
|
cd $TMPDIR
|
|
|
|
echo '{"type":"module"}' >>$TMPDIR/package.json
|
|
|
|
npm install --loglevel silent "${puppeteer_core_tarball}"
|
|
|
|
node --input-type="module" --eval="import puppeteer from 'puppeteer-core'"
|
|
|
|
node --input-type="module" --eval="import 'puppeteer-core/lib/esm/puppeteer/revisions.js';"
|
|
|
|
|
|
|
|
echo "Testing...launch with executablePath"
|
|
|
|
TMPDIR="$(mktemp -d)"
|
|
|
|
cd "$TMPDIR"
|
|
|
|
echo '{"type":"module"}' >>"$TMPDIR/package.json"
|
|
|
|
npm install --loglevel silent "${puppeteer_core_tarball}"
|
|
|
|
# The test tries to launch the node process because
|
|
|
|
# real browsers are not downloaded by puppeteer-core.
|
|
|
|
# The expected error is "Failed to launch the browser process"
|
|
|
|
# so the test verifies that it does not fail for other reasons.
|
|
|
|
node --input-type="module" --eval="
|
|
|
|
import puppeteer from 'puppeteer-core';
|
|
|
|
(async () => {
|
|
|
|
puppeteer.launch({
|
|
|
|
product: 'firefox',
|
|
|
|
executablePath: 'node'
|
|
|
|
}).catch(error => error.message.includes('Failed to launch the browser process') ? process.exit(0) : process.exit(1));
|
|
|
|
})();
|
|
|
|
"
|
|
|
|
node --input-type="module" --eval="
|
|
|
|
import puppeteer from 'puppeteer-core';
|
|
|
|
(async () => {
|
|
|
|
puppeteer.launch({
|
|
|
|
product: 'chrome',
|
|
|
|
executablePath: 'node'
|
|
|
|
}).catch(error => error.message.includes('Failed to launch the browser process') ? process.exit(0) : process.exit(1));
|
|
|
|
})();
|
|
|
|
"
|
|
|
|
|
|
|
|
echo "Puppeteer Test Suite"
|
2022-05-09 11:17:24 +00:00
|
|
|
|
|
|
|
echo "Testing... Chrome CommonJS"
|
2020-06-25 13:24:46 +00:00
|
|
|
TMPDIR="$(mktemp -d)"
|
|
|
|
cd $TMPDIR
|
2022-10-05 12:17:03 +00:00
|
|
|
npm install --loglevel silent $puppeteer_core_tarball $puppeteer_tarball
|
2020-04-22 14:33:36 +00:00
|
|
|
node --eval="require('puppeteer')"
|
2022-10-11 11:20:45 +00:00
|
|
|
ls ~/.cache/puppeteer/chrome
|
2022-02-09 07:47:27 +00:00
|
|
|
|
2022-05-09 11:17:24 +00:00
|
|
|
echo "Testing... Chrome ES Modules"
|
|
|
|
TMPDIR="$(mktemp -d)"
|
|
|
|
cd $TMPDIR
|
|
|
|
echo '{"type":"module"}' >>$TMPDIR/package.json
|
2022-10-05 12:17:03 +00:00
|
|
|
npm install --loglevel silent $puppeteer_core_tarball $puppeteer_tarball
|
2022-05-09 11:17:24 +00:00
|
|
|
node --input-type="module" --eval="import puppeteer from 'puppeteer'"
|
|
|
|
node --input-type="module" --eval="
|
|
|
|
import puppeteer from 'puppeteer';
|
|
|
|
(async () => {
|
|
|
|
const browser = await puppeteer.launch();
|
|
|
|
const page = await browser.newPage();
|
|
|
|
await page.goto('http://example.com');
|
|
|
|
await page.screenshot({ path: 'example.png' });
|
|
|
|
await browser.close();
|
|
|
|
})();
|
|
|
|
"
|
|
|
|
|
2022-06-09 17:00:50 +00:00
|
|
|
echo "Testing... Chrome ES Modules Destructuring"
|
|
|
|
TMPDIR="$(mktemp -d)"
|
|
|
|
cd $TMPDIR
|
|
|
|
echo '{"type":"module"}' >>$TMPDIR/package.json
|
2022-10-05 12:17:03 +00:00
|
|
|
npm install --loglevel silent $puppeteer_core_tarball $puppeteer_tarball
|
2022-06-09 17:00:50 +00:00
|
|
|
node --input-type="module" --eval="import puppeteer from 'puppeteer'"
|
|
|
|
node --input-type="module" --eval="
|
|
|
|
import { launch } from 'puppeteer';
|
|
|
|
(async () => {
|
|
|
|
const browser = await launch();
|
|
|
|
const page = await browser.newPage();
|
|
|
|
await page.goto('http://example.com');
|
|
|
|
await page.screenshot({ path: 'example.png' });
|
|
|
|
await browser.close();
|
|
|
|
})();
|
|
|
|
"
|
|
|
|
|
2022-05-09 11:17:24 +00:00
|
|
|
echo "Testing... Chrome Webpack ES Modules"
|
|
|
|
TMPDIR="$(mktemp -d)"
|
|
|
|
cd $TMPDIR
|
|
|
|
echo '{"type": "module"}' >>$TMPDIR/package.json
|
2022-10-05 12:17:03 +00:00
|
|
|
npm install --loglevel silent $puppeteer_core_tarball $puppeteer_tarball
|
2022-05-09 11:17:24 +00:00
|
|
|
npm install -D --loglevel silent webpack webpack-cli@4.9.2
|
|
|
|
echo 'export default {
|
|
|
|
mode: "production",
|
|
|
|
entry: "./index.js",
|
|
|
|
target: "node",
|
|
|
|
output: {
|
|
|
|
filename: "bundle.cjs",
|
|
|
|
},
|
|
|
|
};' >>$TMPDIR/webpack.config.js
|
|
|
|
echo "
|
|
|
|
import puppeteer from 'puppeteer';
|
|
|
|
(async () => {
|
|
|
|
const browser = await puppeteer.launch();
|
|
|
|
const page = await browser.newPage();
|
|
|
|
await page.goto('http://example.com');
|
2022-09-21 08:16:54 +00:00
|
|
|
await page.\$('aria/example');
|
2022-05-09 11:17:24 +00:00
|
|
|
await page.screenshot({ path: 'example.png' });
|
|
|
|
await browser.close();
|
|
|
|
})();
|
|
|
|
" >>$TMPDIR/index.js
|
|
|
|
npx webpack
|
2022-10-11 11:20:45 +00:00
|
|
|
cp -r ~/.cache/puppeteer/chrome .
|
2022-05-09 11:17:24 +00:00
|
|
|
rm -rf node_modules
|
|
|
|
node dist/bundle.cjs
|
|
|
|
|
|
|
|
echo "Testing... Firefox CommonJS"
|
2020-06-03 14:00:08 +00:00
|
|
|
TMPDIR="$(mktemp -d)"
|
|
|
|
cd $TMPDIR
|
2022-10-05 12:17:03 +00:00
|
|
|
PUPPETEER_PRODUCT=firefox npm install --loglevel silent $puppeteer_core_tarball $puppeteer_tarball
|
2020-06-03 14:00:08 +00:00
|
|
|
node --eval="require('puppeteer')"
|
2022-10-11 11:20:45 +00:00
|
|
|
ls ~/.cache/puppeteer/firefox
|
2020-06-29 15:13:24 +00:00
|
|
|
|
2022-05-09 11:17:24 +00:00
|
|
|
echo "Testing... Firefox ES Modules"
|
|
|
|
TMPDIR="$(mktemp -d)"
|
|
|
|
cd $TMPDIR
|
|
|
|
echo '{"type":"module"}' >>$TMPDIR/package.json
|
2022-10-05 12:17:03 +00:00
|
|
|
PUPPETEER_PRODUCT=firefox npm install --loglevel silent $puppeteer_core_tarball $puppeteer_tarball
|
2022-05-09 11:17:24 +00:00
|
|
|
node --input-type="module" --eval="import puppeteer from 'puppeteer'"
|
2022-10-11 11:20:45 +00:00
|
|
|
ls ~/.cache/puppeteer/firefox
|