44 Commits

Author SHA1 Message Date
187ace9a18 test: don't check pnpx 2022-02-10 01:18:35 +02:00
7f8a57faa8 test: update pnpm version 2022-02-10 01:16:10 +02:00
268b4179de Install the self-contained binary version of pnpm
This is a breaking change because the binary version of pnpm
is only available from v6.17.1

close #18
2022-02-10 01:13:09 +02:00
2270f39ef6 v2.1.0 2022-02-08 19:53:18 +07:00
394c848db6 Update the bundle 2022-02-08 19:50:57 +07:00
e13928ccc5 Merge pull request #27 from metonym/fix-jobs-syntax
Specify job name to fix syntax error
2022-02-08 19:48:36 +07:00
93bd5a123d Merge pull request #29 from pnpm/pnpm-v7
The pnpm home directory should be added to PATH and PNPM_HOME
2022-02-08 19:47:28 +07:00
9eb14dd77c decrease bundle size 2022-02-08 14:44:50 +02:00
eafb777c56 download script from pnpm.io 2022-02-08 00:39:20 +02:00
e6378df420 PNPM_HOME_PATH=>PNPM_HOME 2022-02-08 00:21:53 +02:00
6ff6e97bc6 The pnpm home directory should be added to PATH and PNPM_HOME
This change is needed to make the action compatible with pnpm v7.

Related breaking change in pnpm: pnpm/pnpm#4280
2022-02-07 23:15:44 +02:00
45d9c91ff6 Specify job name to fix syntax error 2022-01-29 08:17:29 -08:00
15569a497d Merge pull request #26 from ai/patch-1
Improve `version` docs
2021-12-16 21:20:06 +07:00
d70eebd14a Update README.md
Co-authored-by: Khải <hvksmr1996@gmail.com>
2021-12-16 17:18:46 +03:00
3bf8acf16f Improve version docs 2021-12-16 17:12:07 +03:00
3c2fe8c592 Merge pull request #21 from gaggle/patch-1
Spelling
2021-10-12 19:45:45 +07:00
76cc04cd5e Spelling 2021-10-12 13:34:10 +02:00
bcad811784 Remove unused env from examples 2021-07-24 08:25:23 +07:00
602b36f177 Remove uses of undefined variables from examples 2021-07-24 08:22:22 +07:00
74a0fdc1a4 Merge pull request #14 from Jack-Works-forks/master
Update README: use lockfile hash instead of package.json hash
2021-06-01 09:44:13 +07:00
493e98ec5e Update README.md 2021-06-01 10:42:26 +08:00
646cdf4821 Update versions in README examples to the latest 2021-04-24 21:13:36 +07:00
a1ba6cf5ae Merge pull request #11 from pnpm/zkochan-patch-1
docs(readme): PNPM=>pnpm
2021-03-27 18:50:58 +07:00
41b381a08b docs(readme): PNPM=>pnpm 2021-03-27 13:45:01 +02:00
3236b209b5 Merge branch 'v2' 2021-03-27 16:56:27 +07:00
2124926520 Update README.md 2021-03-23 12:53:37 +07:00
ba9826e81c Update test workflow 2021-03-23 12:53:25 +07:00
7c4472dbcf Forgot to specify working directory 2021-03-23 12:48:54 +07:00
0db7fb9961 Add .pnpm-store to .gitignore 2021-03-23 12:48:07 +07:00
aefcd1e623 Use pnpm.js to install pnpm 2021-03-23 12:42:43 +07:00
b7b9d6344b Instruct renovate to ignore ajv updates 2021-03-23 11:47:55 +07:00
7e61ea5847 Add "$schema" to renovate.json 2021-03-23 11:46:56 +07:00
3a2c7247e1 Fix js-yaml usage 2021-03-23 11:43:49 +07:00
2a105263a5 Update dependencies 2021-03-23 11:43:36 +07:00
9facd4db8e Merge pull request #9 from hildjj/cache-docs
Adds documentation hints for caching
2021-02-18 08:31:04 +07:00
6c1466d327 Make some tweaks to example code snippets 2021-02-18 08:30:07 +07:00
b26427e53e Adds documentation hints for caching. Fixes #8. 2021-02-17 09:45:25 -07:00
086f5bd3b6 Update README.md
close https://github.com/pnpm/action-setup/issues/6
2020-10-19 14:10:51 +07:00
bdb2a5ee76 Enable Dependabot 2020-10-05 22:16:14 +07:00
8e1abe543f Update dist/index.js 2020-10-05 21:51:43 +07:00
af6247d08a Fix https://github.com/pnpm/action-setup/issues/5 2020-10-05 21:45:45 +07:00
f87c8a916e Fix TypeScript error 2020-10-05 21:45:20 +07:00
d6790970e0 Update dependencies 2020-10-05 21:44:44 +07:00
fa62771e12 Add workflow_dispatch event 2020-08-27 08:25:30 +07:00
19 changed files with 634 additions and 544 deletions

