blob: fd9341852f49757d8ddd38c49f5d2563fe326c23 [file] [log] [blame]
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -05001#!/usr/bin/env bash
2#
Mikael Olssonfb99d0a2023-03-09 14:58:48 +01003# Copyright (c) 2021-2023 Arm Limited. All rights reserved.
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -05004#
5# SPDX-License-Identifier: BSD-3-Clause
6#
7# Clones and checkout TF-A related repositories in case these are not present
8# under SHARE_FOLDER, otherwise copy the share repositories into current folder
9# (workspace)
10
11# The way it works is simple: the top level job sets the SHARE_FOLDER
12# parameter based on its name and number on top of the share
13# volume (/srv/shared/<job name>/<job number>) then it calls the clone
14# script (clone.sh), which in turn it fetches the repositories mentioned
15# above. Jobs triggered on behalf of the latter, share the same
16# SHARE_FOLDER value, and these in turn also call the clone script, but
17# in this case, the script detects that the folder is already populated so
18# its role is to simply copy the repositories into the job's
19# workspace. As seen, all jobs work with repositories on their own
20# workspace, which are just copies of the share folder, so there is no
21# change of a race condition, i.e every job works with its own copy. The
22# worst case scenario is where the down-level job, tf-a-builder, uses its
23# default SHARE_FOLDER value, in this case, it would simply clone its
24# own repositories without reusing any file however the current approach
25# prevents the latter unless the job is triggered manually from the
26# builder job itself.
27
Chris Kayb0392862022-12-23 13:48:01 +000028set -ex
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -050029
30# Global defaults
31REFSPEC_MASTER="refs/heads/master"
Manish V Badarkheb75a15e2025-04-11 09:16:55 +010032REFSPEC_MAIN="refs/heads/main"
Manish V Badarkhe7415ae52024-10-16 08:30:06 +010033REFSPEC_TF_M_TESTS="refs/heads/tfa_ci_dep_revision"
34REFSPEC_TF_M_EXTRAS="refs/heads/tfa_ci_dep_revision"
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -050035GIT_REPO="https://git.trustedfirmware.org"
36GERRIT_HOST="https://review.trustedfirmware.org"
Leonardo Sandoval49a18a42021-09-26 19:48:53 -050037GIT_CLONE_PARAMS=""
Paul Sokolovskyd6b76192023-06-20 16:18:35 +030038SSH_PARAMS="-o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -o PubkeyAcceptedKeyTypes=+ssh-rsa -p 29418 -i ${CI_BOT_KEY}"
Arthur She3eb254e2022-09-18 20:41:03 -070039GERRIT_QUERY_PARAMS="--format=JSON --patch-sets --current-patch-set status:open"
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -050040
41# Defaults Projects
Saheer Babufd524222025-01-21 23:42:41 +000042TF_GERRIT_PROJECT="${TF_GERRIT_PROJECT:-next/TF-A/trusted-firmware-a}"
Jimmy Brisson2fbc06c2023-06-09 08:49:09 -050043TF_M_TESTS_GERRIT_PROJECT="${TF_M_TESTS_GERRIT_PROJECT:-TF-M/tf-m-tests}"
44TF_M_EXTRAS_GERRIT_PROJECT="${TF_M_EXTRAS_GERRIT_PROJECT:-TF-M/tf-m-extras}"
Saheer Babufd524222025-01-21 23:42:41 +000045TFTF_GERRIT_PROJECT="${TFTF_GERRIT_PROJECT:-next/TF-A/tf-a-tests}"
Daniel Boulby9dbe6f12023-11-30 15:29:10 +000046SPM_GERRIT_PROJECT="${SPM_GERRIT_PROJECT:-hafnium/hafnium}"
Manish V Badarkheaa6c48f2025-04-09 14:03:26 +010047RMM_GERRIT_PROJECT="${RMM_GERRIT_PROJECT:-TF-RMM/tf-rmm}"
Arthur She3eb254e2022-09-18 20:41:03 -070048CI_GERRIT_PROJECT="${CI_GERRIT_PROJECT:-ci/tf-a-ci-scripts}"
49JOBS_PROJECT="${JOBS_PROJECT:-ci/tf-a-job-configs.git}"
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -050050
51# Default Reference specs
52TF_GERRIT_REFSPEC="${TF_GERRIT_REFSPEC:-${REFSPEC_MASTER}}"
53TFTF_GERRIT_REFSPEC="${TFTF_GERRIT_REFSPEC:-${REFSPEC_MASTER}}"
Daniel Boulby9dbe6f12023-11-30 15:29:10 +000054SPM_REFSPEC="${SPM_REFSPEC:-${REFSPEC_MASTER}}"
Manish V Badarkheb75a15e2025-04-11 09:16:55 +010055RMM_REFSPEC="${RMM_REFSPEC:-${REFSPEC_MAIN}}"
Manish V Badarkhe7415ae52024-10-16 08:30:06 +010056TF_M_TESTS_GERRIT_REFSPEC="${TF_M_TESTS_GERRIT_REFSPEC:-${REFSPEC_TF_M_TESTS}}"
57TF_M_EXTRAS_GERRIT_REFSPEC="${TF_M_EXTRAS_GERRIT_REFSPEC:-${REFSPEC_TF_M_EXTRAS}}"
Zelalem Awekee8801df2021-10-25 13:41:44 -050058CI_REFSPEC="${CI_REFSPEC:-${REFSPEC_MASTER}}"
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -050059JOBS_REFSPEC="${JOBS_REFSPEC:-${REFSPEC_MASTER}}"
60
Arthur She3eb254e2022-09-18 20:41:03 -070061JOBS_REPO_NAME="tf-a-job-configs"
62
63# Array containing "<repo host>;<project>;<repo name>;<refspec>" elements
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -050064repos=(
Arthur She3eb254e2022-09-18 20:41:03 -070065 "${GERRIT_HOST};${CI_GERRIT_PROJECT};tf-a-ci-scripts;${CI_REFSPEC}"
66 "${GERRIT_HOST};${TF_GERRIT_PROJECT};trusted-firmware-a;${TF_GERRIT_REFSPEC}"
67 "${GERRIT_HOST};${TFTF_GERRIT_PROJECT};tf-a-tests;${TFTF_GERRIT_REFSPEC}"
Daniel Boulbyc61b6cd2023-12-01 11:06:45 +000068 "${GERRIT_HOST};${SPM_GERRIT_PROJECT};spm;${SPM_REFSPEC}"
Manish V Badarkheaa6c48f2025-04-09 14:03:26 +010069 "${GERRIT_HOST};${RMM_GERRIT_PROJECT};tf-rmm;${RMM_REFSPEC}"
Jimmy Brissone4486ec2023-06-07 09:20:27 -050070 "${GERRIT_HOST};${TF_M_TESTS_GERRIT_PROJECT};tf-m-tests;${TF_M_TESTS_GERRIT_REFSPEC}"
71 "${GERRIT_HOST};${TF_M_EXTRAS_GERRIT_PROJECT};tf-m-extras;${TF_M_EXTRAS_GERRIT_REFSPEC}"
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -050072)
73
Paul Sokolovsky9b2a5de2023-12-18 18:25:43 +030074df -h
75
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -050076# Take into consideration non-CI runs where SHARE_FOLDER variable
77# may not be present
78if [ -z "${SHARE_FOLDER}" ]; then
79 # Default Jenkins values
80 SHARE_VOLUME="${SHARE_VOLUME:-$PWD}"
81 JOB_NAME="${JOB_NAME:-local}"
82 BUILD_NUMBER="${BUILD_NUMBER:-0}"
83 SHARE_FOLDER=${SHARE_VOLUME}/${JOB_NAME}/${BUILD_NUMBER}
84fi
85
Arthur She3eb254e2022-09-18 20:41:03 -070086# Clone JOBS_PROJECT first, since we need a helper script there
87if [ ! -d ${SHARE_FOLDER}/${JOBS_REPO_NAME} ]; then
88 git clone ${GIT_CLONE_PARAMS} ${GIT_REPO}/${JOBS_PROJECT} ${SHARE_FOLDER}/${JOBS_REPO_NAME}
89 cd ${SHARE_FOLDER}/${JOBS_REPO_NAME}
90 git fetch origin ${JOBS_REFSPEC}
Arthur Sheb4130f62025-02-08 20:58:14 -080091 git checkout FETCH_HEAD
Arthur She3eb254e2022-09-18 20:41:03 -070092else
93 cd ${SHARE_FOLDER}/${JOBS_REPO_NAME}
94fi
95git log -1
96cd $OLDPWD
97cp -a -f ${SHARE_FOLDER}/${JOBS_REPO_NAME} ${PWD}/${JOBS_REPO_NAME}
98
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -050099# clone git repos
100for repo in ${repos[@]}; do
101
102 # parse the repo elements
Arthur She3eb254e2022-09-18 20:41:03 -0700103 REPO_HOST="$(echo "${repo}" | awk -F ';' '{print $1}')"
104 REPO_PROJECT="$(echo "${repo}" | awk -F ';' '{print $2}')"
105 REPO_NAME="$(echo "${repo}" | awk -F ';' '{print $3}')"
106 REPO_DEFAULT_REFSPEC="$(echo "${repo}" | awk -F ';' '{print $4}')"
107 REPO_URL="${REPO_HOST}/${REPO_PROJECT}"
108 REPO_REFSPEC="${REPO_DEFAULT_REFSPEC}"
Zachary Leaf99dcb2b2024-10-15 14:55:50 +0100109 REPO_SSH_URL="ssh://${CI_BOT_USERNAME}@${REPO_HOST#https://}:29418/${REPO_PROJECT}"
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -0500110
Zachary Leaf81316402024-10-15 14:58:40 +0100111 # if a list of repos is provided via the CLONE_REPOS build param, only clone
112 # those in the list - otherwise all are cloned by default
113 if [[ -n "${CLONE_REPOS}" && "${CLONE_REPOS}" != *"${REPO_NAME}"* ]]; then
114 continue
115 fi
116
Arthur She3eb254e2022-09-18 20:41:03 -0700117 # clone and checkout in case it does not exist
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -0500118 if [ ! -d ${SHARE_FOLDER}/${REPO_NAME} ]; then
119 git clone ${GIT_CLONE_PARAMS} ${REPO_URL} ${SHARE_FOLDER}/${REPO_NAME}
120
Mikael Olssonfb99d0a2023-03-09 14:58:48 +0100121 # If the Gerrit review that triggered the CI had a topic, it will be used to synchronize the other repositories
122 if [ -n "${GERRIT_TOPIC}" -a "${REPO_HOST}" = "${GERRIT_HOST}" -a "${GERRIT_PROJECT}" != "${REPO_PROJECT}" ]; then
Arthur She3eb254e2022-09-18 20:41:03 -0700123 echo "Got Gerrit Topic: ${GERRIT_TOPIC}"
124 REPO_REFSPEC="$(ssh ${SSH_PARAMS} ${CI_BOT_USERNAME}@${REPO_HOST#https://} gerrit query ${GERRIT_QUERY_PARAMS} \
Paul Sokolovsky65bc87b2023-06-20 16:00:36 +0300125 project:${REPO_PROJECT} topic:${GERRIT_TOPIC} | ${SHARE_FOLDER}/${JOBS_REPO_NAME}/scripts/parse_refspec.py)"
Arthur She3eb254e2022-09-18 20:41:03 -0700126 if [ -z "${REPO_REFSPEC}" ]; then
127 REPO_REFSPEC="${REPO_DEFAULT_REFSPEC}"
128 echo "Roll back to \"${REPO_REFSPEC}\" for \"${REPO_PROJECT}\""
129 fi
130 echo "Checkout refspec \"${REPO_REFSPEC}\" from repository \"${REPO_NAME}\""
131 fi
132
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -0500133 # fetch and checkout the corresponding refspec
134 cd ${SHARE_FOLDER}/${REPO_NAME}
Zachary Leaf99dcb2b2024-10-15 14:55:50 +0100135
136 if [[ ${FETCH_SSH} ]]; then
137 GIT_SSH_COMMAND="ssh ${SSH_PARAMS}" git fetch ${REPO_SSH_URL} ${REPO_REFSPEC}
138 else
139 git fetch ${REPO_URL} ${REPO_REFSPEC}
140 fi
141
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -0500142 git checkout FETCH_HEAD
Paul Sokolovskyb41ac9e2022-10-14 19:23:26 +0300143 echo "Freshly cloned ${REPO_URL} (refspec ${REPO_REFSPEC}):"
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -0500144 git log -1
145 cd $OLDPWD
146
147 else
148 # otherwise just show the head's log
149 cd ${SHARE_FOLDER}/${REPO_NAME}
Paul Sokolovskyb41ac9e2022-10-14 19:23:26 +0300150 echo "Using existing shared folder checkout for ${REPO_URL}:"
Leonardo Sandovald1b6b5a2021-09-13 12:06:26 -0500151 git log -1
152 cd $OLDPWD
153 fi
154
155 # copy repository into pwd dir (workspace in CI), so each job would work
156 # on its own workspace
157 cp -a -f ${SHARE_FOLDER}/${REPO_NAME} ${PWD}/${REPO_NAME}
158
159done