Skip to content

feat: naive password storage #14

feat: naive password storage

feat: naive password storage #14

Workflow file for this run

name: Push
on: [ push, pull_request ]
env:
CARGO_TERM_COLOR: always
SQLX_VERSION: 0.6.3
SQLX_FEATURES: "rustls,postgres"
ARM_CLIENT_ID: ${{ secrets.AZURE_AD_CLIENT_ID }}
ARM_CLIENT_SECRET: ${{ secrets.AZURE_AD_CLIENT_SECRET }}
ARM_SUBSCRIPTION_ID: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
ARM_TENANT_ID: ${{ secrets.AZURE_AD_TENANT_ID }}
ARM_ACCESS_KEY: ${{ secrets.AZURE_TERRAFORM_ACCESS_KEY }}
jobs:
test:
name: Test
runs-on: ubuntu-latest
services:
postgres:
image: postgres:14
env:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: password
POSTGRES_DB: postgres
ports:
- 5432:5432
redis:
image: redis:7
ports:
- 6379:6379
steps:
- uses: actions/checkout@v3
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
with:
key: sqlx-${{ env.SQLX_VERSION }}
- name: Install sqlx-cli
run: cargo install sqlx-cli --version=${{ env.SQLX_VERSION }} --features ${{ env.SQLX_FEATURES }} --no-default-features --locked
- name: Migrate database
run: |
sudo apt-get install libpq-dev -y
SKIP_DOCKER=true ./scripts/init_db.sh
- name: Check sqlx-data.json is up-to-date
run: |
cargo sqlx prepare
cargo sqlx prepare --check -- --bin email_api
- name: Run tests
run: cargo test
fmt:
name: Rustfmt
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt
- name: Enforce formatting
run: cargo fmt --check
clippy:
name: Clippy
runs-on: ubuntu-latest
services:
postgres:
image: postgres:14
env:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: password
POSTGRES_DB: postgres
ports:
- 5432:5432
steps:
- uses: actions/checkout@v3
- uses: dtolnay/rust-toolchain@stable
with:
components: clippy
- uses: Swatinem/rust-cache@v2
with:
key: sqlx-${{ env.SQLX_VERSION }}
- name: Install sqlx-cli
run: cargo install sqlx-cli --version=${{ env.SQLX_VERSION }} --features ${{ env.SQLX_FEATURES }} --no-default-features --locked
- name: Migrate database
run: |
sudo apt-get install libpq-dev -y
SKIP_DOCKER=true ./scripts/init_db.sh
- name: Linting
run: cargo clippy -- -D warnings
coverage:
name: Code coverage
runs-on: ubuntu-latest
services:
postgres:
image: postgres:14
env:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: password
POSTGRES_DB: postgres
ports:
- 5432:5432
redis:
image: redis:7
ports:
- 6379:6379
steps:
- name: Checkout repository
uses: actions/checkout@v3
- uses: dtolnay/rust-toolchain@stable
- name: Install libpq
run: sudo apt-get update && sudo apt-get install postgresql-client -y
- uses: Swatinem/rust-cache@v2
with:
key: sqlx-${{ env.SQLX_VERSION }}
- name: Install tarpaulin
run: cargo install cargo-tarpaulin
- name: Install sqlx-cli
run: cargo install sqlx-cli --version=${{ env.SQLX_VERSION }} --features ${{ env.SQLX_FEATURES }} --no-default-features --locked
- name: Migrate database
run: SKIP_DOCKER=true ./scripts/init_db.sh
- name: Generate code coverage
run: cargo tarpaulin --verbose --workspace
# deploy:
# name: Build, push, and deploy
# needs: [ "test", "fmt", "clippy", "coverage" ]
# runs-on: ubuntu-latest
# steps:
# - name: Checkout master
# uses: actions/checkout@master
#
# - name: Deploy Terraform
# uses: ./.github/actions/deploy-terraform
# with:
# BACKEND_STATE_KEY: "terraform.tfstate"
# BACKEND_BUCKET_NAME: "rejdeboertfstate"
# WORKING_DIRECTORY: ./deployment
#
# - name: Build container image
# run: docker build -t emailapi.azurecr.io/repo:email-api .
#
# - name: Azure login
# run: az login
#
# - name: Push image to ACR
# run: docker push emailapi.azurecr.io/repo:email-api
#
# # TODO: Find better Kubernetes deployment strategy
# - name: Replace Environment Variables
# uses: danielr1996/[email protected]
# env:
# PORT: ${{ secrets.PORT }}
# DB_HOST: ${{ secrets.DB_HOST }}
# DB_USERNAME: ${{ secrets.DB_USERNAME }}
# DB_PORT: ${{ secrets.DB_PORT }}
# DB_PASSWORD: ${{ secrets.DB_PASSWORD }}
# DB_NAME: ${{ secrets.DB_NAME }}
# with:
# input: deployment.yml
# output: deploy.yml
#
# - name: Set AKS context
# id: set-context
# uses: azure/aks-set-context@v3
# with:
# resource-group: '${{ secrets.RESOURCE_GROUP }}'
# cluster-name: '${{ secrets.CLUSTER_NAME }}'
#
# - name: Setup kubectl
# id: install-kubectl
# uses: azure/setup-kubectl@v3