Compare commits
15 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5804f049e1 | ||
|
|
84daa2c0f0 | ||
|
|
6d98b259d9 | ||
|
|
3629f23f43 | ||
|
|
4bb2d37925 | ||
|
|
9f83520638 | ||
|
|
10f155294b | ||
|
|
49ce228ea7 | ||
|
|
c08c5ace34 | ||
|
|
c72844caa4 | ||
|
|
ede6c15881 | ||
|
|
17cde8a7d8 | ||
|
|
1dccc4ccc6 | ||
|
|
35d8ea9fdb | ||
|
|
9a6a017c10 |
5
.github/workflows/release.yml
vendored
5
.github/workflows/release.yml
vendored
@@ -19,10 +19,11 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
app_id: ${{ vars.RELEASER_APP_ID }}
|
app_id: ${{ vars.RELEASER_APP_ID }}
|
||||||
private_key: ${{ secrets.RELEASER_APP_PRIVATE_KEY }}
|
private_key: ${{ secrets.RELEASER_APP_PRIVATE_KEY }}
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
token: ${{ steps.app-token.outputs.token }}
|
token: ${{ steps.app-token.outputs.token }}
|
||||||
- run: npm install --no-save @semantic-release/git semantic-release-plugin-github-breaking-version-tag
|
- run: npm install --no-save @semantic-release/git semantic-release-plugin-github-breaking-version-tag
|
||||||
- run: npx semantic-release
|
- run: npm run build
|
||||||
|
- run: npx semantic-release --debug
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ steps.app-token.outputs.token }}
|
GITHUB_TOKEN: ${{ steps.app-token.outputs.token }}
|
||||||
|
|||||||
24
.github/workflows/test.yml
vendored
24
.github/workflows/test.yml
vendored
@@ -1,5 +1,8 @@
|
|||||||
name: test
|
name: test
|
||||||
on:
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
pull_request:
|
pull_request:
|
||||||
|
|
||||||
concurrency:
|
concurrency:
|
||||||
@@ -7,13 +10,28 @@ concurrency:
|
|||||||
cancel-in-progress: true
|
cancel-in-progress: true
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
test:
|
integration:
|
||||||
|
name: Integration
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v4
|
||||||
- uses: actions/setup-node@v3
|
- uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: "16.16"
|
node-version: 20
|
||||||
|
cache: "npm"
|
||||||
|
- run: npm ci
|
||||||
|
- run: npm test
|
||||||
|
|
||||||
|
end-to-end:
|
||||||
|
name: End-to-End
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
# do not run from forks, as forks don’t have access to repository secrets
|
||||||
|
if: github.event.pull_request.head.repo.owner.login == github.event.pull_request.base.repo.owner.login
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
- uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 20
|
||||||
cache: "npm"
|
cache: "npm"
|
||||||
- run: npm ci
|
- run: npm ci
|
||||||
- run: npm run build
|
- run: npm run build
|
||||||
|
|||||||
4373
dist/main.cjs
vendored
4373
dist/main.cjs
vendored
File diff suppressed because one or more lines are too long
3481
dist/post.cjs
vendored
3481
dist/post.cjs
vendored
File diff suppressed because one or more lines are too long
11
lib/main.js
11
lib/main.js
@@ -1,16 +1,12 @@
|
|||||||
// @ts-check
|
// @ts-check
|
||||||
|
|
||||||
import core from "@actions/core";
|
|
||||||
import { createAppAuth } from "@octokit/auth-app";
|
|
||||||
import { request } from "@octokit/request";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {string} appId
|
* @param {string} appId
|
||||||
* @param {string} privateKey
|
* @param {string} privateKey
|
||||||
* @param {string} repository
|
* @param {string} repository
|
||||||
* @param {core} core
|
* @param {import("@actions/core")} core
|
||||||
* @param {createAppAuth} createAppAuth
|
* @param {import("@octokit/auth-app").createAppAuth} createAppAuth
|
||||||
* @param {request} request
|
* @param {import("@octokit/request").request} request
|
||||||
*/
|
*/
|
||||||
export async function main(
|
export async function main(
|
||||||
appId,
|
appId,
|
||||||
@@ -26,6 +22,7 @@ export async function main(
|
|||||||
const auth = createAppAuth({
|
const auth = createAppAuth({
|
||||||
appId,
|
appId,
|
||||||
privateKey,
|
privateKey,
|
||||||
|
request,
|
||||||
});
|
});
|
||||||
|
|
||||||
const appAuthentication = await auth({
|
const appAuthentication = await auth({
|
||||||
|
|||||||
14
lib/post.js
14
lib/post.js
@@ -1,17 +1,17 @@
|
|||||||
// @ts-check
|
// @ts-check
|
||||||
|
|
||||||
import core from "@actions/core";
|
|
||||||
import { request } from "@octokit/request";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {core} core
|
* @param {import("@actions/core")} core
|
||||||
* @param {request} request
|
* @param {import("@octokit/request").request} request
|
||||||
*/
|
*/
|
||||||
export async function post(core, request) {
|
export async function post(core, request) {
|
||||||
const token = core.getState("token");
|
const token = core.getState("token");
|
||||||
|
|
||||||
if (!token) return;
|
if (!token) {
|
||||||
|
core.info("Token is not set");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
await request("DELETE /installation/token", {
|
await request("DELETE /installation/token", {
|
||||||
headers: {
|
headers: {
|
||||||
authorization: `token ${token}`,
|
authorization: `token ${token}`,
|
||||||
|
|||||||
8
lib/request.js
Normal file
8
lib/request.js
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
import { request } from "@octokit/request";
|
||||||
|
|
||||||
|
export default request.defaults({
|
||||||
|
baseUrl: process.env["GITHUB_API_URL"],
|
||||||
|
headers: {
|
||||||
|
"user-agent": "actions/create-github-app-token",
|
||||||
|
},
|
||||||
|
});
|
||||||
21
main.js
21
main.js
@@ -2,9 +2,9 @@
|
|||||||
|
|
||||||
import core from "@actions/core";
|
import core from "@actions/core";
|
||||||
import { createAppAuth } from "@octokit/auth-app";
|
import { createAppAuth } from "@octokit/auth-app";
|
||||||
import { request } from "@octokit/request";
|
|
||||||
|
|
||||||
import { main } from "./lib/main.js";
|
import { main } from "./lib/main.js";
|
||||||
|
import request from "./lib/request.js";
|
||||||
|
|
||||||
if (!process.env.GITHUB_REPOSITORY) {
|
if (!process.env.GITHUB_REPOSITORY) {
|
||||||
throw new Error("GITHUB_REPOSITORY missing, must be set to '<owner>/<repo>'");
|
throw new Error("GITHUB_REPOSITORY missing, must be set to '<owner>/<repo>'");
|
||||||
@@ -15,9 +15,16 @@ const privateKey = core.getInput("private_key");
|
|||||||
|
|
||||||
const repository = process.env.GITHUB_REPOSITORY;
|
const repository = process.env.GITHUB_REPOSITORY;
|
||||||
|
|
||||||
main(appId, privateKey, repository, core, createAppAuth, request).catch(
|
main(
|
||||||
(error) => {
|
appId,
|
||||||
console.error(error);
|
privateKey,
|
||||||
core.setFailed(error.message);
|
repository,
|
||||||
}
|
core,
|
||||||
);
|
createAppAuth,
|
||||||
|
request.defaults({
|
||||||
|
baseUrl: process.env["GITHUB_API_URL"],
|
||||||
|
})
|
||||||
|
).catch((error) => {
|
||||||
|
console.error(error);
|
||||||
|
core.setFailed(error.message);
|
||||||
|
});
|
||||||
|
|||||||
2131
package-lock.json
generated
2131
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
16
package.json
16
package.json
@@ -2,21 +2,24 @@
|
|||||||
"name": "create-github-app-token",
|
"name": "create-github-app-token",
|
||||||
"private": true,
|
"private": true,
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"version": "1.0.5",
|
"version": "1.2.2",
|
||||||
"description": "GitHub Action for creating a GitHub App Installation Access Token",
|
"description": "GitHub Action for creating a GitHub App Installation Access Token",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "esbuild main.js post.js --bundle --outdir=dist --out-extension:.js=.cjs --platform=node --target=node16.16",
|
"build": "esbuild main.js post.js --bundle --outdir=dist --out-extension:.js=.cjs --platform=node --target=node16.16",
|
||||||
"test": "echo \"Error: no test specified\" && exit 1"
|
"test": "ava tests/index.js"
|
||||||
},
|
},
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@actions/core": "^1.10.0",
|
"@actions/core": "^1.10.1",
|
||||||
"@octokit/auth-app": "^6.0.0",
|
"@octokit/auth-app": "^6.0.1",
|
||||||
"@octokit/request": "^8.1.1"
|
"@octokit/request": "^8.1.2"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
"ava": "^5.3.1",
|
||||||
"dotenv": "^16.3.1",
|
"dotenv": "^16.3.1",
|
||||||
"esbuild": "^0.19.2"
|
"esbuild": "^0.19.4",
|
||||||
|
"execa": "^8.0.1",
|
||||||
|
"undici": "^5.25.2"
|
||||||
},
|
},
|
||||||
"release": {
|
"release": {
|
||||||
"branches": [
|
"branches": [
|
||||||
@@ -27,6 +30,7 @@
|
|||||||
"@semantic-release/commit-analyzer",
|
"@semantic-release/commit-analyzer",
|
||||||
"@semantic-release/release-notes-generator",
|
"@semantic-release/release-notes-generator",
|
||||||
"@semantic-release/github",
|
"@semantic-release/github",
|
||||||
|
"@semantic-release/npm",
|
||||||
"semantic-release-plugin-github-breaking-version-tag",
|
"semantic-release-plugin-github-breaking-version-tag",
|
||||||
[
|
[
|
||||||
"@semantic-release/git",
|
"@semantic-release/git",
|
||||||
|
|||||||
17
post.js
17
post.js
@@ -1,13 +1,16 @@
|
|||||||
// @ts-check
|
// @ts-check
|
||||||
|
|
||||||
import core from "@actions/core";
|
import core from "@actions/core";
|
||||||
import { request } from "@octokit/request";
|
|
||||||
|
|
||||||
import { post } from "./lib/post.js";
|
import { post } from "./lib/post.js";
|
||||||
|
import request from "./lib/request.js";
|
||||||
|
|
||||||
post(core, request).catch(
|
post(
|
||||||
(error) => {
|
core,
|
||||||
console.error(error);
|
request.defaults({
|
||||||
core.setFailed(error.message);
|
baseUrl: process.env["GITHUB_API_URL"],
|
||||||
}
|
})
|
||||||
);
|
).catch((error) => {
|
||||||
|
console.error(error);
|
||||||
|
core.setFailed(error.message);
|
||||||
|
});
|
||||||
|
|||||||
19
tests/README.md
Normal file
19
tests/README.md
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
# Tests
|
||||||
|
|
||||||
|
Add one test file per scenario. You can run them in isolation with:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
node tests/post-token-set.test.js
|
||||||
|
```
|
||||||
|
|
||||||
|
All tests are run together in [tests/index.js](index.js), which can be execauted with ava
|
||||||
|
|
||||||
|
```
|
||||||
|
npx ava tests/index.js
|
||||||
|
```
|
||||||
|
|
||||||
|
or with npm
|
||||||
|
|
||||||
|
```
|
||||||
|
npm test
|
||||||
|
```
|
||||||
14
tests/index.js
Normal file
14
tests/index.js
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
import { readdirSync } from "node:fs";
|
||||||
|
|
||||||
|
import { execa } from "execa";
|
||||||
|
import test from "ava";
|
||||||
|
|
||||||
|
const tests = readdirSync("tests").filter((file) => file.endsWith(".test.js"));
|
||||||
|
|
||||||
|
for (const file of tests) {
|
||||||
|
test(file, async (t) => {
|
||||||
|
const { stderr, stdout } = await execa("node", [`tests/${file}`]);
|
||||||
|
t.snapshot(stderr, "stderr");
|
||||||
|
t.snapshot(stdout, "stdout");
|
||||||
|
});
|
||||||
|
}
|
||||||
25
tests/post-token-set.test.js
Normal file
25
tests/post-token-set.test.js
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
import { MockAgent, setGlobalDispatcher } from "undici";
|
||||||
|
|
||||||
|
// state variables are set as environment variables with the prefix STATE_
|
||||||
|
// https://docs.github.com/en/actions/using-workflows/workflow-commands-for-github-actions#sending-values-to-the-pre-and-post-actions
|
||||||
|
process.env.STATE_token = "secret123";
|
||||||
|
|
||||||
|
const mockAgent = new MockAgent();
|
||||||
|
|
||||||
|
setGlobalDispatcher(mockAgent);
|
||||||
|
|
||||||
|
// Provide the base url to the request
|
||||||
|
const mockPool = mockAgent.get("https://api.github.com");
|
||||||
|
|
||||||
|
// intercept the request
|
||||||
|
mockPool
|
||||||
|
.intercept({
|
||||||
|
path: "/installation/token",
|
||||||
|
method: "DELETE",
|
||||||
|
headers: {
|
||||||
|
authorization: "token secret123",
|
||||||
|
},
|
||||||
|
})
|
||||||
|
.reply(204);
|
||||||
|
|
||||||
|
await import("../post.js");
|
||||||
5
tests/post-token-unset.test.js
Normal file
5
tests/post-token-unset.test.js
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
// state variables are set as environment variables with the prefix STATE_
|
||||||
|
// https://docs.github.com/en/actions/using-workflows/workflow-commands-for-github-actions#sending-values-to-the-pre-and-post-actions
|
||||||
|
delete process.env.STATE_token;
|
||||||
|
|
||||||
|
await import("../post.js");
|
||||||
25
tests/snapshots/index.js.md
Normal file
25
tests/snapshots/index.js.md
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
# Snapshot report for `tests/index.js`
|
||||||
|
|
||||||
|
The actual snapshot is saved in `index.js.snap`.
|
||||||
|
|
||||||
|
Generated by [AVA](https://avajs.dev).
|
||||||
|
|
||||||
|
## post-token-set.test.js
|
||||||
|
|
||||||
|
> stderr
|
||||||
|
|
||||||
|
''
|
||||||
|
|
||||||
|
> stdout
|
||||||
|
|
||||||
|
'Token revoked'
|
||||||
|
|
||||||
|
## post-token-unset.test.js
|
||||||
|
|
||||||
|
> stderr
|
||||||
|
|
||||||
|
''
|
||||||
|
|
||||||
|
> stdout
|
||||||
|
|
||||||
|
'Token is not set'
|
||||||
BIN
tests/snapshots/index.js.snap
Normal file
BIN
tests/snapshots/index.js.snap
Normal file
Binary file not shown.
Reference in New Issue
Block a user