summaryrefslogtreecommitdiff
path: root/.github/workflows/tests.yml
blob: f54fc480f4fa50e658a43c12fca84f6ae4def7d5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
---
name: Tests

on:
    push:
        branches:
            - main
    pull_request:

env:
    PYTHON_VERSION: 3.12

jobs:
    tests:
        runs-on: ubuntu-24.04

        services:
            postgres:
                image: postgres:17-trixie
                env:
                    POSTGRES_PASSWORD: postgres
                options: >-
                    --health-cmd pg_isready
                    --health-interval 10s
                    --health-timeout 5s
                    --health-retries 5
                ports:
                    - 5432:5432

        steps:
            - uses: actions/checkout@v6
            - name: Set up Python
              uses: actions/setup-python@v6
              with:
                  python-version: ${{ env.PYTHON_VERSION }}
            - name: Install gettext
              run: sudo apt-get update && sudo apt-get install -y gettext
            - name: Install dependencies
              run: |
                  python -m pip install --upgrade pip setuptools
                  python -m pip install -r requirements/tests.txt
            - name: Install playwright browsers
              run: |
                  python -m playwright install --with-deps chromium
            - name: Set up databases
              run: |
                  PGPASSWORD="postgres" createuser -U postgres -d djangoproject --superuser -h localhost
                  PGPASSWORD="postgres" createdb -U postgres -O djangoproject djangoproject -h localhost
                  PGPASSWORD="postgres" createuser -U postgres -d code.djangoproject --superuser -h localhost
                  PGPASSWORD="postgres" createdb -U postgres -O code.djangoproject code.djangoproject -h localhost
                  PGPASSWORD="postgres" psql -U postgres -h localhost -c "ALTER USER djangoproject WITH PASSWORD 'secret';"
                  PGPASSWORD="postgres" psql -U postgres -h localhost -c "ALTER USER \"code.djangoproject\" WITH PASSWORD 'secret';"
            - name: Load Trac data
              run: |
                  PGPASSWORD="postgres" psql -U postgres -d code.djangoproject -h localhost < tracdb/trac.sql
            - name: Create secrets.json
              working-directory: ..
              run: |
                  mkdir conf
                  echo '{"db_host": "localhost", ' > conf/secrets.json
                  echo '"db_password": "secret", ' >> conf/secrets.json
                  echo '"trac_db_host": "localhost", ' >> conf/secrets.json
                  echo '"trac_db_password": "secret", ' >> conf/secrets.json
                  echo '"secret_key": "a"}' >> conf/secrets.json

            - name: Run tests
              run: |
                  make ci
                  coverage xml

            - name: Upload coverage reports to Codecov
              uses: codecov/codecov-action@v5
              with:
                  token: ${{ secrets.CODECOV_TOKEN }}