blob: 7286aef45672fea6ed77b32f4bd39d9063f595e5 [file] [log] [blame]
robert.tomczykf97b3c22019-09-18 15:14:38 +01001#!/bin/bash
2
3# ============LICENSE_START====================================================
4# Copyright (C) 2019 The Nordix Foundation. All rights reserved.
5# =============================================================================
6# Licensed under the Apache License, Version 2.0 (the "License");
7# you may not use this file except in compliance with the License.
8# You may obtain a copy of the License at
9#
10# http://www.apache.org/licenses/LICENSE-2.0
11#
12# Unless required by applicable law or agreed to in writing, software
13# distributed under the License is distributed on an "AS IS" BASIS,
14# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15# See the License for the specific language governing permissions and
16# limitations under the License.
17#
18# SPDX-License-Identifier: Apache-2.0
19# ============LICENSE_END======================================================
20#
21# This script will take the single commit form the given Nordix Gerrit review
22# and push it, and all its ancestor commit till $GERRIT_BRANCH, to ORANSC Gerrit.
23# Pre-requisites for script to run successfully:
24# - Author name in Nordix Gerrit equals LFID
25# i.e. need to run "git config --global user.name <LFID>"
26# - infra public key on build server needs to be added to your users SSH
27# Public Keys in ORANSC Gerrit
28#
29set -euxo pipefail
30
31cd "$WORKSPACE"
32
33oransc_gerrit_base='gerrit.o-ran-sc.org:29418'
34echo >&2 "Collecting information about what and how to push towards ORANSC Gerrit"
35
36# The git hash of the commit in the review this job runs on
37commit_hash="$GERRIT_PATCHSET_REVISION"
38
39# GERRIT_PROJECT is in the form of oransc/<oransc-project>
40oransc_project=$(echo "$GERRIT_PROJECT" | cut -d/ -f2- )
41
42# Unfortunately for the some of the Nordix users, the Nordix Gerrit username don't match
43# the ORANSC Gerrit username for their LFID. The git author will be used
44# to push the change to ORANSC Gerrit.
45username=$(git show -s --pretty=%an)
46
47oransc_remote_url="ssh://$username@$oransc_gerrit_base/$oransc_project"
48
49# GERRIT_BRANCH is the _intended_ branch of the commit under review
50# E.g. git push HEAD:refs/for/master => GERRIT_BRANCH='master'
51# GERRIT_TOPIC is the rest of the refspec after GERRIT_BRANCH when the topic
52# is set for the change.
53if [ -z "${GERRIT_TOPIC:-}" ] ; then
robert.tomczyk40f60152020-10-13 11:03:13 +010054 refspec="${commit_hash}:refs/for/${GERRIT_BRANCH}"
robert.tomczykf97b3c22019-09-18 15:14:38 +010055else
robert.tomczyk40f60152020-10-13 11:03:13 +010056 refspec="${commit_hash}:refs/for/${GERRIT_BRANCH}%topic=${GERRIT_TOPIC}"
robert.tomczykf97b3c22019-09-18 15:14:38 +010057fi
58
59echo >&2 "Pushing to ORANSC Gerrit"
60
61# do not fail if git push fails as in case of no new changes we want to succeed. See below.
62set +o pipefail
63
64git push "$oransc_remote_url" "$refspec" 2>&1 | tee push_result.txt
65push_result=${PIPESTATUS[0]}
66
67# make the job a success if the above git push fails due to no new changes are needed
68# to be created upstream. This will be useful when we switch to automatic triggering
69# of the push-upstream for each patch set and jobs on different commits in a same chain
70# will race with each other to push parts of the chain
71if [ $push_result -ne 0 ]; then
72 grep '(no new changes)' push_result.txt
73fi