The Wayback Machine - https://web.archive.org/web/20201027112151/https://github.com/leafo/gh-actions-lua
Skip to content
Use this GitHub Action with your project

Add this Action to an existing workflow or create a new one.

View on Marketplace
master
Go to file
Code

Latest commit

 

Git stats

Files

Permalink
Failed to load latest commit information.
Type
Name
Latest commit message
Commit time
 
 
 
 
 
 
 
 
 
 
 
 

README.md

Github Action for Lua and LuaJIT

leafo/gh-actions-lua

Actions Status

Update July 1 2020 A Lua 5.4 alias has been added in the most recent tagged version. The default version has been updated to 5.4 in v6.

Builds and installs Lua into the .lua/ directory in the working directory. Adds the .lua/bin to the PATH environment variable so lua can be called directly in workflows.

Other Lua GitHub actions:

Is your build failing when installing Lua? GitHub Action's Ubuntu base image changed default packages, please update to v5 or later

Usage

Install Lua: (Will typically default to the latest release, 5.4.1 as of this readme)

- uses: leafo/gh-actions-lua@v7

Install specific version of Lua:

- uses: leafo/gh-actions-lua@v7
  with:
    luaVersion: "5.1.5"

Install specific version of LuaJIT:

- uses: leafo/gh-actions-lua@v7
  with:
    luaVersion: "luajit-2.1.0-beta3"

Inputs

luaVersion

Default: "5.4"

Specifies the version of Lua to install. The version name instructs the action where to download the source from.

Examples of versions:

  • "5.1.5"
  • "5.2.4"
  • "5.3.5"
  • "5.4.1"
  • "luajit-2.0.5"
  • "luajit-2.1.0-beta3"
  • "luajit-openresty"

The version specifies where the source is downloaded from:

Version aliases

You can use shorthand 5.1, 5.2, 5.3, 5.4, luajit version aliases to point to the latest (or recent) version of Lua for that version.

Full Example

This example is for running tests on a Lua module that uses LuaRocks for dependencies and busted for a test suite.

Create .github/workflows/test.yml in your repository:

name: test

on: [push]

jobs:
  test:
    runs-on: ubuntu-latest

    steps:
    - uses: actions/checkout@master

    - uses: leafo/gh-actions-lua@v7
      with:
        luaVersion: "5.1.5"

    - uses: leafo/gh-actions-luarocks@v3

    - name: build
      run: |
        luarocks install busted
        luarocks make

    - name: test
      run: |
        busted -o utfTerminal

This example:

  • Uses Lua 5.1.5 — You can use another version by chaning the luaVersion varible. LuaJIT versions can be used by prefixing the version with luajit-, i.e. luajit-2.1.0-beta3
  • Uses a .rockspec file the root directory of your repository to install dependencies and test packaging the module via luarocks make

View the documentation for the individual actions (linked above) to learn more about how they work.

Version build matrix

You can test against multiple versions of Lua using a matrix strategy:

jobs:
  test:
    strategy:
      matrix:
        luaVersion: ["5.1.5", "5.2.4", "luajit-2.1.0-beta3"]

    steps:
    - uses: actions/checkout@master
    - uses: leafo/gh-actions-lua@v5
      with:
        luaVersion: ${{ matrix.luaVersion }}

    # ...
You can’t perform that action at this time.