10 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
45d9c91ff6 Specify job name to fix syntax error 2022-01-29 08:17:29 -08:00
4 changed files with 51 additions and 48 deletions

View File

@ -15,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
@ -27,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
@ -44,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
@ -56,11 +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
- 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
@ -74,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
@ -112,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

View File

@ -54,10 +54,11 @@ on:
- pull_request - pull_request
jobs: jobs:
install:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: pnpm/action-setup@v2.0.1 - uses: pnpm/action-setup@v2.1.0
with: with:
version: 6.0.2 version: 6.0.2
``` ```
@ -70,12 +71,13 @@ on:
- pull_request - pull_request
jobs: jobs:
install:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
- uses: pnpm/action-setup@v2.0.1 - uses: pnpm/action-setup@v2.1.0
with: with:
version: 6.0.2 version: 6.0.2
run_install: | run_install: |
@ -92,6 +94,7 @@ on:
- pull_request - pull_request
jobs: jobs:
cache-and-install:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
@ -106,7 +109,7 @@ jobs:
restore-keys: | restore-keys: |
${{ runner.os }}- ${{ runner.os }}-
- uses: pnpm/action-setup@v2.0.1 - uses: pnpm/action-setup@v2.1.0
with: with:
version: 6.0.2 version: 6.0.2
run_install: true run_install: true

2
dist/index.js vendored

File diff suppressed because one or more lines are too long

View File

@ -1,15 +1,15 @@
import * as core from '@actions/core' 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 { join } from 'path' import path from 'path'
import { remove, ensureFile, writeFile } from 'fs-extra' import { remove, ensureFile, writeFile } from 'fs-extra'
import fetch from 'node-fetch' 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 { version, dest } = inputs const { version, dest } = inputs
const target = version ? `pnpm@${version}` : 'pnpm' const target = version ? `@pnpm/exe@${version}` : '@pnpm/exe'
const pkgJson = join(dest, 'package.json') const pkgJson = path.join(dest, 'package.json')
await remove(dest) await remove(dest)
await ensureFile(pkgJson) await ensureFile(pkgJson)
@ -20,7 +20,7 @@ export async function runSelfInstaller(inputs: Inputs): Promise<number> {
stdio: ['pipe', 'inherit', 'inherit'], stdio: ['pipe', 'inherit', 'inherit'],
}) })
const response = await fetch('https://pnpm.js.org/pnpm.js') const response = await fetch('https://get.pnpm.io/v6.16.js')
response.body.pipe(cp.stdin) response.body.pipe(cp.stdin)
const exitCode = await new Promise<number>((resolve, reject) => { const exitCode = await new Promise<number>((resolve, reject) => {
@ -28,9 +28,9 @@ export async function runSelfInstaller(inputs: Inputs): Promise<number> {
cp.on('close', resolve) cp.on('close', resolve)
}) })
if (exitCode === 0) { if (exitCode === 0) {
const pnpmHome = join(dest, 'node_modules/.bin') const pnpmHome = path.join(dest, 'node_modules/.bin')
core.addPath(pnpmHome) addPath(pnpmHome)
core.exportVariable('PNPM_HOME', pnpmHome) exportVariable('PNPM_HOME', pnpmHome)
} }
return exitCode return exitCode
} }