Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Migrate to pnpm #3889

Merged
merged 24 commits into from
Sep 6, 2023
Merged
Show file tree
Hide file tree
Changes from 13 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 6 additions & 15 deletions .github/actions/install-dependencies/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,14 @@ description: "Install dependencies, fetching from cache when possible"
runs:
using: "composite"
steps:
- uses: pnpm/action-setup@v2
with:
version: 8
mrbbot marked this conversation as resolved.
Show resolved Hide resolved
- name: Use Node.js ${{ env.node-version }}
uses: actions/setup-node@v3
with:
node-version: ${{ env.node-version }}
cache: "npm" # cache ~/.npm in case 'npm ci' needs to run
cache: "pnpm"

- name: ESlint and Typescript caching
uses: actions/cache@v3
Expand All @@ -18,18 +21,6 @@ runs:
tsconfig.tsbuildinfo
key: ${{ matrix.os }}-eslint-tsbuildinfo-${{ hashFiles('**/*.ts','**/*.js', 'package.json', 'tsconfig.json') }}

# Attempt to cache all the node_modules directories based on the OS and package lock.
- name: Cache node_modules
id: npm-cache
uses: actions/cache@v3
env:
cache-name: cache-node-modules
with:
key: ${{ runner.os }}-${{ env.node-version }}-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
path: "**/node_modules"

# If the cache missed then install using `npm ci` to follow package lock exactly
- if: ${{ steps.npm-cache.outputs.cache-hit != 'true'}}
shell: bash
- shell: bash
penalosa marked this conversation as resolved.
Show resolved Hide resolved
name: Install NPM Dependencies
run: npm ci
run: pnpm install --frozen-lockfile
14 changes: 3 additions & 11 deletions .github/changeset-version.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,17 +2,9 @@ const { execSync } = require("node:child_process");

// This script is used by the `release.yml` workflow to update the version of the packages being released.
// The standard step is only to run `changeset version` but this does not update the package-lock.json file.
// So we also run `npm install`, which does this update.
// So we also run `pnpm install`, which does this update.
// This is a workaround until this is handled automatically by `changeset version`.
// See https://github.com/changesets/changesets/issues/421.
execSync("npx changeset version");
execSync("pnpm exec changeset version");

// HACK: run a newer version of npm that can update package-lock.json using local dependencies.
// See https://github.com/npm/cli/issues/4379 and https://github.com/npm/cli/pull/4371.
// The error looks like: `No matching version found for wrangler@^2.15.0.`
if (!process.version.startsWith("v16")) {
throw new Error(
"You have updated node version and so you must now remove the hack below!"
);
}
execSync("npx -y [email protected] install --package-lock-only");
execSync("pnpm install");
22 changes: 13 additions & 9 deletions .github/extract-runtime-versions.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import fs from "node:fs/promises";
import module from "node:module";
import path from "node:path";
import url from "node:url";
import { execSync } from "node:child_process";

