Skip to content
forked from actions/toolkit

The GitHub ToolKit for developing GitHub Actions.

License

Notifications You must be signed in to change notification settings

tawoops/toolkit

This branch is 2 commits ahead of, 121 commits behind actions/toolkit:master.

Folders and files

NameName
Last commit message
Last commit date
Jan 4, 2020
Dec 23, 2019
Sep 13, 2020
Jul 10, 2019
Apr 22, 2019
May 21, 2019
May 22, 2019
May 22, 2019
May 21, 2019
Apr 19, 2019
Oct 9, 2019
Apr 20, 2019
Jan 10, 2020
Oct 9, 2019
Apr 19, 2019
Apr 19, 2019
Jan 10, 2020
Jan 10, 2020
May 21, 2019

Repository files navigation

GitHub Actions status

GitHub Actions Toolkit

The GitHub Actions ToolKit provides a set of packages to make creating actions easier.


Get started with the javascript-action template!


Packages

βœ”οΈ @actions/core

Provides functions for inputs, outputs, results, logging, secrets and variables. Read more here

$ npm install @actions/core --save

πŸƒ @actions/exec

Provides functions to exec cli tools and process output. Read more here

$ npm install @actions/exec --save

🍨 @actions/glob

Provides functions to search for files matching glob patterns. Read more here

$ npm install @actions/glob --save

✏️ @actions/io

Provides disk i/o functions like cp, mv, rmRF, find etc. Read more here

$ npm install @actions/io --save

πŸ”¨ @actions/tool-cache

Provides functions for downloading and caching tools. e.g. setup-* actions. Read more here

$ npm install @actions/tool-cache --save

:octocat: @actions/github

Provides an Octokit client hydrated with the context that the current action is being run in. Read more here

$ npm install @actions/github --save

Creating an Action with the Toolkit

❓ Choosing an action type

Outlines the differences and why you would want to create a JavaScript or a container based action.

➰ Versioning

Actions are downloaded and run from the GitHub graph of repos. This contains guidance for versioning actions and safe releases.

⚠️ Problem Matchers

Problem Matchers are a way to scan the output of actions for a specified regex pattern and surface that information prominently in the UI.

Illustrates how to create a simple hello world javascript action.

...
  const nameToGreet = core.getInput('who-to-greet');
  console.log(`Hello ${nameToGreet}!`);
...

Walkthrough and template for creating a JavaScript Action with tests, linting, workflow, publishing, and versioning.

async function run() {
  try { 
    const ms = core.getInput('milliseconds');
    console.log(`Waiting ${ms} milliseconds ...`)
    ...
PASS ./index.test.js
  βœ“ throws invalid number 
  βœ“ wait 500 ms 
  βœ“ test runs

Test Suites: 1 passed, 1 total    
Tests:       3 passed, 3 total

Walkthrough creating a TypeScript Action with compilation, tests, linting, workflow, publishing, and versioning.

import * as core from '@actions/core';

async function run() {
  try {
    const ms = core.getInput('milliseconds');
    console.log(`Waiting ${ms} milliseconds ...`)
    ...
PASS ./index.test.js
  βœ“ throws invalid number 
  βœ“ wait 500 ms 
  βœ“ test runs

Test Suites: 1 passed, 1 total    
Tests:       3 passed, 3 total


Create an action that is delivered as a container and run with docker.

FROM alpine:3.10
COPY LICENSE README.md /
COPY entrypoint.sh /entrypoint.sh
ENTRYPOINT ["/entrypoint.sh"]

Create an action that is delivered as a container which uses the toolkit. This example uses the GitHub context to construct an Octokit client.

FROM node:slim
COPY . .
RUN npm install --production
ENTRYPOINT ["node", "/lib/main.js"]
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}`)    

Contributing

We welcome contributions. See how to contribute.

Code of Conduct

See our code of conduct.

About

The GitHub ToolKit for developing GitHub Actions.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 98.4%
  • Other 1.6%