10
.github/dependabot.yml vendored Normal file
View File

@ -0,0 +1,10 @@
version: 2
updates:
- package-ecosystem: github-actions
directory: "/"
schedule:
interval: weekly
open-pull-requests-limit: 10
labels:
- dependabot
- github-actions

View File

@ -3,6 +3,7 @@ name: Test Action
on: on:
- push - push
- pull_request - pull_request
- workflow_dispatch
jobs: jobs:
test_default_inputs: test_default_inputs:
@ -14,7 +15,7 @@ jobs:
fail-fast: false fail-fast: false
matrix: matrix:
pnpm: pnpm:
- 4.11.1 - 6.17.1
os: os:
- ubuntu-latest - ubuntu-latest
- macos-latest - macos-latest
@ -26,10 +27,10 @@ jobs:
- name: Run the action - name: Run the action
uses: ./ uses: ./
with: with:
version: 4.11.1 version: 6.17.1
- name: 'Test: which' - name: 'Test: which'
run: which pnpm; which pnpx run: which pnpm
- name: 'Test: install' - name: 'Test: install'
run: pnpm install run: pnpm install
@ -43,7 +44,7 @@ jobs:
fail-fast: false fail-fast: false
matrix: matrix:
pnpm: pnpm:
- 4.11.1 - 6.17.1
os: os:
- ubuntu-latest - ubuntu-latest
- macos-latest - macos-latest
@ -55,13 +56,11 @@ jobs:
- name: Run the action - name: Run the action
uses: ./ uses: ./
with: with:
version: 4.11.1 version: 6.17.1
dest: ~/test/pnpm dest: ~/test/pnpm
bin_dest: ~/test/pnpm/.bin
registry: http://registry.yarnpkg.com/
- name: 'Test: which' - name: 'Test: which'
run: which pnpm && which pnpx run: which pnpm
- name: 'Test: install' - name: 'Test: install'
run: pnpm install run: pnpm install
@ -75,7 +74,7 @@ jobs:
fail-fast: false fail-fast: false
matrix: matrix:
pnpm: pnpm:
- 4.11.1 - 6.17.1
os: os:
- ubuntu-latest - ubuntu-latest
- macos-latest - macos-latest
@ -113,11 +112,11 @@ jobs:
- name: Run the action - name: Run the action
uses: ./ uses: ./
with: with:
version: 4.11.1 version: 6.17.1
run_install: ${{ matrix.run_install.value }} run_install: ${{ matrix.run_install.value }}
- name: 'Test: which' - name: 'Test: which'
run: which pnpm; which pnpx run: which pnpm
- name: 'Test: install' - name: 'Test: install'
run: pnpm install run: pnpm install

1
.gitignore vendored
View File

@ -8,3 +8,4 @@ temp
*.temp *.temp
tmp.* tmp.*
temp.* temp.*
.pnpm-store

View File