/**
* @param {string} from
Expand Down Expand Up @@ -31,8 +32,10 @@ const wranglerVersion = wranglerPackage.version;
const miniflareVersionConstraint = wranglerPackage.dependencies.miniflare;

// 2. Load `miniflare` `package.json`, getting `miniflare` version and `workerd` version constraint
const wranglerRequire = module.createRequire(wranglerPackagePath);
const miniflareMainPath = wranglerRequire.resolve("miniflare");
const miniflareMainPath = path.resolve(
__dirname,
"../packages/wrangler/node_modules/miniflare"
);
mrbbot marked this conversation as resolved.
Show resolved Hide resolved
const miniflarePackageJsonPath = findClosestPackageJson(miniflareMainPath);
assert(miniflarePackageJsonPath !== undefined);
const miniflarePackagePath = path.dirname(miniflarePackageJsonPath);
Expand All @@ -45,13 +48,14 @@ const miniflareVersion = miniflarePackage.version;
const workerdVersionConstraint = miniflarePackage.dependencies.workerd;

// 3. Load `workerd` `package.json`, getting `workerd` version
const miniflareRequire = module.createRequire(miniflarePackagePath);
const workerdMainPath = miniflareRequire.resolve("workerd");
const workerdPackageJsonPath = findClosestPackageJson(workerdMainPath);
assert(workerdPackageJsonPath !== undefined);
const workerdPackageJson = await fs.readFile(workerdPackageJsonPath, "utf8");
const workerdPackage = JSON.parse(workerdPackageJson);
const workerdVersion = workerdPackage.version;
const workerdMainPath = path.resolve(
__dirname,
"../packages/wrangler/node_modules/miniflare/node_modules/.bin/workerd"
);

const workerdVersion = execSync(workerdMainPath + " --version")
.toString()
.split(" ")[1];
penalosa marked this conversation as resolved.
Show resolved Hide resolved

// 4. Write basic markdown report
const report = [
Expand Down
16 changes: 9 additions & 7 deletions .github/workflows/codecov-context.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,14 @@ jobs:
uses: actions/checkout@v3
with:
ref: main

- name: Use Node.js 16.13
- uses: pnpm/action-setup@v2
with:
version: 8
- name: Use Node.js 16.14
uses: actions/setup-node@v3
with:
node-version: 16.13
cache: "npm" # cache ~/.npm in case 'npm ci' needs to run
node-version: 16.14
cache: "pnpm"

- name: Install workerd Dependencies
if: ${{ runner.os == 'Linux' }}
Expand All @@ -30,15 +32,15 @@ jobs:
sudo apt-get install -y libc++1

- name: Install NPM Dependencies
run: npm ci
run: pnpm install --frozen-lockfile

- name: Build wrangler
run: npm run build
run: pnpm run build
env:
NODE_ENV: "production"

- name: Run tests & collect coverage
run: npm run test:ci -w wrangler
run: pnpm run --filter wrangler test:ci
env:
NODE_OPTIONS: "--max_old_space_size=8192"

Expand Down
20 changes: 11 additions & 9 deletions .github/workflows/create-pullrequest-prerelease.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,12 +13,14 @@ jobs:
uses: actions/checkout@v3
with:
fetch-depth: 0

- name: Use Node.js 16.13
- uses: pnpm/action-setup@v2
with:
version: 8
- name: Use Node.js 16.14
uses: actions/setup-node@v3
with:
node-version: 16.13
cache: "npm" # cache ~/.npm in case 'npm ci' needs to run
node-version: 16.14
cache: "pnpm"

- name: Install workerd Dependencies
if: ${{ runner.os == 'Linux' }}
Expand All @@ -28,7 +30,7 @@ jobs:
sudo apt-get install -y libc++1

- name: Install NPM Dependencies
run: npm ci
run: pnpm install --frozen-lockfile

- name: Extract runtime versions
run: node .github/extract-runtime-versions.mjs # extract versions before modifying version to include commit hash
Expand All @@ -43,14 +45,14 @@ jobs:
run: node .github/version-script.js

- name: Build
run: npm run build
run: pnpm run build
env:
NODE_ENV: "production"
ALGOLIA_APP_ID: ${{ secrets.ALGOLIA_APP_ID }}
ALGOLIA_PUBLIC_KEY: ${{ secrets.ALGOLIA_PUBLIC_KEY }}

- name: Pack wrangler
run: npm pack
run: pnpm pack
working-directory: packages/wrangler

- name: Upload packaged wrangler artifact
Expand All @@ -60,7 +62,7 @@ jobs:
path: packages/wrangler/wrangler-*.tgz

- name: Pack @cloudflare/pages-shared
run: npm pack
run: pnpm pack
working-directory: packages/pages-shared

- name: Upload packaged @cloudflare/pages-shared artifact
Expand All @@ -70,7 +72,7 @@ jobs:
path: packages/pages-shared/cloudflare-pages-shared-*.tgz

- name: Pack @cloudflare/create-cloudflare
run: npm pack
run: pnpm pack
working-directory: packages/create-cloudflare

- name: Upload packaged @cloudflare/create-cloudflare artifact
Expand Down
18 changes: 10 additions & 8 deletions .github/workflows/d1.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,14 @@ jobs:
uses: actions/checkout@v3
with:
fetch-depth: 0

- name: Use Node.js 16.13
- uses: pnpm/action-setup@v2
with:
version: 8
- name: Use Node.js 16.14
uses: actions/setup-node@v3
with:
node-version: 16.13
cache: "npm" # cache ~/.npm in case 'npm ci' needs to run
node-version: 16.14
cache: "pnpm"

- name: Install workerd Dependencies
if: ${{ runner.os == 'Linux' }}
Expand All @@ -30,21 +32,21 @@ jobs:
sudo apt-get install -y libc++1

- name: Install NPM Dependencies
run: npm ci
run: pnpm install --frozen-lockfile

- name: Build
run: npm run build
run: pnpm run build

- name: Check for errors
run: npm run check
run: pnpm run check
env:
NODE_OPTIONS: "--max_old_space_size=8192"

- name: Modify package.json version
run: node .github/version-script.js

- name: Publish to NPM
run: npm publish --tag d1
run: pnpm publish --tag d1
env:
NODE_ENV: "production"
NPM_PUBLISH_TOKEN: ${{ secrets.NPM_PUBLISH_TOKEN }}
Expand Down
10 changes: 6 additions & 4 deletions .github/workflows/devtools.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,13 @@ jobs:
uses: actions/checkout@v3
with:
fetch-depth: 0

- uses: pnpm/action-setup@v2
with:
version: 8
- name: Use Node.js
uses: actions/setup-node@v3
with:
cache: "npm" # cache ~/.npm in case 'npm ci' needs to run
cache: "pnpm"

- name: Install workerd Dependencies
if: ${{ runner.os == 'Linux' }}
Expand All @@ -32,10 +34,10 @@ jobs:
sudo apt-get install -y libc++1

- name: Install NPM Dependencies
run: npm ci
run: pnpm install --frozen-lockfile

- name: Build
run: npm run build
run: pnpm run build

- name: Run Devtools release & publish
run: cd packages/wrangler-devtools && make publish
Expand Down
42 changes: 17 additions & 25 deletions .github/workflows/e2e.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ jobs:
if: github.repository_owner == 'cloudflare' && (github.event_name != 'pull_request' || (github.event_name == 'pull_request' && contains(github.event.*.labels.*.name, 'e2e' )) || (github.event_name == 'pull_request' && github.head_ref == 'changeset-release/main'))
name: "E2E Test"
strategy:
fail-fast: false
petebacondarwin marked this conversation as resolved.
Show resolved Hide resolved
matrix:
os: [
# macos-11,
Expand All @@ -31,11 +32,14 @@ jobs:
uses: actions/checkout@v3
with:
fetch-depth: 0
- uses: pnpm/action-setup@v2
with:
version: 8
- name: Use Node.js ${{ matrix.node }}
uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node }}
cache: "npm"
cache: "pnpm"

- name: Install workerd Dependencies
if: ${{ runner.os == 'Linux' }}
Expand All @@ -44,55 +48,43 @@ jobs:
sudo apt-get update
sudo apt-get install -y libc++1

# Attempt to cache all the node_modules directories based on the OS and package lock.
- name: Cache node_modules
id: npm-cache
uses: actions/cache@v3
env:
cache-name: cache-node-modules
with:
key: ${{ runner.os }}-${{ matrix.node }}-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
path: "**/node_modules"

