forked from conda-incubator/conda-recipe-manager
-
Notifications
You must be signed in to change notification settings - Fork 0
74 lines (65 loc) · 2.32 KB
/
integration_tests.yaml
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
on:
workflow_dispatch: # This allows manual triggering of the workflow from the GitHub UI
jobs:
integration-builds:
runs-on: ubuntu-latest
timeout-minutes: 60
strategy:
fail-fast: false
matrix:
test-directory:
- anaconda_recipes_01
- conda_forge_recipes_01
steps:
# Clone the test data repository
- uses: actions/checkout@v4
# Checkout conda-recipe-manager-test-data repository
- uses: actions/checkout@v4
with:
repository: conda-incubator/conda-recipe-manager-test-data
path: test_data
# Setup the environment
- name: Setup Conda Environment
run: |
source $CONDA/bin/activate
conda create -y -n conda-recipe-manager python=3.11
conda activate conda-recipe-manager
conda install -y -c conda-forge rattler-build jq conda-recipe-manager
# Verify crm command is available
- name: Verify crm is available
run: |
which crm || echo "crm command not found"
# Load the allow-list from the JSON configuration
- name: Load Allow-List
run: |
echo "Loading allow-list from integration_build_test_config.json"
ALLOW_LIST=$(cat integration_build_test_config.json | jq -r '.v0_test_files[]')
echo "$ALLOW_LIST" > allow_list.txt
# Process each recipe: Convert V0 to V1 and run a full build
- name: Full Build with rattler-build
run: |
mkdir -p logs
set -o pipefail
while read -r recipe; do
echo "Processing recipe: $recipe"
crm convert "$recipe" --output recipe.yaml | tee -a logs/convert.log
rattler-build build recipe.yaml | tee -a logs/build.log || echo "Build failed for $recipe" >> logs/failed_recipes.log
done < allow_list.txt
# Upload logs as artifacts
- uses: actions/upload-artifact@v4
with:
name: full-build-logs
path: logs/
final-report:
runs-on: ubuntu-latest
needs: [integration-builds]
steps:
# Download logs
- uses: actions/download-artifact@v4
with:
name: full-build-logs
path: logs/
# Generate Final Report
- name: Generate Report
run: |
python scripts/parse_full_build_logs.py logs/