@ -1,24 +1,16 @@
# Setup PNPM # Setup pnpm
Install PNPM package manager. Install pnpm package manager.
## Inputs ## Inputs
### `version` ### `version`
**Required** Version of PNPM to install. **Required** Version of pnpm to install. It supports npm versioning scheme, it could be an exact version (such as `6.24.1`), or a version range (such as `6`, `6.x.x`, `6.24.x`, `^6.24.1`, `*`, etc.), or `latest`.
### `dest` ### `dest`
**Optional** Where to store PNPM files. **Optional** Where to store pnpm files.
### `bin_dest`
**Optional** Where to store executables (`pnpm` and `pnpx` commands).
### `registry`
**Optional** (_default:_ `https://registry.npmjs.com`) Registry to download PNPM from.
### `run_install` ### `run_install`
@ -50,11 +42,11 @@ Expanded path of inputs#dest.
### `bin_dest` ### `bin_dest`
Expanded path of inputs#bin_dest. Location of `pnpm` and `pnpx` command.
## Usage example ## Usage example
### Just install PNPM ### Just install pnpm
```yaml ```yaml
on: on:
@ -62,15 +54,16 @@ on:
- pull_request - pull_request
jobs: jobs:
runs-on: ubuntu-latest install:
runs-on: ubuntu-latest
steps: steps:
- uses: pnpm/action-setup@v1.2.0 - uses: pnpm/action-setup@v2.1.0
with: with:
version: 4.11.1 version: 6.0.2
``` ```
### Install PNPM and a few NPM packages ### Install pnpm and a few npm packages
```yaml ```yaml
on: on:
@ -78,20 +71,52 @@ on:
- pull_request - pull_request
jobs: jobs:
runs-on: ubuntu-latest install:
runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
- uses: pnpm/action-setup@v1.2.0 - uses: pnpm/action-setup@v2.1.0
with: with:
version: 4.11.1 version: 6.0.2
run_install: | run_install: |
- recursive: true - recursive: true
args: [--frozen-lockfile, --strict-peer-dependencies] args: [--frozen-lockfile, --strict-peer-dependencies]
- args: [--global, gulp, prettier, typescript] - args: [--global, gulp, prettier, typescript]
``` ```
### Use cache to reduce installation time
```yaml
on:
- push
- pull_request
jobs:
cache-and-install:
runs-on: ubuntu-latest
steps:
build:
- uses: actions/checkout@v2
- name: Cache pnpm modules
uses: actions/cache@v2
with:
path: ~/.pnpm-store
key: ${{ runner.os }}-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-
- uses: pnpm/action-setup@v2.1.0
with:
version: 6.0.2
run_install: true
```
**Note:** You don't need to run `pnpm store prune` at the end; post-action has already taken care of that.
## Notes ## Notes
This action does not setup Node.js for you, use [actions/setup-node](https://github.com/actions/setup-node) yourself. This action does not setup Node.js for you, use [actions/setup-node](https://github.com/actions/setup-node) yourself.

View File

@ -11,14 +11,6 @@ inputs:
description: Where to store PNPM files description: Where to store PNPM files
required: false required: false
default: ~/setup-pnpm default: ~/setup-pnpm
bin_dest:
description: Where to store executables (pnpm and pnpx commands)
required: false
default: ~/setup-pnpm/.bin
registry:
description: Registry to download PNPM from
required: false
default: https://registry.npmjs.com
run_install: run_install:
description: If specified, run `pnpm install` description: If specified, run `pnpm install`
required: false required: false

2
dist/index.js vendored

File diff suppressed because one or more lines are too long

View File

@ -7,19 +7,21 @@
"start": "pnpm run build && sh ./run.sh" "start": "pnpm run build && sh ./run.sh"
}, },
"dependencies": { "dependencies": {
"node-fetch": "^2.6.0", "@actions/core": "^1.6.0",
"expand-tilde": "^2.0.2",
"js-yaml": "^3.13.1",
"ajv": "^6.12.0",
"@actions/core": "^1.2.4",
"@types/expand-tilde": "^2.0.0", "@types/expand-tilde": "^2.0.0",
"@types/node-fetch": "^2.5.7", "@types/fs-extra": "^9.0.13",
"@types/js-yaml": "^3.12.3", "@types/js-yaml": "^4.0.5",
"@types/node": "^13.13.5" "@types/node": "^14.18.10",
"@types/node-fetch": "^2.5.12",
"ajv": "^6.12.6",
"expand-tilde": "^2.0.2",
"fs-extra": "^9.1.0",
"js-yaml": "^4.1.0",
"node-fetch": "^2.6.7"
}, },
"devDependencies": { "devDependencies": {
"typescript": "^3.8.3",
"@ts-schema-autogen/cli": "^0.1.2", "@ts-schema-autogen/cli": "^0.1.2",
"@zeit/ncc": "^0.22.1" "@vercel/ncc": "^0.27.0",
"typescript": "^4.5.5"
} }
} }

