Skip to content

Merge pull request #166 from serpent213/main #384

Merge pull request #166 from serpent213/main

Merge pull request #166 from serpent213/main #384

Workflow file for this run

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
# Sets the ENV `MIX_ENV` to `test` for running tests
env:
MIX_ENV: test
EVISION_PREFER_PRECOMPILED: true
# VIX_COMPILATION_MODE: PLATFORM_PROVIDED_LIBVIPS
VIX_COMPILATION_MODE: PRECOMPILED_NIF_AND_LIBVIPS
permissions:
contents: read
jobs:
test:
# 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.
# services:
# db:
# image: postgres:12
# ports: ['5432:5432']
# env:
# POSTGRES_PASSWORD: postgres
# options: >-
# --health-cmd pg_isready
# --health-interval 10s
# --health-timeout 5s
# --health-retries 5
runs-on: ubuntu-latest
name: Test on OTP ${{matrix.otp}} / Elixir ${{matrix.elixir}}
strategy:
fail-fast: false
# Specify the OTP and Elixir versions to use when building
# and running the workflow steps.
matrix:
include:
# minimum required versions
- otp: "25.3"
elixir: "1.14.4-otp-25"
# latest
- otp: "27"
elixir: "1.17.2-otp-27"
lint: true
steps:
# 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@v4
# Step: Define how to cache deps. Restores existing cache if present.
- name: Cache deps
id: cache-deps
uses: actions/cache@v4
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@v4
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-
# Step: Install the dependencies for libvips
- name: Install libvips build dependencies
run: sudo apt-get install build-essential meson libwebp-dev libheif-dev libavif-dev libcgif0 libcgif-dev libxml2-dev libfftw3-dev libmagickwand-dev libopenexr-dev liborc-0.4-0 gobject-introspection libgirepository1.0-dev libgsf-1-dev libglib2.0-dev liborc-0.4-dev libpango1.0-dev libpangocairo-1.0-0 libpangoft2-1.0-0 curl xz-utils
# Install latest libvips
- name: Get latest version of libvips
run: |
VIPS_LATEST_RELEASE="https://github.com/libvips/libvips/releases/download/v8.14.4/vips-8.14.4.tar.xz"
echo "VIPS_LATEST_RELEASE=${VIPS_LATEST_RELEASE}" >> $GITHUB_ENV
- name: Cache libvips artifacts
uses: actions/cache@v4
id: vips-cache
with:
path: vips
key: ${{ runner.os }}-vips-${{ env.VIPS_LATEST_RELEASE }}
- name: Compile libvips from source
if: steps.vips-cache.outputs.cache-hit != 'true'
run: |
mkdir vips
curl -s -L "${VIPS_LATEST_RELEASE}" | unxz | tar x -C ./vips --strip-components=1
cd vips
meson setup build -Ddebug=false -Dcgif=enabled -Ddeprecated=false -Dexamples=false
cd build
meson compile
- name: Install libvips
run: |
cd vips/build
sudo meson install
sudo ldconfig -v
vips --vips-config
# 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
if: ${{ matrix.lint }}
# 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 --exclude text --exclude text_avatar --exclude video
# Step: Execute dialyzer.
- name: Run dialyzer
run: mix dialyzer
if: ${{ matrix.lint }}