forked from openshift/release
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmkpjpod.sh
executable file
·38 lines (36 loc) · 1.25 KB
/
mkpjpod.sh
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
#!/bin/bash
# Create a pod from a Prow job using the test-infra mkpj and mkpod utilities.
# The required information about the pull request can be passed in a few
# different ways:
#
# 1. Passing the pull request number as the only argument. `mkpj`'s defaulting
# behavior will use Github's API to fetch the required information.
# Convenient, but has been victim of API throttling in the past.
# 2. Passing the required information as environment variables. See the
# `pj_env.py` script for a way to set them using `git`. The variables are:
#
# - BASE_REF
# - BASE_SHA
# - PULL_NUMBER
# - PULL_SHA
# - PULL_AUTHOR
set -euo pipefail
run() {
docker run \
--rm \
--volume "$PWD:/tmp/release:z" \
--workdir /tmp/release \
registry.svc.ci.openshift.org/ci/test-infra:binaries \
bash -c '/go/bin/mkpj "$@" | /go/bin/mkpod --prow-job -' -- \
--config-path cluster/ci/config/prow/config.yaml \
--job-config-path ci-operator/jobs/ \
"$@"
}
case "$#" in
1) run --job "$1" \
--base-ref "$BASE_REF" --base-sha "$BASE_SHA" \
--pull-number "$PULL_NUMBER" --pull-sha "$PULL_SHA" \
--pull-author "$PULL_AUTHOR";;
2) run --job "$1" --pull-number "$2";;
*) echo >&2 "Usage: $0 job_name [pull_number]"; exit 1;;
esac