blob: 6ae598e5304abf005fda33ff569284bc66e422d8 [file] [log] [blame]
kelvin.zhang2219b412022-03-04 16:44:41 +08001#!/bin/bash
2#
3# Copyright (c) 2021-2022 Amlogic, Inc. All rights reserved.
4#
5# SPDX-License-Identifier: MIT
6#
7
Kelvin Zhang6305ae32022-09-06 17:55:51 +08008get_repo_path() {
9 for keyword in $keyline; do
10 if [[ $keyword == $pattern* ]]; then
11 repo_path=`echo ${keyword#*${pattern}} | sed 's/\"//g' | sed 's/\/>//g'`
12 break;
13 fi
14 done
15}
kelvin.zhang2219b412022-03-04 16:44:41 +080016
Kelvin Zhang6305ae32022-09-06 17:55:51 +080017cherry_pick() {
18 if [ -d "$repo_path" ]; then
19 pushd $repo_path > /dev/null
20 git fetch ssh://${GERRIT_SERVER}:${GERRIT_PORT}/${GERRIT_PROJECT} ${GERRIT_REFSPEC}
21 git cherry-pick FETCH_HEAD
22 if [ "$?" -ne 0 ]; then
23 git status
24 git log -1
25 echo -e "\nFailed to apply patch!\n"
26 exit 1
27 fi
28 popd > /dev/null
29 else
30 echo -e "\nNo such directory! $repo_path\n"
31 exit 1
32 fi
33}
34
35apply_patch_by_change_number() {
Kelvin Zhang3664eec2022-09-07 11:04:32 +080036 [ -z "$GERRIT_CHANGE_NUMBER" -o -z "$GERRIT_PROJECT" -o -z "$GERRIT_REFSPEC" ] && [ -z "$MANUAL_GERRIT_CHANGE_NUMBER" ] && return
Kelvin Zhang6305ae32022-09-06 17:55:51 +080037
Kelvin Zhang3664eec2022-09-07 11:04:32 +080038 if [ -n "$GERRIT_CHANGE_NUMBER" ] && [ -n "$GERRIT_PROJECT" ] && [ -n "$GERRIT_REFSPEC" ]; then
Kelvin Zhang330cace2022-09-07 11:49:57 +080039 echo -e "\n======== Auto-applying Gerrit change $GERRIT_CHANGE_NUMBER on Project $GERRIT_PROJECT ========"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080040 elif [ -n "$MANUAL_GERRIT_CHANGE_NUMBER" ]; then
Kelvin Zhang6305ae32022-09-06 17:55:51 +080041 ssh -p $GERRIT_PORT $GERRIT_SERVER gerrit query --format=JSON --current-patch-set status:open change:$MANUAL_GERRIT_CHANGE_NUMBER > $GERRIT_QUERY_RESULT
42 GERRIT_PROJECT=$(jq -r '.project // empty' $GERRIT_QUERY_RESULT)
43 GERRIT_REFSPEC=$(jq -r '.currentPatchSet.ref // empty' $GERRIT_QUERY_RESULT)
Kelvin Zhang330cace2022-09-07 11:49:57 +080044 echo -e "\n======== Manually applying Gerrit change $MANUAL_GERRIT_CHANGE_NUMBER on Project $GERRIT_PROJECT ========"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080045 fi
46
47 keyline=`grep "name=\"$GERRIT_PROJECT\"" $CURRENT_MANIFEST`
48 pattern="path="
49 get_repo_path
50
51 cherry_pick
Kelvin Zhang3664eec2022-09-07 11:04:32 +080052 echo -e "======== Done ========\n"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080053}
54
55apply_patch_by_gerrit_topic() {
56 [ -z "$MANUAL_GERRIT_TOPIC" ] && return
57
Kelvin Zhang6305ae32022-09-06 17:55:51 +080058 ssh -p $GERRIT_PORT $GERRIT_SERVER gerrit query --format=JSON --current-patch-set status:open topic:$MANUAL_GERRIT_TOPIC > $GERRIT_QUERY_RESULT
59 GERRIT_PROJECTS=$(jq -r '.project // empty' $GERRIT_QUERY_RESULT)
60 GERRIT_REFSPECS=$(jq -r '.currentPatchSet.ref // empty' $GERRIT_QUERY_RESULT)
61
Kelvin Zhang330cace2022-09-07 11:49:57 +080062 echo -e "\n======== Manually applying Gerrit changes ========"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080063
64 i=1
65 for GERRIT_PROJECT in $GERRIT_PROJECTS; do
Kelvin Zhang330cace2022-09-07 11:49:57 +080066 echo "-------- Applying patch $i on Project $GERRIT_PROJECT --------"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080067 keyline=`grep "name=\"$GERRIT_PROJECT\"" $CURRENT_MANIFEST`
68 pattern="path="
69 get_repo_path
70
71 GERRIT_REFSPEC=$(echo $GERRIT_REFSPECS | awk "{print \$$i}")
72 cherry_pick
73 echo -e "-------- Done --------\n"
74 i=$((i+1))
75 done
76
77 i=$((i-1))
Kelvin Zhang330cace2022-09-07 11:49:57 +080078 [[ "$i" -eq 1 ]] && echo -e "======== Applied $i patch for $MANUAL_GERRIT_TOPIC ========\n"
79 [[ "$i" -gt 1 ]] && echo -e "======== Applied $i patches for $MANUAL_GERRIT_TOPIC ========\n"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080080}
81
82apply_patch_by_gerrit_url() {
83 [ -z "$GIT_CHERRY_PICK" ] && return
84
Kelvin Zhangb2630702022-04-20 11:22:32 +080085 while IFS= read -r line
kelvin.zhang2219b412022-03-04 16:44:41 +080086 do
87 pattern=":29418/"
88 for keyword in $line; do
89 if [[ $keyword == *$pattern* ]]; then
90 GIT_PROJECT=`echo ${keyword#*${pattern}} | sed 's/\"//g' | sed 's/\/>//g'`
91 break;
92 fi
93 done
94
Kelvin Zhang330cace2022-09-07 11:49:57 +080095 echo -e "\n-------- Manually applying patch on Project $GIT_PROJECT --------"
Kelvin Zhang4982b0b2022-08-31 19:15:24 +080096 keyline=`grep "name=\"$GIT_PROJECT\"" $CURRENT_MANIFEST`
Kelvin Zhang6305ae32022-09-06 17:55:51 +080097 pattern="path="
98 get_repo_path
kelvin.zhang2219b412022-03-04 16:44:41 +080099
100 if [ -d "$repo_path" ]; then
101 pushd $repo_path > /dev/null
102 cmd=`echo $line | sed -e 's/ssh:\/\/.*@scgit.amlogic.com/ssh:\/\/scgit.amlogic.com/'`
103 eval $cmd
104 if [ "$?" -ne 0 ]; then
Kelvin Zhangcceacda2022-05-23 09:34:34 +0800105 git status
106 git log -1
107 echo -e "-------- Failed to apply patch! --------"
kelvin.zhang2219b412022-03-04 16:44:41 +0800108 exit 1
109 fi
110 popd > /dev/null
111 else
112 echo "No such directory! $repo_path"
113 exit 1
114 fi
Kelvin Zhangb6cbb072022-04-26 14:19:35 +0800115 echo -e "-------- Done --------\n"
Kelvin Zhangb2630702022-04-20 11:22:32 +0800116 done <<< "$GIT_CHERRY_PICK"
Kelvin Zhang6305ae32022-09-06 17:55:51 +0800117}
Kelvin Zhang0322c7e2022-04-25 18:19:41 +0800118
Kelvin Zhang6305ae32022-09-06 17:55:51 +0800119[ -z "$CURRENT_MANIFEST" ] && CURRENT_MANIFEST="curr_manifest.xml"
120[ ! -f $CURRENT_MANIFEST ] && repo manifest -r -o $CURRENT_MANIFEST
Kelvin Zhang0322c7e2022-04-25 18:19:41 +0800121
Kelvin Zhang3664eec2022-09-07 11:04:32 +0800122[ -z "$GERRIT_PORT" ] && GERRIT_PORT="29418"
Kelvin Zhang6305ae32022-09-06 17:55:51 +0800123GERRIT_SERVER="scgit.amlogic.com"
124GERRIT_QUERY_RESULT="changes.txt"
Kelvin Zhang0322c7e2022-04-25 18:19:41 +0800125
Kelvin Zhang6305ae32022-09-06 17:55:51 +0800126apply_patch_by_change_number
127apply_patch_by_gerrit_topic