2022-12-19 23:06:03 -05:00
|
|
|
name: Elixir CI
|
|
|
|
|
|
|
|
# Define workflow that runs when changes are pushed to the
|
|
|
|
# `main` branch or pushed to a PR branch that targets the `main`
|
|
|
|
# branch. Change the branch name if your project uses a
|
|
|
|
# different name for the main branch like "master" or "production".
|
|
|
|
on:
|
|
|
|
push:
|
|
|
|
branches: [ "main" ] # adapt branch for project
|
|
|
|
pull_request:
|
|
|
|
branches: [ "main" ] # adapt branch for project
|
|
|
|
|
|
|
|
env:
|
|
|
|
MIX_ENV: test
|
2022-12-29 20:29:40 -05:00
|
|
|
NODE_ID: aUniqueString
|
2022-12-19 22:56:59 -05:00
|
|
|
|
|
|
|
jobs:
|
|
|
|
test:
|
2022-12-19 23:06:03 -05:00
|
|
|
# Set up a Postgres DB service. By default, Phoenix applications
|
|
|
|
# use Postgres. This creates a database for running tests.
|
|
|
|
# Additional services can be defined here if required.
|
2022-12-19 22:56:59 -05:00
|
|
|
services:
|
|
|
|
db:
|
2022-12-19 23:06:03 -05:00
|
|
|
image: postgres:14
|
2022-12-19 22:56:59 -05:00
|
|
|
ports: ['5432:5432']
|
|
|
|
env:
|
|
|
|
POSTGRES_PASSWORD: postgres
|
|
|
|
options: >-
|
|
|
|
--health-cmd pg_isready
|
|
|
|
--health-interval 10s
|
|
|
|
--health-timeout 5s
|
|
|
|
--health-retries 5
|
|
|
|
|
2022-12-19 23:06:03 -05:00
|
|
|
runs-on: ubuntu-latest
|
|
|
|
name: Test on OTP ${{matrix.otp}} / Elixir ${{matrix.elixir}}
|
|
|
|
strategy:
|
|
|
|
# Specify the OTP and Elixir versions to use when building
|
|
|
|
# and running the workflow steps.
|
|
|
|
matrix:
|
|
|
|
otp: ['25.0.4'] # Define the OTP version [required]
|
2023-09-14 11:38:16 -04:00
|
|
|
elixir: ['1.14.3'] # Define the elixir version [required]
|
2022-12-19 22:56:59 -05:00
|
|
|
steps:
|
2022-12-19 23:06:03 -05:00
|
|
|
# Step: Setup Elixir + Erlang image as the base.
|
|
|
|
- name: Set up Elixir
|
|
|
|
uses: erlef/setup-beam@v1
|
|
|
|
with:
|
|
|
|
otp-version: ${{matrix.otp}}
|
|
|
|
elixir-version: ${{matrix.elixir}}
|
|
|
|
|
|
|
|
# Step: Check out the code.
|
|
|
|
- name: Checkout code
|
|
|
|
uses: actions/checkout@v3
|
|
|
|
|
|
|
|
# Step: Define how to cache deps. Restores existing cache if present.
|
|
|
|
- name: Cache deps
|
|
|
|
id: cache-deps
|
|
|
|
uses: actions/cache@v3
|
|
|
|
env:
|
|
|
|
cache-name: cache-elixir-deps
|
|
|
|
with:
|
|
|
|
path: deps
|
|
|
|
key: ${{ runner.os }}-mix-${{ env.cache-name }}-${{ hashFiles('**/mix.lock') }}
|
|
|
|
restore-keys: |
|
|
|
|
${{ runner.os }}-mix-${{ env.cache-name }}-
|
|
|
|
|
|
|
|
# Step: Define how to cache the `_build` directory. After the first run,
|
|
|
|
# this speeds up tests runs a lot. This includes not re-compiling our
|
|
|
|
# project's downloaded deps every run.
|
|
|
|
- name: Cache compiled build
|
|
|
|
id: cache-build
|
|
|
|
uses: actions/cache@v3
|
|
|
|
env:
|
|
|
|
cache-name: cache-compiled-build
|
|
|
|
with:
|
|
|
|
path: _build
|
|
|
|
key: ${{ runner.os }}-mix-${{ env.cache-name }}-${{ hashFiles('**/mix.lock') }}
|
|
|
|
restore-keys: |
|
|
|
|
${{ runner.os }}-mix-${{ env.cache-name }}-
|
|
|
|
${{ runner.os }}-mix-
|
|
|
|
|
|
|
|
- name: Install ncurses
|
|
|
|
run: sudo apt install -y libncurses5-dev libncursesw5-dev
|
|
|
|
|
|
|
|
# Step: Download project dependencies. If unchanged, uses
|
|
|
|
# the cached version.
|
|
|
|
- name: Install dependencies
|
|
|
|
run: mix deps.get
|
|
|
|
|
|
|
|
# Step: Compile the project treating any warnings as errors.
|
|
|
|
# Customize this step if a different behavior is desired.
|
|
|
|
- name: Compiles without warnings
|
|
|
|
run: mix compile --warnings-as-errors
|
|
|
|
|
|
|
|
# Step: Check that the checked in code has already been formatted.
|
|
|
|
# This step fails if something was found unformatted.
|
|
|
|
# Customize this step as desired.
|
|
|
|
- name: Check Formatting
|
|
|
|
run: mix format --check-formatted
|
|
|
|
|
|
|
|
# Step: Execute the tests.
|
|
|
|
- name: Run tests
|
|
|
|
run: mix test
|