961
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@ -1,6 +1,10 @@
{ {
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"pinVersions": false, "pinVersions": false,
"extends": [ "extends": [
"config:base" "config:base"
],
"ignoreDeps": [
"ajv"
] ]
} }

2
run.sh
View File

@ -3,7 +3,5 @@
export HOME="$(pwd)" export HOME="$(pwd)"
export INPUT_VERSION=4.11.1 export INPUT_VERSION=4.11.1
export INPUT_DEST='~/pnpm.temp' export INPUT_DEST='~/pnpm.temp'
export INPUT_BIN_DEST='~/pnpm.temp/.bin'
export INPUT_REGISTRY=https://registry.npmjs.com
export INPUT_RUN_INSTALL=null export INPUT_RUN_INSTALL=null
exec node dist/index.js exec node dist/index.js

View File

@ -5,8 +5,6 @@ import { RunInstall, parseRunInstall } from './run-install'
export interface Inputs { export interface Inputs {
readonly version: string readonly version: string
readonly dest: string readonly dest: string
readonly binDest: string
readonly registry: string
readonly runInstall: RunInstall[] readonly runInstall: RunInstall[]
} }
@ -19,8 +17,6 @@ const parseInputPath = (name: string) => expandTilde(getInput(name, options))
export const getInputs = (): Inputs => ({ export const getInputs = (): Inputs => ({
version: getInput('version', options), version: getInput('version', options),
dest: parseInputPath('dest'), dest: parseInputPath('dest'),
binDest: parseInputPath('bin_dest'),
registry: getInput('registry', options),
runInstall: parseRunInstall('run_install'), runInstall: parseRunInstall('run_install'),
}) })

View File

