mirror of
https://git.mirrors.martin98.com/https://github.com/actions/toolkit
synced 2025-08-22 03:09:05 +08:00

💡 See https://github.com/actions/toolkit/pull/1064 for a better diff! https://github.com/actions/toolkit contains a variety of packages used for building actions. https://github.com/actions/http-client is one such package, but lives outside of the toolkit. Moving it inside of the toolkit will improve discoverability and reduce the number of repos we have to keep track of for maintenance tasks (such as github/c2c-actions-service#2937). I checked with @bryanmacfarlane on the historical decision here. Apparently it was just inertia from before we released the toolkit as multiple packages. The benefits here are: - Have one fewer repo to keep track of - Signal that this is an HTTP client meant for building actions, not for general use. ## Notes - `@actions/http-client` will continue to be released as its own package. - Bumping the package version to **2.0.0**. Since we're compiling in strict mode now, there are some breaking changes to the exported types. This is an improvement because the null-unsafe version of`http-client` is currently breaking the safety of null-safe consumers. - I'm not updating the other packages to use the new version in this PR. I plan to do that in a follow-up. We'll hold off on publishing `http-client` v2 to NPM until that's done just in case other changes shake out of it.
228 lines
5.7 KiB
Markdown
228 lines
5.7 KiB
Markdown
|
|
<p align="center">
|
|
<img src="res/at-logo.png">
|
|
</p>
|
|
|
|
<p align="center">
|
|
<a href="https://github.com/actions/toolkit/actions?query=workflow%3Atoolkit-unit-tests"><img alt="Toolkit unit tests status" src="https://github.com/actions/toolkit/workflows/toolkit-unit-tests/badge.svg"></a>
|
|
<a href="https://github.com/actions/toolkit/actions?query=workflow%3Atoolkit-audit"><img alt="Toolkit audit status" src="https://github.com/actions/toolkit/workflows/toolkit-audit/badge.svg"></a>
|
|
</p>
|
|
|
|
|
|
## GitHub Actions Toolkit
|
|
|
|
The GitHub Actions ToolKit provides a set of packages to make creating actions easier.
|
|
|
|
<br/>
|
|
<h3 align="center">Get started with the <a href="https://github.com/actions/javascript-action">javascript-action template</a>!</h3>
|
|
<br/>
|
|
|
|
## Packages
|
|
|
|
:heavy_check_mark: [@actions/core](packages/core)
|
|
|
|
Provides functions for inputs, outputs, results, logging, secrets and variables. Read more [here](packages/core)
|
|
|
|
```bash
|
|
$ npm install @actions/core
|
|
```
|
|
<br/>
|
|
|
|
:runner: [@actions/exec](packages/exec)
|
|
|
|
Provides functions to exec cli tools and process output. Read more [here](packages/exec)
|
|
|
|
```bash
|
|
$ npm install @actions/exec
|
|
```
|
|
<br/>
|
|
|
|
:ice_cream: [@actions/glob](packages/glob)
|
|
|
|
Provides functions to search for files matching glob patterns. Read more [here](packages/glob)
|
|
|
|
```bash
|
|
$ npm install @actions/glob
|
|
```
|
|
<br/>
|
|
|
|
:phone: [@actions/http-client](packages/http-client)
|
|
|
|
A lightweight HTTP client optimized for building actions. Read more [here](packages/http-client)
|
|
|
|
```bash
|
|
$ npm install @actions/http-client
|
|
```
|
|
<br/>
|
|
|
|
:pencil2: [@actions/io](packages/io)
|
|
|
|
Provides disk i/o functions like cp, mv, rmRF, which etc. Read more [here](packages/io)
|
|
|
|
```bash
|
|
$ npm install @actions/io
|
|
```
|
|
<br/>
|
|
|
|
:hammer: [@actions/tool-cache](packages/tool-cache)
|
|
|
|
Provides functions for downloading and caching tools. e.g. setup-* actions. Read more [here](packages/tool-cache)
|
|
|
|
See @actions/cache for caching workflow dependencies.
|
|
|
|
```bash
|
|
$ npm install @actions/tool-cache
|
|
```
|
|
<br/>
|
|
|
|
:octocat: [@actions/github](packages/github)
|
|
|
|
Provides an Octokit client hydrated with the context that the current action is being run in. Read more [here](packages/github)
|
|
|
|
```bash
|
|
$ npm install @actions/github
|
|
```
|
|
<br/>
|
|
|
|
:floppy_disk: [@actions/artifact](packages/artifact)
|
|
|
|
Provides functions to interact with actions artifacts. Read more [here](packages/artifact)
|
|
|
|
```bash
|
|
$ npm install @actions/artifact
|
|
```
|
|
<br/>
|
|
|
|
:dart: [@actions/cache](packages/cache)
|
|
|
|
Provides functions to cache dependencies and build outputs to improve workflow execution time. Read more [here](packages/cache)
|
|
|
|
```bash
|
|
$ npm install @actions/cache
|
|
```
|
|
<br/>
|
|
|
|
## Creating an Action with the Toolkit
|
|
|
|
:question: [Choosing an action type](docs/action-types.md)
|
|
|
|
Outlines the differences and why you would want to create a JavaScript or a container based action.
|
|
<br/>
|
|
<br/>
|
|
|
|
:curly_loop: [Versioning](docs/action-versioning.md)
|
|
|
|
Actions are downloaded and run from the GitHub graph of repos. This contains guidance for versioning actions and safe releases.
|
|
<br/>
|
|
<br/>
|
|
|
|
:warning: [Problem Matchers](docs/problem-matchers.md)
|
|
|
|
Problem Matchers are a way to scan the output of actions for a specified regex pattern and surface that information prominently in the UI.
|
|
<br/>
|
|
<br/>
|
|
|
|
:warning: [Proxy Server Support](docs/proxy-support.md)
|
|
|
|
Self-hosted runners can be configured to run behind proxy servers.
|
|
<br/>
|
|
<br/>
|
|
|
|
<h3><a href="https://github.com/actions/hello-world-javascript-action">Hello World JavaScript Action</a></h3>
|
|
|
|
Illustrates how to create a simple hello world javascript action.
|
|
|
|
```javascript
|
|
...
|
|
const nameToGreet = core.getInput('who-to-greet');
|
|
console.log(`Hello ${nameToGreet}!`);
|
|
...
|
|
```
|
|
<br/>
|
|
|
|
<h3><a href="https://github.com/actions/javascript-action">JavaScript Action Walkthrough</a></h3>
|
|
|
|
Walkthrough and template for creating a JavaScript Action with tests, linting, workflow, publishing, and versioning.
|
|
|
|
```javascript
|
|
async function run() {
|
|
try {
|
|
const ms = core.getInput('milliseconds');
|
|
console.log(`Waiting ${ms} milliseconds ...`)
|
|
...
|
|
```
|
|
```javascript
|
|
PASS ./index.test.js
|
|
✓ throws invalid number
|
|
✓ wait 500 ms
|
|
✓ test runs
|
|
|
|
Test Suites: 1 passed, 1 total
|
|
Tests: 3 passed, 3 total
|
|
```
|
|
<br/>
|
|
|
|
<h3><a href="https://github.com/actions/typescript-action">TypeScript Action Walkthrough</a></h3>
|
|
|
|
Walkthrough creating a TypeScript Action with compilation, tests, linting, workflow, publishing, and versioning.
|
|
|
|
```javascript
|
|
import * as core from '@actions/core';
|
|
|
|
async function run() {
|
|
try {
|
|
const ms = core.getInput('milliseconds');
|
|
console.log(`Waiting ${ms} milliseconds ...`)
|
|
...
|
|
```
|
|
```javascript
|
|
PASS ./index.test.js
|
|
✓ throws invalid number
|
|
✓ wait 500 ms
|
|
✓ test runs
|
|
|
|
Test Suites: 1 passed, 1 total
|
|
Tests: 3 passed, 3 total
|
|
```
|
|
<br/>
|
|
<br/>
|
|
|
|
<h3><a href="docs/container-action.md">Docker Action Walkthrough</a></h3>
|
|
|
|
Create an action that is delivered as a container and run with docker.
|
|
|
|
```docker
|
|
FROM alpine:3.10
|
|
COPY LICENSE README.md /
|
|
COPY entrypoint.sh /entrypoint.sh
|
|
ENTRYPOINT ["/entrypoint.sh"]
|
|
```
|
|
<br/>
|
|
|
|
<h3><a href="https://github.com/actions/container-toolkit-action">Docker Action Walkthrough with Octokit</a></h3>
|
|
|
|
Create an action that is delivered as a container which uses the toolkit. This example uses the GitHub context to construct an Octokit client.
|
|
|
|
```docker
|
|
FROM node:slim
|
|
COPY . .
|
|
RUN npm install --production
|
|
ENTRYPOINT ["node", "/lib/main.js"]
|
|
```
|
|
```javascript
|
|
const myInput = core.getInput('myInput');
|
|
core.debug(`Hello ${myInput} from inside a container`);
|
|
|
|
const context = github.context;
|
|
console.log(`We can even get context data, like the repo: ${context.repo.repo}`)
|
|
```
|
|
<br/>
|
|
|
|
## Contributing
|
|
|
|
We welcome contributions. See [how to contribute](.github/CONTRIBUTING.md).
|
|
|
|
## Code of Conduct
|
|
|
|
See [our code of conduct](CODE_OF_CONDUCT.md).
|