From 33783e4c2fcafd40814eda19f3c27995db672c63 Mon Sep 17 00:00:00 2001 From: Jonas Schmidt Date: Mon, 17 Jul 2023 11:13:31 +0200 Subject: [PATCH] Create elixir.yml --- .github/workflows/elixir.yml | 55 ++++++++++++++++++++++++++++++++++++ mix.exs | 2 +- 2 files changed, 56 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/elixir.yml diff --git a/.github/workflows/elixir.yml b/.github/workflows/elixir.yml new file mode 100644 index 0000000..e365c2c --- /dev/null +++ b/.github/workflows/elixir.yml @@ -0,0 +1,55 @@ +# This workflow uses actions that are not certified by GitHub. +# They are provided by a third-party and are governed by +# separate terms of service, privacy policy, and support +# documentation. + +name: Elixir CI + +on: + push: + branches: ["github-actions"] + pull_request: + branches: ["github-actions"] + +permissions: + contents: read + +jobs: + build: + + name: Build and test + runs-on: ubuntu-latest + env: + MIX_ENV: test + + steps: + - uses: actions/checkout@v3 + with: + submodules: recursive + - name: Set up Elixir + uses: erlef/setup-beam@61e01a43a562a89bfc54c7f9a378ff67b03e4a21 # v1.16.0 + with: + elixir-version: '1.15.2' # [Required] Define the Elixir version + otp-version: '25.3' # [Required] Define the Erlang/OTP version + - name: Restore dependencies cache + uses: actions/cache@v3 + with: + path: deps + key: ${{ runner.os }}-deps-${{ hashFiles('**/mix.lock') }} + restore-keys: ${{ runner.os }}-deps- + - name: Restore build cache + uses: actions/cache@v3 + with: + path: _build/test + key: ${{ runner.os }}-build-${{ hashFiles('**/mix.lock') }} + restore-keys: ${{ runner.os }}-build- + - name: Install dependencies + run: mix deps.get + - name: Compile dependencies + run: mix deps.compile + - name: Compile + run: mix compile --warnings-as-errors + - name: Dialyzer + run: mix dialyzer --halt-exit-status + - name: Run tests + run: mix test diff --git a/mix.exs b/mix.exs index 5be2e06..03fe51f 100644 --- a/mix.exs +++ b/mix.exs @@ -21,7 +21,7 @@ defmodule ExJsonSchema.Mixfile do preferred_cli_env: [coveralls: :test, dialyzer: :test], dialyzer: [ plt_add_apps: [:ex_unit], - plt_core_path: ".", + plt_core_path: "_build/#{Mix.env()}", plt_add_deps: :transitive ] ]