-
Notifications
You must be signed in to change notification settings - Fork 83
164 lines (144 loc) · 6.65 KB
/
map_new_plugins.yml
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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
name: Perform layer mapping
# THIS WORKFLOW ONLY WORKS WHEN NEW_MODEL CHANGES ARE MADE. BENCHMARKS ARE NOT SUPPORTED
on:
status:
pull_request:
types: [labeled, synchronize]
jobs:
# Trigger Layer Mapping only on web_submissions OR if trigger-mapping label is added to PR
check_jenkins_jobs:
name: Check Triggers
runs-on: ubuntu-latest
outputs:
all_checks_passed: ${{ steps.check_jenkins_jobs.outputs.all_checks_passed }}
if: |
(
(
startsWith(github.head_ref, 'web_submission_') &&
endsWith(github.head_ref, '/add_plugins')
)
|| contains(github.event.pull_request.labels.*.name, 'trigger-mapping')
)
steps:
# Wait for Plugin Unit Test Checks to complete
- name: Check if both Jenkins jobs are successful
id: check_jenkins_jobs
run: |
required_checks=("Brain-Score Plugins Unit tests (AWS Jenkins, AWS Execution)" "Brain-Score Non-Plugin Unit tests (AWS Jenkins, AWS Execution)")
completed_checks=0
all_checks_passed=true
echo "Using github PR head sha: ${{ github.event.pull_request.head.sha }}"
# Fetch the status of all checks for this commit
statuses=$(curl -s -H "Authorization: token ${{ secrets.GITHUB_TOKEN }}" \
"https://api.github.com/repos/brain-score/vision/commits/${{ github.event.pull_request.head.sha }}/status")
echo "Statuses response from GitHub API:"
echo "$statuses" | jq '.statuses[] | {context: .context, state: .state}'
# Loop through each required check and verify if it has succeeded
for check in "${required_checks[@]}"; do
if echo "$statuses" | jq -e --arg check "$check" '.statuses[] | select(.context == $check and .state == "success")' > /dev/null; then
echo "Job '$check' is successful."
((completed_checks+=1))
else
echo "Job '$check' is NOT successful."
all_checks_passed=false
fi
done
echo "Completed checks: $completed_checks / ${#required_checks[@]}"
echo "all_checks_passed=$all_checks_passed" >> $GITHUB_OUTPUT
trigger_layer_mapping:
name: Trigger Layer Mapping
runs-on: ubuntu-latest
needs: check_jenkins_jobs
if: ${{ needs.check_jenkins_jobs.outputs.all_checks_passed == 'true' }}
steps:
# Check out PR head
- name: Check out repository code
uses: actions/checkout@v4
with:
ref: ${{ github.head_ref }}
fetch-depth: 0
# Set up Python 3.11 because we are using some brainscore_core functions
- name: Set up Python 3.11
uses: actions/setup-python@v4
with:
python-version: 3.11
# Install dependencies
- name: Install dependencies
run: |
python -m pip install --upgrade pip setuptools
python -m pip install ".[test]"
# Get a list of changed files. `score_new_plugins.yml` version was not working on my forked branch
# because it was always comparing to origin/masster. Can revert back to score version of this step
- name: Get Changed Files
id: changed_files
uses: actions/github-script@v6
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
script: |
const prNumber = ${{ github.event.number }};
const { data: files } = await github.rest.pulls.listFiles({
owner: context.repo.owner,
repo: context.repo.repo,
pull_number: prNumber,
per_page: 100,
});
const changedFiles = files.map(f => f.filename).join(' ');
core.setOutput('files', changedFiles);
# Store changed files as a variable
- name: Set CHANGED_FILES
run: |
echo "CHANGED_FILES=${{ steps.changed_files.outputs.files }}" >> $GITHUB_ENV
# Parse changes for relevant information
- name: Get plugin info
id: getplugininfo
run: |
set -e
# Execute the Python script and capture the JSON output
PLUGIN_INFO=$(python -c "from brainscore_core.plugin_management.parse_plugin_changes import get_scoring_info; get_scoring_info('${{ env.CHANGED_FILES }}', 'brainscore_vision')")
# Set the output correctly without extra quotes
echo "PLUGIN_INFO=$PLUGIN_INFO" >> $GITHUB_OUTPUT
# Debug output to verify
echo "PLUGIN_INFO is $PLUGIN_INFO"
# Extract run_score and store in RUN_MAPPING
- name: Check if layer mapping needed
id: mappingneeded
run: |
RUN_MAPPING=$(echo '${{ steps.getplugininfo.outputs.PLUGIN_INFO }}' | jq -r '.run_score')
echo "RUN_MAPPING=$RUN_MAPPING" >> $GITHUB_OUTPUT
echo "RUN_MAPPING is $RUN_MAPPING"
# Extract list of new_models and the pr_number and store as env var
- name: Extract new_models and pr_number
run: |
set -e
PLUGIN_INFO="${PLUGIN_INFO}"
NEW_MODELS=$(echo '${{ steps.getplugininfo.outputs.PLUGIN_INFO }}' | jq -r '.new_models')
PR_NUMBER="${{ github.event.number }}"
echo "NEW_MODELS=$NEW_MODELS"
echo "PR_NUMBER=$PR_NUMBER"
echo "NEW_MODELS=$NEW_MODELS" >> $GITHUB_ENV
echo "PR_NUMBER=$PR_NUMBER" >> $GITHUB_ENV
# If new_models is not empty and run_mapping is true, trigger Jenkins with correct payload
- name: Trigger Jenkins
if: ${{ steps.mappingneeded.outputs.RUN_MAPPING == 'True' && env.NEW_MODELS != '' }}
env:
JENKINS_USER: ${{ secrets.JENKINS_MAPPING_USER }}
JENKINS_USER_API: ${{ secrets.JENKINS_MAPPING_USER_API }}
JENKINS_TOKEN: ${{ secrets.JENKINS_MAPPING_TOKEN }}
JENKINS_TRIGGER: ${{ secrets.JENKINS_MAPPING_URL }}
# Relevant parameters for the Jenkins job
NEW_MODELS: ${{ env.NEW_MODELS }}
SOURCE_REPO: ${{ github.event.pull_request.head.repo.clone_url }}
SOURCE_BRANCH: ${{ github.head_ref }}
PR_NUMBER: ${{ env.PR_NUMBER }}
run: |
if [[ -z "$JENKINS_TRIGGER" || -z "$JENKINS_USER" || -z "$JENKINS_USER_API" || -z "$JENKINS_TOKEN" ]]; then
echo "One or more Jenkins environment variables are empty. Aborting."
exit 1
fi
curl -X POST "$JENKINS_TRIGGER" \
--user "$JENKINS_USER:$JENKINS_USER_API" \
--data-urlencode "NEW_MODELS=$NEW_MODELS" \
--data-urlencode "PR_NUMBER=$PR_NUMBER" \
--data-urlencode "SOURCE_REPO=$SOURCE_REPO" \
--data-urlencode "SOURCE_BRANCH=$SOURCE_BRANCH" \
--data-urlencode "TOKEN=$JENKINS_TOKEN"