DEV Community

Erik Guzman
Erik Guzman

Posted on • Edited on

Creating a JavaScript Github Action with Benjamin Lannon (@lannonbr)

Creating a "Hello World" JavaScript Github Action

This will be a simple walkthrough creating your very first JavaScript Github Action. This repository was created on Stream during the Talk Github Actions with guest Banjamin Lannon stream. If you would to watch our conversation of follow along at the end of the stream when making this project you can watch the linked video.

If you would like to also watch on YouTube the entire conversation and at the end creating the Github Action here you go:

Getting Started

  • Use an existing repository or make a brand new repository

    You can run the Github Action from the repository it lives in or run it from another repositories action.

  • Create a .github folder and the root of your directory

  • Create a actions folder inside of .github folder

Creating our JavaScript Action

Now we have basic folder structure. Lets make our first JavaScript Github Action.

  • Create a test-action folder inside of the previously created actions folder.
  • Inside of test-action initialize a npm package by running
npm init -y
  • Now create a index.js file

This index.js file will contain the logic we will run for our Github Action

  • Open up index.js and lets add a simple Hello World
// Inside of index.js
console.log('Hello World!)
  • Create an action.yml file inside test-action folder

This is a special file for Github Actions, it helps tell Github information about your action and how to run it

  • Insert the following into action.yml the following:
name: Hello-World
description: Example hello world running JavaScript Github Action
runs:
  using: node12 # Runtime Environment
  main: index.js # Script to run, path is relative
  • Make sure everything is saved, commit the code, and push it to your Github repository

Creating your Github Action Workflow

Next we need to create a Github Action Workflow that will run our brand new JavaScript "Hello World" Github Action. This can be done one of two ways.

  1. On Github.com in your repostory page directly
  2. Locally be manually creating the dependent folder and files

Doing it manually is a little more work since on Github.com you can start with using the template boilerplate.

I will going through Method 1. Once were done with Method 1, it will be easy to say how to do it manually.

Creating your Workflow on Github.com

  • Navigate to your repository homepage on Github
  • On the top bar next to Pull Requests click on ▶️ Actions

When you dont have any Github Action Workflows for your repository you will see a "Getting Started" kind of page. It will suggest Github Actions you can start with based off the main language of your repository.

  • Ignore the suggestion and click on Setup and workflow yourself button located on the right side of the page.

You will be taken to the standard Github file create/edit screen with a TWIST (very twisty)! On the right margin you will have a WYSIWYG sort of thing to fill in Github Actions that might be of use. This will be attempt to make a main.yml file inside of .github/workflow/.

This YAML file will run an entire workflow, executing our desired Github Actions or commands.

  • In our main.yml put the following in:
name: CI # Name of our workflow

on: [push] # Repository event that will trigger the workflow

jobs:
  build:

    runs-on: ubuntu-latest # Environment job will run in

    steps: # Each action/command to run
    - uses: actions/checkout@v1 # Helps check out the repo code
    - uses: ./.github/actions/test-action # Tell it to run out JS Action
  • Commit the file on Github

Since we just made our workflow file and it triggers on push. Github should actually attempt to run our workflow and trigger our JavaScript action. Let's go check it out!

Checking Executed Workflows

  • On the top bar next to Pull Requests click on ▶️ Actions

This page will look completely different since that last time we visited it. Since we now have a workflow, it will display the history of our workflow runs.

In the table for All Workflows you should see a job called CI that is currently running or has completed (depending on how fast you got to this page after committing the workflow.

  • Click on name CI to view the workflow details.

You will see a UI displaying the various steps your workflow went through during is execution process.

  • Click on Run /./.github/actions/test-action if its not already expanded.

If the step has completed executing it will be expanded showing you what is going on during that step. If it has been completed it will be collapsed.

  • You should see our console log of Hello World!

Congratulations you just made your own JavaScript Github Action and Workflow to run it!!!!!

Support Using Packages in JavaScript Actions

Doing a plain console log is nice and all but its looking kinda plain. Lets spice it up a little by giving the "Hello World" some flair. By using Boxen package to put our "Hello World" in a nice box to make it feel more official.

But in order to support running 3rd party packages, our JavaScript Github Action must be bundled together with its dependency (just like if we were deploying a front end app).

  • Install boxen inside test-action folder using the terminal:
npm i boxen
  • Update index.js to use boxen:
// In index.js
const boxen = require('boxen');

console.log(boxen('HELLO WORLD!!', {padding: 1}));
  • Check everything so far is working by running index.js with node in the terminal
node index.js

# Should output:
┌───────────────────┐
│                   │
│   HELLO WORLD!!   │
│                   │
└───────────────────┘

Next step is to bundle all our index.js together with our dependencies, in this case Boxen. Webpack will be used in this situation but you can use a number of other bundlers as an alternative.

  • Inside test-action folder run the following command in the terminal:
npm i -D webpack webpack-cli
  • Inside test-action folder create a file called webpack.config.js and add the following:
// Inside webpack.config.js
const path = require("path")

module.exports = {
  mode: "production",
  entry: "./index.js",
  output: {
    path: path.resolve(__dirname, "dist"),
    filename: "index.js",
  },
  target: "node",
  node: false,
}

Although Webpack 4 has made major improvements so that a configuration file is not needed, it is still valuable to create one to demystify whats going on when you move to the build step.

  • Inside test-action open package.json and inside of scripts attribute add a build command:
{
  // ...
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "build": "webpack"
  }
  // ....
}

build will run webpack which will take a look at the config file and output a production bundle of index.js inside of dist folder.

  • Now create our bundle for Github to run the action in the terminal:
npm run build

A new folder called dist should have been created containing an index.js file. If you open it up you will see a lot of code, since our file also includes the code for our Boxen dependency.

Github doesnt know yet how to run our new bundled action, right now it will only run the normal index.js. So you will need to update action.yml inside of test-action to run dist/index.js:

name: Hello-World
description: Example hello world running JavaScript Github Action
runs:
  using: node12
  main: dist/index.js # This changed to point to our new JavaScript bundle
  • Lastly commit all the new files and push it up to Github

Checking on Our Newly Updated Github Action

Now that our Github Action has a little more sizzle, razzle-dazzle, spiciness, and the new code has just been pushed. The Github Workflow should had been triggered and the new Hello World message.

  • On the top bar next to Pull Requests click on ▶️ Actions
  • Click on latest CI to view the workflow details.
  • Click on Run /./.github/actions/test-action if its not already expanded.
  • You should see the output we tested locally:
Run ./.github/actions/test-action
tput: No value for $TERM and no -T specified
┌───────────────────┐
│                   │
│   HELLO WORLD!!   │
│                   │
└───────────────────┘

At this point we should now have a JavaScript Github Action that can run dependencies. This is just a trivial example but it perfectly shows the steps necessary to creating a custom Github Action to execute a desired behavior or series of actions. An example of what you can do next is building out integrations with a third party API to trigger events like your lights blinking or sending a text.

Top comments (0)