chore: improve docs and scripts (#9107)

This PR updates some docs and scripts related to the recent changes in
the repository.
This commit is contained in:
jrandolf 2022-10-13 18:55:11 +02:00 committed by GitHub
parent 1fbc3c643f
commit 6a05d8e9c1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
11 changed files with 174 additions and 201 deletions

View File

@ -134,10 +134,8 @@ jobs:
node-version: latest node-version: latest
- name: Install dependencies - name: Install dependencies
run: npm ci --ignore-scripts run: npm ci --ignore-scripts
- name: Build libraries - name: Build packages
run: npm run build run: npm run build
- name: Build tests
run: npm run build:test
- name: Setup cache for Chromium binary - name: Setup cache for Chromium binary
uses: actions/cache@v3 uses: actions/cache@v3
with: with:
@ -149,7 +147,7 @@ jobs:
if: ${{ matrix.os == 'ubuntu-latest' }} if: ${{ matrix.os == 'ubuntu-latest' }}
run: sudo apt-get install xvfb run: sudo apt-get install xvfb
- name: Tests types - name: Tests types
run: npm run test:types run: npm run test-types
- name: Run all tests (for non-Linux) - name: Run all tests (for non-Linux)
if: ${{ matrix.os != 'ubuntu-latest' }} if: ${{ matrix.os != 'ubuntu-latest' }}
run: npm run test -- --test-suite ${{ matrix.suite }} run: npm run test -- --test-suite ${{ matrix.suite }}
@ -177,10 +175,8 @@ jobs:
node-version: latest node-version: latest
- name: Install dependencies - name: Install dependencies
run: npm ci --ignore-scripts run: npm ci --ignore-scripts
- name: Build libraries - name: Build packages
run: npm run build run: npm run build
- name: Build tests
run: npm run build:test
- name: Setup cache for Firefox binary - name: Setup cache for Firefox binary
uses: actions/cache@v3 uses: actions/cache@v3
with: with:
@ -193,7 +189,7 @@ jobs:
- name: Install linux dependencies. - name: Install linux dependencies.
run: sudo apt-get install xvfb run: sudo apt-get install xvfb
- name: Tests types - name: Tests types
run: npm run test:types run: npm run test-types
- name: Run all tests - name: Run all tests
run: xvfb-run --auto-servernum npm run test -- --test-suite ${{ matrix.suite }} run: xvfb-run --auto-servernum npm run test -- --test-suite ${{ matrix.suite }}
@ -247,7 +243,7 @@ jobs:
with: with:
name: packages name: packages
- name: Test bundling and installation - name: Test bundling and installation
run: npm run test:install run: npm run test-install
docker-tests: docker-tests:
name: Test Docker image name: Test Docker image

View File

@ -43,7 +43,7 @@ jobs:
echo "Installing revision $REV" echo "Installing revision $REV"
cat src/revisions.ts | sed "s/[0-9]\{6,\}/$REV/" > src/revisions.ts.replaced cat src/revisions.ts | sed "s/[0-9]\{6,\}/$REV/" > src/revisions.ts.replaced
mv src/revisions.ts.replaced src/revisions.ts mv src/revisions.ts.replaced src/revisions.ts
npm run build:test npm run build
npm install npm install
- name: Run unit tests in headless - name: Run unit tests in headless
@ -81,7 +81,7 @@ jobs:
echo "Installing revision $REV" echo "Installing revision $REV"
cat src/revisions.ts | sed "s/[0-9]\{6,\}/$REV/" > src/revisions.ts.replaced cat src/revisions.ts | sed "s/[0-9]\{6,\}/$REV/" > src/revisions.ts.replaced
mv src/revisions.ts.replaced src/revisions.ts mv src/revisions.ts.replaced src/revisions.ts
npm run build:test npm run build
npm install npm install
- name: Run unit tests in headful - name: Run unit tests in headful
@ -119,7 +119,7 @@ jobs:
echo "Installing revision $REV" echo "Installing revision $REV"
cat src/revisions.ts | sed "s/[0-9]\{6,\}/$REV/" > src/revisions.ts.replaced cat src/revisions.ts | sed "s/[0-9]\{6,\}/$REV/" > src/revisions.ts.replaced
mv src/revisions.ts.replaced src/revisions.ts mv src/revisions.ts.replaced src/revisions.ts
npm run build:test npm run build
npm install npm install
- name: Run unit tests in chrome headless - name: Run unit tests in chrome headless

View File

@ -16,7 +16,7 @@ export declare class Keyboard
For finer control, you can use [Keyboard.down()](./puppeteer.keyboard.down.md), [Keyboard.up()](./puppeteer.keyboard.up.md), and [Keyboard.sendCharacter()](./puppeteer.keyboard.sendcharacter.md) to manually fire events as if they were generated from a real keyboard. For finer control, you can use [Keyboard.down()](./puppeteer.keyboard.down.md), [Keyboard.up()](./puppeteer.keyboard.up.md), and [Keyboard.sendCharacter()](./puppeteer.keyboard.sendcharacter.md) to manually fire events as if they were generated from a real keyboard.
On MacOS, keyboard shortcuts like `⌘ A` -> Select All do not work. See [\#1313](https://github.com/puppeteer/puppeteer/issues/1313). On macOS, keyboard shortcuts like `⌘ A` -> Select All do not work. See [\#1313](https://github.com/puppeteer/puppeteer/issues/1313).
The constructor for this class is marked as internal. Third-party code should not call the constructor directly or create subclasses that extend the `Keyboard` class. The constructor for this class is marked as internal. Third-party code should not call the constructor directly or create subclasses that extend the `Keyboard` class.

View File

@ -19,45 +19,78 @@ You generally only need to submit a CLA once, so if you've already submitted one
(even if it was for a different project), you probably don't need to do it (even if it was for a different project), you probably don't need to do it
again. again.
## Getting Code ## Getting started
1. Clone this repository 1. Clone this repository
```bash ```sh
git clone https://github.com/puppeteer/puppeteer git clone https://github.com/puppeteer/puppeteer
cd puppeteer cd puppeteer
``` ```
2. Install the dependencies 2. Install the dependencies
```bash ```sh
npm install npm install # or PUPPETEER_PRODUCT=firefox npm install
# Downloads the Firefox binary for Firefox tests
PUPPETEER_PRODUCT=firefox npm install
``` ```
## Building Puppeteer 3. Build all packages
Puppeteer has two configurations for building: ```sh
npm run build
- `npm run build` (or `npm run build:prod`) - Builds Puppeteer and artifacts
used in production.
- `npm run build:test` - Builds Puppeteer, test runner, tests, and artifacts used in
production.
## Testing Puppeteer
For browser testing, you can run
```bash
npm run build:test && npm run test
``` ```
We also have other tests such as `test:types` that tests types and 4. Run all tests
`test:install` which tests installation. See the `package.json` for more tests
(all prefixed with `test`).
Puppeteer is using a custom test runner on top of Mocha that consults ```sh
npm test
```
### macOS ARM and custom executables.
- To run experimental Chromium macOS ARM tests, firstly ensure you have correct Chromium version installed locally (you only need to do this once, not on every test run) and then you can run the tests:
```bash
PUPPETEER_EXPERIMENTAL_CHROMIUM_MAC_ARM=1 npm install
PUPPETEER_EXPERIMENTAL_CHROMIUM_MAC_ARM=1 npm run test
```
- To run tests with custom browser executable:
```bash
BINARY=<path-to-chrome/firefox-executable> npm run test:chrome # Or npm run test:firefox
```
## Building a single package
To build a single package, you can run
```sh
npm run build --workspace <package> # e.g. puppeteer
```
This will build all dependent packages automatically, so specifying a single packages is sufficient. This is all possible due to [wireit](https://github.com/google/wireit) which behaves similar to [GNU Make](https://www.gnu.org/software/make/).
## Removing stale artifacts
It's possible some generated artifacts (such as `packages/puppeteer-core/src/types.ts`) can become stale since these artifacts rely on complex conditions (such as names of distinct files) that cannot be captured by the build system. To clean artifacts, you can run
```sh
npm run clean # or npm run clean --workspace <package>
```
## Comprehensive testing
Outside of `npm test`, there are several other [`npm` scripts](https://docs.npmjs.com/cli/v8/using-npm/scripts) that are usually check through CI:
- `test-install` - Tests whether `puppeteer` and `puppeteer-core` install properly and are functional.
- `test-types` - Tests the TypeScript types in `puppeteer` using [`tsd`](https://github.com/SamVerschueren/tsd).
- `test:chrome:**` - Tests `puppeteer` on Chromium.
- `test:firefox:**` - Tests `puppeteer` on Firefox.
The default `npm test` runs `test:{chrome,firefox}:headless` which is generally sufficient.
Puppeteer uses a custom test runner on top of Mocha that consults
the [TestExpectations.json](https://github.com/puppeteer/puppeteer/blob/main/test/TestExpectations.json) the [TestExpectations.json](https://github.com/puppeteer/puppeteer/blob/main/test/TestExpectations.json)
to see if a given test result is expected or not. See more info about the test runner in [`tools/mochaRunner`](https://github.com/puppeteer/puppeteer/tree/main/tools/mochaRunner). to see if a given test result is expected or not. See more info about the test runner in [`tools/mochaRunner`](https://github.com/puppeteer/puppeteer/tree/main/tools/mochaRunner).
@ -94,38 +127,11 @@ npm run format
The following is a description of the primary folders in Puppeteer: The following is a description of the primary folders in Puppeteer:
- `src` - contains the source code for Puppeteer. - `packages` contains all public source code.
- `test/src` - contains the source code for Puppeteer tests. - `test` contains all test source code.
- `utils`/`scripts` - contains various scripts.
- `tools/testserver` - contains the source code for our test servers in testing.
- `tools/mochaRunner` - contains the source code for our test runner.
- `compat` - contains code separated by module import type. See [`compat/README.md`](https://github.com/puppeteer/puppeteer/blob/main/compat/README.md) for details.
- `test-d` contains type tests using [`tsd`](https://github.com/SamVerschueren/tsd). - `test-d` contains type tests using [`tsd`](https://github.com/SamVerschueren/tsd).
- `third_party` contains all dependencies that we vendor into the final build. See the [`third_party/README.md`](https://github.com/puppeteer/puppeteer/blob/main/third_party/README.md) for details. - `tools` contains miscellaneous scripts that are used in building and etc.
- `tools/mochaRunner` - contains the source code for our test runner.
### Shipping CJS and ESM bundles
Puppeteer ships both CommonJS and ES modules, therefore we maintain two `tsconfig` files for each project: `tsconfig.esm.json` and `tsconfig.cjs.json`. At build time we compile twice, once for CommonJS and once for ES modules.
We compile into the `lib` directory which is what we publish on the npm repository and it's structured like so:
```
lib
- cjs
- puppeteer <== the output of compiling `src/tsconfig.cjs.json`
- third_party <== the output of compiling `third_party/tsconfig.cjs.json`
- esm
- puppeteer <== the output of compiling `src/tsconfig.esm.json`
- third_party <== the output of compiling `third_party/tsconfig.json`
```
### `tsconfig.json` for the tests
We also maintain `test/tsconfig.json`. This is used to incrementally compile the unit test `*.spec.ts` files. Tests are run against the compiled code we ship to users so it gives us more confidence in our compiled output being correct.
### Root `tsconfig.json`
The root `tsconfig.json` exists for the API Extractor; it has to find a `tsconfig.json` in the project's root directory.
## API guidelines ## API guidelines
@ -135,7 +141,7 @@ When authoring new API methods, consider the following:
- Methods are used in favor of getters/setters. - Methods are used in favor of getters/setters.
- The only exception is namespaces, e.g. `page.keyboard` and `page.coverage` - The only exception is namespaces, e.g. `page.keyboard` and `page.coverage`
- All string literals must be small case. This includes event names and option values. - All string literals must be small case. This includes event names and option values.
- Avoid adding "sugar" API (API that is trivially implementable in user-space) unless they're **very** demanded. - Avoid adding "sugar" API (API that is trivially implementable in user-space) unless they're **extremely** demanded.
## Commit messages ## Commit messages
@ -168,7 +174,7 @@ Each change to Puppeteer should be thoroughly documented using TSDoc comments. R
## Running the documentation site locally ## Running the documentation site locally
1. At root, install all dependencies with `npm i`. 1. At root, install all dependencies with `npm i --ignore-scripts`.
2. run `npm run docs` which will generate all the `.md` files on `puppeteer/docs/api`. 2. run `npm run docs` which will generate all the `.md` files on `puppeteer/docs/api`.
3. run `npm i` in `puppeteer/website`. 3. run `npm i` in `puppeteer/website`.
4. run `npm start` in `puppeteer/website`. 4. run `npm start` in `puppeteer/website`.
@ -186,70 +192,13 @@ A barrier for introducing new installation dependencies is especially high:
There are additional considerations for dependencies that are environment agonistic. See the [`third_party/README.md`](https://github.com/puppeteer/puppeteer/blob/main/third_party/README.md) for details. There are additional considerations for dependencies that are environment agonistic. See the [`third_party/README.md`](https://github.com/puppeteer/puppeteer/blob/main/third_party/README.md) for details.
## Running & Writing Tests ## Testing tips
- Every feature should be accompanied by a test. - Every feature should be accompanied by a test.
- Every public api event/method should be accompanied by a test. - Every public api event/method should be accompanied by a test.
- Tests should not depend on external services. - Tests should not depend on external services.
- Tests should work on all three platforms: Mac, Linux and Win. This is especially important for screenshot tests. - Tests should work on all three platforms: Mac, Linux and Win. This is especially important for screenshot tests.
Puppeteer tests are located in [the `test` directory](https://github.com/puppeteer/puppeteer/blob/main/test/) and are written using Mocha. See [`test/README.md`](https://github.com/puppeteer/puppeteer/blob/main/test/README.md) for more details.
The tests are making sure public API methods and events work as expected.
- To run all tests:
```bash
npm run test
```
- To run a specific test, substitute the `it` with `it.only`:
```ts
...
it.only('should work', async function({server, page}) {
const response = await page.goto(server.EMPTY_PAGE);
expect(response.ok).toBe(true);
});
```
- To disable a specific test, substitute the `it` with `it.skip`:
```ts
...
// Using "it.skip" to skip specific test
it.skip('should work', async function({server, page}) {
const response = await page.goto(server.EMPTY_PAGE);
expect(response.ok).toBe(true);
});
```
- To run Chrome tests in non-headless mode:
```bash
npm run test:chrome:headful
```
- To run Firefox tests, firstly ensure you have Firefox installed locally (you only need to do this once, not on every test run) and then you can run the tests:
```bash
PUPPETEER_PRODUCT=firefox npm install
npm run test:firefox
```
- To run experimental Chromium MacOS ARM tests, firstly ensure you have correct Chromium version installed locally (you only need to do this once, not on every test run) and then you can run the tests:
```bash
PUPPETEER_EXPERIMENTAL_CHROMIUM_MAC_ARM=1 npm install
PUPPETEER_EXPERIMENTAL_CHROMIUM_MAC_ARM=1 npm run test:chrome:headless
```
- To run tests with custom browser executable:
```bash
BINARY=<path-to-executable> npm run test:chrome:headless # Or npm run test:firefox
```
If a test is expected to fail on certain configurations or became flaky, update [TestExpectations.json](https://github.com/puppeteer/puppeteer/blob/main/test/TestExpectations.json) If a test is expected to fail on certain configurations or became flaky, update [TestExpectations.json](https://github.com/puppeteer/puppeteer/blob/main/test/TestExpectations.json)
to reflect that. See more info about TestExpectations.json in [`tools/mochaRunner`](https://github.com/puppeteer/puppeteer/tree/main/tools/mochaRunner). to reflect that. See more info about TestExpectations.json in [`tools/mochaRunner`](https://github.com/puppeteer/puppeteer/tree/main/tools/mochaRunner).
@ -267,28 +216,25 @@ See [Debugging Tips](https://github.com/puppeteer/puppeteer/blob/main/README.md#
The following steps are needed to update the Chromium version. The following steps are needed to update the Chromium version.
1. Find a suitable Chromium revision 1. Find a suitable Chromium revision. Not all revisions have builds for all platforms, so we need to find one that does. The easiest way is to run `tools/check_availability.js -rd` to find the latest suitable `dev` Chromium revision (see `tools/check_availability.js -help` for more options).
Not all revisions have builds for all platforms, so we need to find one that does. 2. Update `packages/puppeteer-core/src/revisions.ts` with the found revision number.
To do so, run `tools/check_availability.js -rd` to find the latest suitable `dev` Chromium revision (see `tools/check_availability.js -help` for more options). 3. Update `versions.js` with the new Chromium-to-Puppeteer version mapping and update `lastMaintainedChromiumVersion` with the latest stable Chrome version.
1. Update `src/revisions.ts` with the found revision number. 4. Run `npm run check:protocol-revision`. If it fails, update `package.json` with the expected `devtools-protocol` version.
1. Update `versions.js` with the new Chromium-to-Puppeteer version mapping and update `lastMaintainedChromiumVersion` with the latest stable Chrome version. 5. Run `npm run build` and `npm install`.
1. Run `npm run check:protocol-revision`. 6. Run `npm test` and ensure that all tests pass. If a test fails, [bisect](#bisecting-upstream-changes) the upstream cause of the failure, and either update the test expectations accordingly (if it was an intended change) or work around the changes in Puppeteer (if its not desirable to change Puppeteers observable behavior).
If it fails, update `package.json` with the expected `devtools-protocol` version. 7. Commit and push your changes and open a pull request.
1. Run `npm run build && npm run build:test` and `npm install`.
1. Run `npm test` and ensure that all tests pass. If a test fails, [bisect](#bisecting-upstream-changes) the upstream cause of the failure, and either update the test expectations accordingly (if it was an intended change) or work around the changes in Puppeteer (if its not desirable to change Puppeteers observable behavior).
1. Commit and push your changes and open a pull request.
The commit message must contain the version in `Chromium <version> (<revision>)` format to ensure that [pptr.dev](https://pptr.dev/) can parse it correctly, e.g. `'feat(chromium): roll to Chromium 90.0.4427.0 (r856583)'`. The commit message must contain the version in `Chromium <version> (<revision>)` format to ensure that [pptr.dev](https://pptr.dev/) can parse it correctly, e.g. `'feat(chromium): roll to Chromium 90.0.4427.0 (r856583)'`.
### Bisecting upstream changes ### Bisecting upstream changes
Sometimes, performing a Chromium roll causes tests to fail. To figure out the cause, you need to bisect Chromium revisions to figure out the earliest possible revision that changed the behavior. The script in `tools/bisect.js` can be helpful here. Given a pattern for one or more unit tests, it will automatically bisect the current range: Sometimes, performing a Chromium roll causes tests to fail. To figure out the cause, you need to bisect Chromium revisions to figure out the earliest possible revision that changed the behavior. The `bisect` script can be helpful here. Given a pattern for one or more unit tests, it will automatically bisect the current range:
```sh ```sh
node tools/bisect.js --good 686378 --bad 706915 script.js npm run bisect -- --good 686378 --bad 706915 script.js
node tools/bisect.js --unit-test Response.fromCache npm run bisect -- --unit-test Response.fromCache
``` ```
By default, it will use the Chromium revision in `src/revisions.ts` from the `main` branch and from the working tree to determine the range to bisect. By default, it will use the Chromium revision in `packages/puppeteer-core/src/revisions.ts` from the `main` branch and from the working tree to determine the range to bisect.
## Releasing to npm ## Releasing to npm

18
package-lock.json generated
View File

@ -7,7 +7,8 @@
"name": "puppeteer-repo", "name": "puppeteer-repo",
"hasInstallScript": true, "hasInstallScript": true,
"workspaces": [ "workspaces": [
"packages/*" "packages/*",
"test"
], ],
"devDependencies": { "devDependencies": {
"@commitlint/cli": "17.1.2", "@commitlint/cli": "17.1.2",
@ -7033,6 +7034,10 @@
"node": ">=6" "node": ">=6"
} }
}, },
"node_modules/test": {
"resolved": "test",
"link": true
},
"node_modules/test-exclude": { "node_modules/test-exclude": {
"version": "6.0.0", "version": "6.0.0",
"resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz",
@ -7796,6 +7801,11 @@
"mime": "3.0.0", "mime": "3.0.0",
"ws": "8.9.0" "ws": "8.9.0"
} }
},
"test": {
"dependencies": {
"puppeteer": "file:../packages/puppeteer"
}
} }
}, },
"dependencies": { "dependencies": {
@ -12986,6 +12996,12 @@
"readable-stream": "^3.1.1" "readable-stream": "^3.1.1"
} }
}, },
"test": {
"version": "file:test",
"requires": {
"puppeteer": "file:../packages/puppeteer"
}
},
"test-exclude": { "test-exclude": {
"version": "6.0.0", "version": "6.0.0",
"resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz",

View File

@ -6,13 +6,13 @@
"url": "https://github.com/puppeteer/puppeteer" "url": "https://github.com/puppeteer/puppeteer"
}, },
"scripts": { "scripts": {
"build:test": "wireit", "bisect": "tsx tools/bisect.ts",
"build": "npm run build --workspaces --if-present", "build": "npm run build --workspaces --if-present",
"check:pinned-deps": "tsx tools/ensure-pinned-deps", "check:pinned-deps": "tsx tools/ensure-pinned-deps",
"check": "npm run check --workspaces --if-present && run-p check:*", "check": "npm run check --workspaces --if-present && run-p check:*",
"clean": "npm run clean --workspaces --if-present && rimraf **/.wireit", "clean": "npm run clean --workspaces --if-present && rimraf **/.wireit",
"commitlint": "commitlint --from=HEAD~1", "commitlint": "commitlint --from=HEAD~1",
"debug": "npm run build:test && mocha --inspect-brk", "debug": "mocha --inspect-brk",
"docs": "run-s build generate:markdown", "docs": "run-s build generate:markdown",
"format:eslint": "eslint --ext js --ext ts --fix .", "format:eslint": "eslint --ext js --ext ts --fix .",
"format:prettier": "prettier --write .", "format:prettier": "prettier --write .",
@ -23,35 +23,17 @@
"lint": "run-s lint:prettier lint:eslint", "lint": "run-s lint:prettier lint:eslint",
"postinstall": "npm run postinstall --workspaces --if-present", "postinstall": "npm run postinstall --workspaces --if-present",
"prepare": "husky install", "prepare": "husky install",
"test:chrome:headful": "npm run test -- --test-suite chrome-headful", "test-install": "test/test-install.sh",
"test:chrome:headless-chrome": "npm run test -- --test-suite chrome-new-headless", "test-types": "tsd -t packages/puppeteer",
"test:chrome:headless": "npm run test -- --test-suite chrome-headless", "test:chrome:headful": "npm test -- --test-suite chrome-headful",
"test:chrome:headless-chrome": "npm test -- --test-suite chrome-new-headless",
"test:chrome:headless": "npm test -- --test-suite chrome-headless",
"test:chrome": "run-s test:chrome:*", "test:chrome": "run-s test:chrome:*",
"test:firefox:headful": "npm run test -- --test-suite firefox-headful", "test:firefox:headful": "npm test -- --test-suite firefox-headful",
"test:firefox:headless": "npm run test -- --test-suite firefox-headless", "test:firefox:headless": "npm test -- --test-suite firefox-headless",
"test:firefox": "run-s test:firefox:*", "test:firefox": "run-s test:firefox:*",
"test:install": "test/test-install.sh",
"test:types": "tsd -t packages/puppeteer",
"test": "cross-env PUPPETEER_DEFERRED_PROMISE_DEBUG_TIMEOUT=20000 node tools/mochaRunner/lib/main.js" "test": "cross-env PUPPETEER_DEFERRED_PROMISE_DEBUG_TIMEOUT=20000 node tools/mochaRunner/lib/main.js"
}, },
"wireit": {
"build:test": {
"command": "tsc -b test",
"clean": "if-file-deleted",
"dependencies": [
"./packages/puppeteer:build",
"./packages/puppeteer-core:build",
"./packages/testserver:build"
],
"files": [
"test/src/**"
],
"output": [
"test/build/**",
"test/tsconfig.tsbuildinfo"
]
}
},
"devDependencies": { "devDependencies": {
"@commitlint/cli": "17.1.2", "@commitlint/cli": "17.1.2",
"@commitlint/config-conventional": "17.1.0", "@commitlint/config-conventional": "17.1.0",
@ -121,6 +103,7 @@
"zod": "3.19.1" "zod": "3.19.1"
}, },
"workspaces": [ "workspaces": [
"packages/*" "packages/*",
"test"
] ]
} }

View File

@ -35,7 +35,7 @@ type KeyDescription = Required<
* {@link Keyboard.up}, and {@link Keyboard.sendCharacter} * {@link Keyboard.up}, and {@link Keyboard.sendCharacter}
* to manually fire events as if they were generated from a real keyboard. * to manually fire events as if they were generated from a real keyboard.
* *
* On MacOS, keyboard shortcuts like `⌘ A` -\> Select All do not work. * On macOS, keyboard shortcuts like `⌘ A` -\> Select All do not work.
* See {@link https://github.com/puppeteer/puppeteer/issues/1313 | #1313}. * See {@link https://github.com/puppeteer/puppeteer/issues/1313 | #1313}.
* *
* @example * @example

27
test/package.json Normal file
View File

@ -0,0 +1,27 @@
{
"private": true,
"scripts": {
"build": "wireit",
"clean": "tsc -b --clean && rimraf build"
},
"wireit": {
"build": {
"command": "tsc -b",
"clean": "if-file-deleted",
"dependencies": [
"../packages/puppeteer:build",
"../packages/testserver:build"
],
"files": [
"src/**"
],
"output": [
"build/**",
"tsconfig.tsbuildinfo"
]
}
},
"dependencies": {
"puppeteer": "file:../packages/puppeteer"
}
}

View File

@ -7,7 +7,7 @@ set -e
# 2. The install script works and correctly exits without errors # 2. The install script works and correctly exits without errors
# 3. Requiring/importing Puppeteer from Node works. # 3. Requiring/importing Puppeteer from Node works.
# MacOS doesn't support realpath # macOS doesn't support realpath
realpath() { realpath() {
[[ $1 = /* ]] && echo "$1" || echo "$PWD/${1#./}" [[ $1 = /* ]] && echo "$1" || echo "$PWD/${1#./}"
} }

View File

@ -15,20 +15,22 @@
* limitations under the License. * limitations under the License.
*/ */
const URL = require('url'); import {execSync, fork, spawn} from 'child_process';
const debug = require('debug'); import debug from 'debug';
const pptr = require('..'); import fs from 'fs';
const browserFetcher = pptr.createBrowserFetcher(); import minimist from 'minimist';
const path = require('path'); import path from 'path';
const fs = require('fs'); import {BrowserFetcher, BrowserFetcherRevisionInfo} from 'puppeteer';
const {fork, spawn, execSync} = require('child_process'); import URL from 'url';
import ProgressBar from 'progress';
const COLOR_RESET = '\x1b[0m'; const COLOR_RESET = '\x1b[0m';
const COLOR_RED = '\x1b[31m'; const COLOR_RED = '\x1b[31m';
const COLOR_GREEN = '\x1b[32m'; const COLOR_GREEN = '\x1b[32m';
const COLOR_YELLOW = '\x1b[33m'; const COLOR_YELLOW = '\x1b[33m';
const argv = require('minimist')(process.argv.slice(2), {}); const argv = minimist(process.argv.slice(2), {});
const help = ` const help = `
Usage: Usage:
@ -88,9 +90,8 @@ if (!argv.script && !argv['unit-test']) {
process.exit(1); process.exit(1);
} }
const scriptPath = argv.script ? path.resolve(argv.script) : null; const scriptPath = argv.script && path.resolve(argv.script);
if (scriptPath && !fs.existsSync(scriptPath)) {
if (argv.script && !fs.existsSync(scriptPath)) {
console.log( console.log(
COLOR_RED + COLOR_RED +
'ERROR: Expected to be given a path to a script to run' + 'ERROR: Expected to be given a path to a script to run' +
@ -100,6 +101,8 @@ if (argv.script && !fs.existsSync(scriptPath)) {
process.exit(1); process.exit(1);
} }
const browserFetcher = new BrowserFetcher();
(async (scriptPath, good, bad, pattern, noCache) => { (async (scriptPath, good, bad, pattern, noCache) => {
const span = Math.abs(good - bad); const span = Math.abs(good - bad);
console.log( console.log(
@ -114,7 +117,8 @@ if (argv.script && !fs.existsSync(scriptPath)) {
if (!revision || revision === good || revision === bad) { if (!revision || revision === good || revision === bad) {
break; break;
} }
let info = browserFetcher.revisionInfo(revision); let info: BrowserFetcherRevisionInfo | undefined =
browserFetcher.revisionInfo(revision);
const shouldRemove = noCache && !info.local; const shouldRemove = noCache && !info.local;
info = await downloadRevision(revision); info = await downloadRevision(revision);
const exitCode = await (pattern const exitCode = await (pattern
@ -201,13 +205,12 @@ function runUnitTest(pattern, revisionInfo) {
async function downloadRevision(revision) { async function downloadRevision(revision) {
const log = debug('bisect:download'); const log = debug('bisect:download');
log(`Downloading ${revision}`); log(`Downloading ${revision}`);
let progressBar = null; let progressBar: ProgressBar | undefined;
let lastDownloadedBytes = 0; let lastDownloadedBytes = 0;
return await browserFetcher.download( return await browserFetcher.download(
revision, revision,
(downloadedBytes, totalBytes) => { (downloadedBytes, totalBytes) => {
if (!progressBar) { if (!progressBar) {
const ProgressBar = require('progress');
progressBar = new ProgressBar( progressBar = new ProgressBar(
`- downloading Chromium r${revision} - ${toMegabytes( `- downloading Chromium r${revision} - ${toMegabytes(
totalBytes totalBytes
@ -269,15 +272,18 @@ async function revisionToSha(revision) {
return json.git_sha; return json.git_sha;
} }
function fetchJSON(url) { async function fetchJSON(url: string): Promise<{git_sha: string}> {
return new Promise((resolve, reject) => {
const agent = url.startsWith('https://') const agent = url.startsWith('https://')
? require('https') ? await import('https')
: require('http'); : await import('http');
const options = URL.parse(url);
options.method = 'GET'; return new Promise((resolve, reject) => {
options.headers = { const options = {
...URL.parse(url),
method: 'GET',
headers: {
'Content-Type': 'application/json', 'Content-Type': 'application/json',
},
}; };
const req = agent.request(options, function (res) { const req = agent.request(options, function (res) {
let result = ''; let result = '';
@ -296,14 +302,13 @@ function fetchJSON(url) {
}); });
} }
function getChromiumRevision(gitRevision = null) { function getChromiumRevision(gitRevision?: string) {
const fileName = 'src/revisions.ts'; const fileName = 'packages/puppeteer-core/src/revisions.ts';
const command = gitRevision const command = gitRevision
? `git show ${gitRevision}:${fileName}` ? `git show ${gitRevision}:${fileName}`
: `cat ${fileName}`; : `cat ${fileName}`;
const result = execSync(command, { const result = execSync(command, {
encoding: 'utf8', encoding: 'utf8',
shell: true,
}); });
const m = result.match(/chromium: '(\d+)'/); const m = result.match(/chromium: '(\d+)'/);

View File

@ -53,8 +53,8 @@ For browser testing, you can run
npm run build:test && npm run test npm run build:test && npm run test
``` ```
We also have other tests such as `test:types` that tests types and We also have other tests such as `test-types` that tests types and
`test:install` which tests installation. See the `package.json` for more tests `test-install` which tests installation. See the `package.json` for more tests
(all prefixed with `test`). (all prefixed with `test`).
Puppeteer is using a custom test runner on top of Mocha that consults Puppeteer is using a custom test runner on top of Mocha that consults