Move cron to a CronJob, queue to a DaemonSet, and add a volume for container nginx files #69
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Tests | |
on: | |
pull_request: | |
types: [opened, synchronize, reopened] | |
env: | |
helm: v3.16.2 | |
python-version: 3.x | |
jobs: | |
linter: | |
name: Lint chart files | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- name: Set up Helm | |
uses: azure/setup-helm@v4 | |
with: | |
version: ${{ env.helm }} | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ env.python-version }} | |
- name: Set up chart-testing | |
uses: helm/chart-testing-action@v2 | |
- name: Run chart-testing (lint) | |
run: ct lint --config ct.yaml --target-branch ${{ github.event.repository.default_branch }} | |
helm-tests: | |
runs-on: ubuntu-latest | |
name: Helm tests (${{ matrix.test_cases.name }}) | |
strategy: | |
fail-fast: false | |
matrix: | |
test_cases: | |
- name: Default - no custom values | |
- name: PostgreSQL enabled | |
helm_args: '--set=internalDatabase.enabled=false --set=postgresql.enabled=true' | |
- name: Mariadb enabled | |
helm_args: '--set=internalDatabase.enabled=false --set=mariadb.enabled=true' | |
- name: Nodeport service enabled | |
helm_args: '--set=service.type=NodePort --set=service.nodePort=30001' | |
- name: nginx enabled | |
helm_args: '--set=nginx.enabled=true --set=image.tag=main-fpm' | |
- name: Horizontal Pod Autoscaling Enabled | |
helm_args: '--set=hpa.enabled=true --set=hpa.minPods=2 --set=hpa.maxPods=3 --set=hpa.cputhreshold=75' | |
- name: Redis and queue enabled | |
file: redis.yaml | |
- name: Meilisearch and queue enabled | |
file: meilisearch.yaml | |
# - name: External database | |
# external_database: true | |
# file: external_database.yaml | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- name: Set up Helm | |
uses: azure/setup-helm@v4 | |
with: | |
version: ${{ env.helm }} | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ env.python-version }} | |
- name: Set up chart-testing | |
uses: helm/chart-testing-action@v2 | |
- name: Run chart-testing (list-changed) | |
id: list-changed | |
run: | | |
changed=$(ct list-changed --config ct.yaml --target-branch ${{ github.event.repository.default_branch }}) | |
if [[ -n "$changed" ]]; then | |
echo "changed=true" >> $GITHUB_OUTPUT | |
fi | |
- name: Create kind cluster | |
uses: helm/kind-action@v1 | |
if: steps.list-changed.outputs.changed == 'true' | |
- name: Cp test case file | |
if: matrix.test_cases.file != '' | |
run: cp .github/tests/${{ matrix.test_cases.file }} charts/monica/ci/test-values.yaml | |
- name: Create mysql database | |
if: matrix.test_cases.external_database | |
run: | | |
sudo systemctl start mysql.service | |
mysql --protocol=tcp -u root -proot -e "CREATE DATABASE IF NOT EXISTS monica CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;" | |
hostname -I | |
IFS=' ' | |
read -ra hostname <<< $(hostname -I) | |
DB_HOST=${hostname[1]} | |
sed -i "s/%DB_HOST%/$DB_HOST/" charts/monica/ci/test-values.yaml | |
- name: Run chart-testing (install) | |
if: steps.list-changed.outputs.changed == 'true' | |
run: ct install --config ct.yaml --helm-extra-args '--timeout 600s' --target-branch ${{ github.event.repository.default_branch }} --helm-extra-set-args "${{ matrix.test_cases.helm_args }}" |