# If the cache missed then install using `npm ci` to follow package lock exactly
- if: ${{ steps.npm-cache.outputs.cache-hit != 'true'}}
- shell: bash
name: Install NPM Dependencies
run: npm ci
run: pnpm install --frozen-lockfile

- name: Run builds
run: npm run build
run: pnpm run build
env:
NODE_ENV: "production"

- name: Build Wrangler package for npm
run: cd packages/wrangler && npm pack
run: pnpm pack --pack-destination $HOME
env:
NODE_ENV: "production"
working-directory: packages/wrangler

- name: Move Wrangler package to tmp directory
- name: Find Wrangler
shell: bash
id: "move-wrangler"
run: |
cp packages/wrangler/wrangler-*.tgz $HOME
echo "dir=$(ls $HOME/wrangler-*.tgz)" >> $GITHUB_OUTPUT;
id: "find-wrangler"
run: echo "dir=$(ls $HOME/wrangler-*.tgz)" >> $GITHUB_OUTPUT;
env:
NODE_ENV: "production"

- name: Run tests
id: e2e-1
continue-on-error: true
run: npm run -w wrangler test:e2e
run: pnpm run --filter wrangler test:e2e
env:
CLOUDFLARE_API_TOKEN: ${{ secrets.TEST_CLOUDFLARE_API_TOKEN }}
CLOUDFLARE_ACCOUNT_ID: ${{ secrets.TEST_CLOUDFLARE_ACCOUNT_ID }}
WRANGLER: npm install ${{ steps.move-wrangler.outputs.dir}} && npx --prefer-offline wrangler
WRANGLER: pnpm --silent --package ${{ steps.find-wrangler.outputs.dir}} dlx wrangler
NODE_OPTIONS: "--max_old_space_size=8192"

- name: Retry tests
if: steps.e2e-1.outcome == 'failure'
run: npm run -w wrangler test:e2e
run: pnpm run --filter wrangler test:e2e
env:
CLOUDFLARE_API_TOKEN: ${{ secrets.TEST_CLOUDFLARE_API_TOKEN }}
CLOUDFLARE_ACCOUNT_ID: ${{ secrets.TEST_CLOUDFLARE_ACCOUNT_ID }}
WRANGLER: npm install ${{ steps.move-wrangler.outputs.dir}} && npx --prefer-offline wrangler
WRANGLER: pnpm --silent --package ${{ steps.find-wrangler.outputs.dir}} dlx wrangler
NODE_OPTIONS: "--max_old_space_size=8192"
Loading