Merge "Create jenkins pipeline for k6 performance tests"
[infra/cicd.git] / jjb / global / 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 #
22 # This script will take the changes that are pushed to Nordix Gerrit and push upstream to ONAP
23 # Pre-requisites for script to run successfully:
24 # - Author name in Nordix Gerrit equals LFID i.e. need to run "git config --global user.name <LFID>"
25 # - infra public key on build server needs to be added to your users SSH Public Keys in ONAP Gerrit
26 #
27 set -o nounset
28 set -o pipefail
29
30 cd $WORKSPACE
31 echo "Retrieving information from commit to push towards ONAP"
32 project=$(git config --local remote.origin.url | awk -F "29418/" '{print $2}')
33 message=$(git show -s --pretty=%B | grep -vi 'Signed-off-by')
34 username=$(git show -s --pretty=%an)
35
36 pattern=" "
37 if [[ "$username" =~ $pattern ]]
38 then
39     echo "Incorrect username, use Linux Foundation ID as git user.name when pushing to Nordix"
40     exit 1
41 fi
42
43 echo "Setting user name and email"
44 git config user.email $(git show -s --pretty=%ae)
45 git config user.name $username
46
47 echo "Checking out branch on master with new changes"
48 git reset HEAD~1 --soft
49 git checkout -b delivery_branch origin/$BRANCH
50
51 git config --get remote.upstream.url
52 retVal=$?
53
54 if [[ $retVal -eq 0 ]]
55 then
56   git remote rm upstream
57   git remote add upstream "ssh://$username@gerrit.onap.org:29418/$project.git"
58 else
59   git remote add upstream "ssh://$username@gerrit.onap.org:29418/$project.git"
60 fi
61
62 echo "Committing changes and pushing upstream"
63 git commit -as -m "$message"
64 git push upstream HEAD:refs/for/$BRANCH
65
66 retVal1=$?
67 if [[ $retVal1 -eq 0 ]]
68 then
69   echo "Push upstream to ONAP succeeded"
70 else
71   echo "Push upstream to ONAP failed"
72   exit 2
73 fi
74
75 git checkout $BRANCH
76 git branch -D delivery_branch