From d800f511de8d9be90aeada1094b804d8aa0aeb57 Mon Sep 17 00:00:00 2001 From: Samuel Levy Date: Fri, 20 Jan 2023 21:01:48 -0300 Subject: [PATCH 1/5] Add GItHub CI --- .github/workflows/elixir.yaml | 102 ++++++++++++++++++++++++++++++++++ 1 file changed, 102 insertions(+) create mode 100644 .github/workflows/elixir.yaml diff --git a/.github/workflows/elixir.yaml b/.github/workflows/elixir.yaml new file mode 100644 index 00000000..ffe47e3a --- /dev/null +++ b/.github/workflows/elixir.yaml @@ -0,0 +1,102 @@ +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 + +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: + # Specify the OTP and Elixir versions to use when building + # and running the workflow steps. + matrix: + otp: ['24.1.1'] # Define the OTP version [required] + elixir: ['1.13.2'] # Define the elixir version [required] + 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@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- + + # 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 From 2e4d3e2cf7bccd498e353d355dfad4fba17f93aa Mon Sep 17 00:00:00 2001 From: Samuel Levy Date: Fri, 20 Jan 2023 21:04:56 -0300 Subject: [PATCH 2/5] Change otp version --- .github/workflows/elixir.yaml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/elixir.yaml b/.github/workflows/elixir.yaml index ffe47e3a..fc38b629 100644 --- a/.github/workflows/elixir.yaml +++ b/.github/workflows/elixir.yaml @@ -40,8 +40,8 @@ jobs: # Specify the OTP and Elixir versions to use when building # and running the workflow steps. matrix: - otp: ['24.1.1'] # Define the OTP version [required] - elixir: ['1.13.2'] # Define the elixir version [required] + otp: ['24.1'] # Define the OTP version [required] + elixir: ['1.13.2'] # Define the elixir version [required] steps: # Step: Setup Elixir + Erlang image as the base. - name: Set up Elixir From dd2fd47a967ca5168a217d65e0d606c9fb04aeec Mon Sep 17 00:00:00 2001 From: Samuel Levy Date: Fri, 20 Jan 2023 21:11:48 -0300 Subject: [PATCH 3/5] Change otp and elixir versions --- .github/workflows/elixir.yaml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/elixir.yaml b/.github/workflows/elixir.yaml index fc38b629..0276cece 100644 --- a/.github/workflows/elixir.yaml +++ b/.github/workflows/elixir.yaml @@ -40,8 +40,8 @@ jobs: # Specify the OTP and Elixir versions to use when building # and running the workflow steps. matrix: - otp: ['24.1'] # Define the OTP version [required] - elixir: ['1.13.2'] # Define the elixir version [required] + otp: ['25.0.4'] # Define the OTP version [required] + elixir: ['1.14.1'] # Define the elixir version [required] steps: # Step: Setup Elixir + Erlang image as the base. - name: Set up Elixir From 7abde04017f5d2bc5abecf107fed402459b554d2 Mon Sep 17 00:00:00 2001 From: Samuel Levy Date: Fri, 20 Jan 2023 21:16:18 -0300 Subject: [PATCH 4/5] Remove warning as errors --- .github/workflows/elixir.yaml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/elixir.yaml b/.github/workflows/elixir.yaml index 0276cece..0b41ff2b 100644 --- a/.github/workflows/elixir.yaml +++ b/.github/workflows/elixir.yaml @@ -88,8 +88,8 @@ jobs: # 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 + - name: Compiles + run: mix compile # Step: Check that the checked in code has already been formatted. # This step fails if something was found unformatted. From d9bcd826c4cb2808ce906ef9f7dca7c9d93e9cf2 Mon Sep 17 00:00:00 2001 From: Samuel Levy Date: Fri, 20 Jan 2023 21:20:05 -0300 Subject: [PATCH 5/5] Mix format --- config/prod.exs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/config/prod.exs b/config/prod.exs index e81a1d77..ddfc8e05 100644 --- a/config/prod.exs +++ b/config/prod.exs @@ -51,7 +51,8 @@ config :sig_live, SigLive.Endpoint, config :logger, level: :info config :sentry, - dsn: "https://beec3ef07da54b178efde3905c913d0c@o4504494316716032.ingest.sentry.io/4504494320058368", + dsn: + "https://beec3ef07da54b178efde3905c913d0c@o4504494316716032.ingest.sentry.io/4504494320058368", environment_name: :prod, enable_source_code_context: true, root_source_code_path: File.cwd!(),