@ -1,5 +1,5 @@
import process from 'process' import process from 'process'
import { safeLoad } from 'js-yaml' import { load } from 'js-yaml'
import Ajv from 'ajv' import Ajv from 'ajv'
import { getInput, error, InputOptions } from '@actions/core' import { getInput, error, InputOptions } from '@actions/core'
import runInstallSchema from './run-install-input.schema.json' import runInstallSchema from './run-install-input.schema.json'
@ -21,10 +21,9 @@ const options: InputOptions = {
} }
export function parseRunInstall(name: string): RunInstall[] { export function parseRunInstall(name: string): RunInstall[] {
const result: RunInstallInput = safeLoad(getInput(name, options)) const result: RunInstallInput = load(getInput(name, options)) as any
const ajv = new Ajv({ const ajv = new Ajv({
allErrors: true, allErrors: true,
async: false,
}) })
const validate = ajv.compile(runInstallSchema) const validate = ajv.compile(runInstallSchema)
if (!validate(result)) { if (!validate(result)) {

View File

@ -9,7 +9,7 @@ export async function install(inputs: Inputs) {
const status = await runSelfInstaller(inputs) const status = await runSelfInstaller(inputs)
endGroup() endGroup()
if (status) { if (status) {
return setFailed(`Something does wrong, self-installer exits with code ${status}`) return setFailed(`Something went wrong, self-installer exits with code ${status}`)
} }
} }

View File

@ -1,26 +1,38 @@
import { addPath, exportVariable } from '@actions/core'
import { spawn } from 'child_process' import { spawn } from 'child_process'
import { execPath } from 'process' import { execPath } from 'process'
import { downloadSelfInstaller } from '../self-installer' import path from 'path'
import { remove, ensureFile, writeFile } from 'fs-extra'
import fetch from 'node-fetch'
import { Inputs } from '../inputs' import { Inputs } from '../inputs'
export async function runSelfInstaller(inputs: Inputs): Promise<number> { export async function runSelfInstaller(inputs: Inputs): Promise<number> {
const cp = spawn(execPath, { const { version, dest } = inputs
env: { const target = version ? `@pnpm/exe@${version}` : '@pnpm/exe'
PNPM_VERSION: inputs.version, const pkgJson = path.join(dest, 'package.json')
PNPM_DEST: inputs.dest,
PNPM_BIN_DEST: inputs.binDest, await remove(dest)
PNPM_REGISTRY: inputs.registry, await ensureFile(pkgJson)
}, await writeFile(pkgJson, JSON.stringify({ private: true }))
const cp = spawn(execPath, ['-', 'install', target, '--no-lockfile'], {
cwd: dest,
stdio: ['pipe', 'inherit', 'inherit'], stdio: ['pipe', 'inherit', 'inherit'],
}) })
const response = await downloadSelfInstaller() const response = await fetch('https://get.pnpm.io/v6.16.js')
response.body.pipe(cp.stdin) response.body.pipe(cp.stdin)
return new Promise((resolve, reject) => { const exitCode = await new Promise<number>((resolve, reject) => {
cp.on('error', reject) cp.on('error', reject)
cp.on('close', resolve) cp.on('close', resolve)
}) })
if (exitCode === 0) {
const pnpmHome = path.join(dest, 'node_modules/.bin')
addPath(pnpmHome)
exportVariable('PNPM_HOME', pnpmHome)
}
return exitCode
} }
export default runSelfInstaller export default runSelfInstaller

View File

@ -1,10 +1,12 @@
import { setOutput, addPath } from '@actions/core' import { setOutput, addPath } from '@actions/core'
import { Inputs } from '../inputs' import { Inputs } from '../inputs'
import { getBinDest } from '../utils'
export function setOutputs(inputs: Inputs) { export function setOutputs(inputs: Inputs) {
addPath(inputs.binDest) const binDest = getBinDest(inputs)
addPath(binDest)
setOutput('dest', inputs.dest) setOutput('dest', inputs.dest)
setOutput('bin_dest', inputs.binDest) setOutput('bin_dest', binDest)
} }
export default setOutputs export default setOutputs

View File

@ -1,4 +0,0 @@
import fetch from 'node-fetch'
import url from './url'
export const downloadSelfInstaller = () => fetch(url)
export default downloadSelfInstaller

View File

@ -1,2 +0,0 @@
export * from './url'
export * from './download'

View File

@ -1,3 +0,0 @@
export const ref = '301414cec74a2b6b63c95b42f2ad1790ccb980ed'
export const url = `https://raw.githubusercontent.com/pnpm/self-installer/${ref}/install.js`
export default url

View File

@ -2,7 +2,9 @@ import process from 'process'
import path from 'path' import path from 'path'
import { Inputs } from '../inputs' import { Inputs } from '../inputs'
export const getBinDest = (inputs: Inputs): string => path.join(inputs.dest, 'node_modules', '.bin')
export const patchPnpmEnv = (inputs: Inputs): NodeJS.ProcessEnv => ({ export const patchPnpmEnv = (inputs: Inputs): NodeJS.ProcessEnv => ({
...process.env, ...process.env,
PATH: inputs.binDest + path.delimiter + process.env.PATH PATH: getBinDest(inputs) + path.delimiter + process.env.PATH
}) })