-
Notifications
You must be signed in to change notification settings - Fork 0
113 lines (101 loc) · 4.39 KB
/
test.yml
File metadata and controls
113 lines (101 loc) · 4.39 KB
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
# Canvas Learning System - Test Pipeline
# Story 30.23: CI pipeline activation for automated regression protection
#
# Runs non-integration tests on PRs and pushes.
# Integration tests requiring Docker/external services are excluded.
name: Test Suite
on:
pull_request:
paths:
- 'backend/**'
push:
branches:
- main
- clean-release
paths:
- 'backend/**'
jobs:
# ═══════════════════════════════════════════════════════════════════════════════
# All Tests (excluding @pytest.mark.integration — no Docker in CI)
# ═══════════════════════════════════════════════════════════════════════════════
tests:
name: Tests (Python ${{ matrix.python-version }})
runs-on: ubuntu-latest
timeout-minutes: 5
strategy:
matrix:
python-version: ['3.11', '3.12']
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
cache: 'pip'
cache-dependency-path: backend/requirements.txt
- name: Install dependencies
run: |
cd backend
pip install -r requirements.txt
- name: Create reports directory
run: mkdir -p backend/reports
- name: Run tests
run: |
cd backend
python -m pytest tests/ \
-m "not integration" \
-v --tb=short \
--junitxml=reports/test-results.xml \
-q --no-header \
-p no:cacheprovider \
--override-ini="addopts=" 2>&1
- name: Upload test results
if: always()
uses: actions/upload-artifact@v4
with:
name: test-results-py${{ matrix.python-version }}
path: backend/reports/test-results.xml
retention-days: 14
# ═══════════════════════════════════════════════════════════════════════════════
# Dependency Audit (EPIC-33 NFR Security)
# ═══════════════════════════════════════════════════════════════════════════════
security:
name: Dependency Audit
runs-on: ubuntu-latest
timeout-minutes: 3
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.12'
- name: Run pip-audit
continue-on-error: true
run: |
pip install pip-audit
pip-audit -r backend/requirements.txt --desc
# ═══════════════════════════════════════════════════════════════════════════════
# Summary
# ═══════════════════════════════════════════════════════════════════════════════
summary:
name: Test Summary
runs-on: ubuntu-latest
needs: [tests, security]
if: always()
steps:
- name: Generate summary
run: |
echo "## Test Suite Summary" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY
echo "| Suite | Status |" >> $GITHUB_STEP_SUMMARY
echo "|-------|--------|" >> $GITHUB_STEP_SUMMARY
if [ "${{ needs.tests.result }}" == "success" ]; then
echo "| Tests (non-integration) | :white_check_mark: |" >> $GITHUB_STEP_SUMMARY
else
echo "| Tests (non-integration) | :x: |" >> $GITHUB_STEP_SUMMARY
fi
if [ "${{ needs.security.result }}" == "success" ]; then
echo "| Dependency Audit | :white_check_mark: |" >> $GITHUB_STEP_SUMMARY
else
echo "| Dependency Audit | :warning: |" >> $GITHUB_STEP_SUMMARY
fi