forked from scipy/scipy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
.cirrus.star
41 lines (34 loc) · 1.72 KB
/
.cirrus.star
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
# The guide to programming cirrus-ci tasks using starlark is found at
# https://cirrus-ci.org/guide/programming-tasks/
#
# In this simple starlark script we simply check conditions for whether
# a CI run should go ahead. If the conditions are met, then we just
# return the yaml containing the tasks to be run.
load("cirrus", "env", "fs", "http")
def main(ctx):
######################################################################
# Should wheels be built?
# Only test on the scipy/scipy repository
# Test if the run was triggered by:
# - a cron job called "nightly". The cron job is not set in this file,
# but on the cirrus-ci repo page
# - commit message containing [wheel build]
######################################################################
if env.get("CIRRUS_REPO_FULL_NAME") != "scipy/scipy":
return []
if env.get("CIRRUS_CRON", "") == "nightly":
return fs.read("ci/cirrus_wheels.yml")
# Obtain commit message for the event. Unfortunately CIRRUS_CHANGE_MESSAGE
# only contains the actual commit message on a non-PR trigger event.
# For a PR event it contains the PR title and description.
SHA = env.get("CIRRUS_CHANGE_IN_REPO")
url = "https://api.github.com/repos/scipy/scipy/git/commits/" + SHA
dct = http.get(url).json()
if "[wheel build]" in dct["message"]:
return fs.read("ci/cirrus_wheels.yml")
# this configuration runs a single linux_aarch64 + macosx_arm64 run.
# there's no need to do this during a wheel run as they automatically build
# and test over a wider range of Pythons.
if "[skip cirrus]" in dct["message"] or "[skip ci]" in dct["message"]:
return []
return fs.read("ci/cirrus_general_ci.yml")