Merge "eiffel: Create periodic build jobs for initial set of etos repos"
[infra/cicd.git] / jjb / oransc / push-upstream-jobs.sh
1 #!/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 #
29 set -euxo pipefail
30
31 cd "$WORKSPACE"
32
33 oransc_gerrit_base='gerrit.o-ran-sc.org:29418'
34 echo >&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
37 commit_hash="$GERRIT_PATCHSET_REVISION"
38
39 # GERRIT_PROJECT is in the form of oransc/<oransc-project>
40 oransc_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.
45 username=$(git show -s --pretty=%an)
46
47 oransc_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.
53 if [ -z "${GERRIT_TOPIC:-}" ] ; then
54     refspec="${commit_hash}:refs/for/${GERRIT_BRANCH}"
55 else
56     refspec="${commit_hash}:refs/for/${GERRIT_BRANCH}%topic=${GERRIT_TOPIC}"
57 fi
58
59 echo >&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.
62 set +o pipefail
63
64 git push "$oransc_remote_url" "$refspec" 2>&1 | tee push_result.txt
65 push_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
71 if [ $push_result -ne 0 ]; then
72     grep '(no new changes)' push_result.txt
73 fi