blob: a7729687c5e92ee76a0f27f103294eea4aff9b4c [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
Kelvin Zhang09aa4b62022-09-19 18:13:56 +080011 repo_path=`echo ${keyword#*${pattern}} | sed 's/\"//g'`
Kelvin Zhang6305ae32022-09-06 17:55:51 +080012 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
bin.chen00be9eb2024-01-29 14:10:56 +080020 echo -e "========toby debug (1):$GERRIT_SERVER (2):$GERRIT_PORT (3):$GERRIT_PROJECT (4):$GERRIT_REFSPEC ========"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080021 git fetch ssh://${GERRIT_SERVER}:${GERRIT_PORT}/${GERRIT_PROJECT} ${GERRIT_REFSPEC}
22 git cherry-pick FETCH_HEAD
23 if [ "$?" -ne 0 ]; then
24 git status
25 git log -1
Kelvin Zhangcf643422022-11-22 15:28:31 +080026 echo -e "\n${FUNCNAME[0]}: Failed to apply patch!\n"
Kelvin Zhang461d2e12022-11-21 20:51:42 +080027 return 1
Kelvin Zhang6305ae32022-09-06 17:55:51 +080028 fi
29 popd > /dev/null
30 else
Kelvin Zhangcf643422022-11-22 15:28:31 +080031 echo -e "\n${FUNCNAME[0]}: No such directory! $repo_path\n"
Kelvin Zhang461d2e12022-11-21 20:51:42 +080032 return 1
Kelvin Zhang6305ae32022-09-06 17:55:51 +080033 fi
34}
35
36apply_patch_by_change_number() {
Kelvin Zhang3664eec2022-09-07 11:04:32 +080037 [ -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 +080038
Kelvin Zhang3664eec2022-09-07 11:04:32 +080039 if [ -n "$GERRIT_CHANGE_NUMBER" ] && [ -n "$GERRIT_PROJECT" ] && [ -n "$GERRIT_REFSPEC" ]; then
Kelvin Zhangbfe35d52022-09-08 10:35:34 +080040 echo -e "======== Auto-applying Gerrit change $GERRIT_CHANGE_NUMBER on Project $GERRIT_PROJECT ========"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080041 elif [ -n "$MANUAL_GERRIT_CHANGE_NUMBER" ]; then
Kelvin Zhang6305ae32022-09-06 17:55:51 +080042 ssh -p $GERRIT_PORT $GERRIT_SERVER gerrit query --format=JSON --current-patch-set status:open change:$MANUAL_GERRIT_CHANGE_NUMBER > $GERRIT_QUERY_RESULT
43 GERRIT_PROJECT=$(jq -r '.project // empty' $GERRIT_QUERY_RESULT)
44 GERRIT_REFSPEC=$(jq -r '.currentPatchSet.ref // empty' $GERRIT_QUERY_RESULT)
Kelvin Zhangbfe35d52022-09-08 10:35:34 +080045 echo -e "======== Manually applying Gerrit change $MANUAL_GERRIT_CHANGE_NUMBER on Project $GERRIT_PROJECT ========"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080046 fi
47
Kelvin Zhangfdf8ff02023-04-21 21:23:30 +080048 keyline=`grep "name=\"$GERRIT_PROJECT\"" $MANIFEST`
Kelvin Zhang6305ae32022-09-06 17:55:51 +080049 pattern="path="
50 get_repo_path
51
52 cherry_pick
Kelvin Zhang461d2e12022-11-21 20:51:42 +080053 [ "$?" -ne 0 ] && return 1
Kelvin Zhang3664eec2022-09-07 11:04:32 +080054 echo -e "======== Done ========\n"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080055}
56
57apply_patch_by_gerrit_topic() {
Kelvin Zhange8015cf2023-01-17 15:49:29 +080058 [ -z "$MANUAL_GERRIT_TOPIC" ] && return 0
Kelvin Zhang6305ae32022-09-06 17:55:51 +080059
Kelvin Zhang6305ae32022-09-06 17:55:51 +080060 ssh -p $GERRIT_PORT $GERRIT_SERVER gerrit query --format=JSON --current-patch-set status:open topic:$MANUAL_GERRIT_TOPIC > $GERRIT_QUERY_RESULT
61 GERRIT_PROJECTS=$(jq -r '.project // empty' $GERRIT_QUERY_RESULT)
62 GERRIT_REFSPECS=$(jq -r '.currentPatchSet.ref // empty' $GERRIT_QUERY_RESULT)
63
Kelvin Zhang31490012022-11-01 11:17:58 +080064 echo -e "======== Manually applying Gerrit Topic: $MANUAL_GERRIT_TOPIC ========"
Kelvin Zhang6305ae32022-09-06 17:55:51 +080065
66 i=1
67 for GERRIT_PROJECT in $GERRIT_PROJECTS; do
Kelvin Zhang330cace2022-09-07 11:49:57 +080068 echo "-------- Applying patch $i on Project $GERRIT_PROJECT --------"
Kelvin Zhangfdf8ff02023-04-21 21:23:30 +080069 keyline=`grep "name=\"$GERRIT_PROJECT\"" $MANIFEST`
Kelvin Zhang6305ae32022-09-06 17:55:51 +080070 pattern="path="
71 get_repo_path
72
73 GERRIT_REFSPEC=$(echo $GERRIT_REFSPECS | awk "{print \$$i}")
74 cherry_pick
Kelvin Zhang461d2e12022-11-21 20:51:42 +080075 [ "$?" -ne 0 ] && return 1
Kelvin Zhang6305ae32022-09-06 17:55:51 +080076 echo -e "-------- Done --------\n"
77 i=$((i+1))
78 done
79
80 i=$((i-1))
Kelvin Zhang330cace2022-09-07 11:49:57 +080081 [[ "$i" -eq 1 ]] && echo -e "======== Applied $i patch for $MANUAL_GERRIT_TOPIC ========\n"
82 [[ "$i" -gt 1 ]] && echo -e "======== Applied $i patches for $MANUAL_GERRIT_TOPIC ========\n"
Kelvin Zhange8015cf2023-01-17 15:49:29 +080083
84 return 0
Kelvin Zhang6305ae32022-09-06 17:55:51 +080085}
86
87apply_patch_by_gerrit_url() {
88 [ -z "$GIT_CHERRY_PICK" ] && return
89
Kelvin Zhangb2630702022-04-20 11:22:32 +080090 while IFS= read -r line
kelvin.zhang2219b412022-03-04 16:44:41 +080091 do
92 pattern=":29418/"
93 for keyword in $line; do
94 if [[ $keyword == *$pattern* ]]; then
95 GIT_PROJECT=`echo ${keyword#*${pattern}} | sed 's/\"//g' | sed 's/\/>//g'`
96 break;
97 fi
98 done
99
Kelvin Zhang330cace2022-09-07 11:49:57 +0800100 echo -e "\n-------- Manually applying patch on Project $GIT_PROJECT --------"
Kelvin Zhangfdf8ff02023-04-21 21:23:30 +0800101 keyline=`grep "name=\"$GIT_PROJECT\"" $MANIFEST`
Kelvin Zhang6305ae32022-09-06 17:55:51 +0800102 pattern="path="
103 get_repo_path
kelvin.zhang2219b412022-03-04 16:44:41 +0800104
105 if [ -d "$repo_path" ]; then
106 pushd $repo_path > /dev/null
107 cmd=`echo $line | sed -e 's/ssh:\/\/.*@scgit.amlogic.com/ssh:\/\/scgit.amlogic.com/'`
108 eval $cmd
109 if [ "$?" -ne 0 ]; then
Kelvin Zhangcceacda2022-05-23 09:34:34 +0800110 git status
111 git log -1
Kelvin Zhangcf643422022-11-22 15:28:31 +0800112 echo -e "\n${FUNCNAME[0]}: Failed to apply patch!\n"
kelvin.zhang2219b412022-03-04 16:44:41 +0800113 exit 1
114 fi
115 popd > /dev/null
116 else
Kelvin Zhangcf643422022-11-22 15:28:31 +0800117 echo -e "\n${FUNCNAME[0]}: No such directory! $repo_path\n"
kelvin.zhang2219b412022-03-04 16:44:41 +0800118 exit 1
119 fi
Kelvin Zhangb6cbb072022-04-26 14:19:35 +0800120 echo -e "-------- Done --------\n"
Kelvin Zhangb2630702022-04-20 11:22:32 +0800121 done <<< "$GIT_CHERRY_PICK"
Kelvin Zhang6305ae32022-09-06 17:55:51 +0800122}
Kelvin Zhang0322c7e2022-04-25 18:19:41 +0800123
Kelvin Zhang7052f1c2022-09-20 11:11:41 +0800124[ -z "$OUTPUT_DIR" ] && OUTPUT_DIR=$PWD/output
125[ ! -d $OUTPUT_DIR ] && mkdir -p $OUTPUT_DIR
126
Kelvin Zhangfdf8ff02023-04-21 21:23:30 +0800127[ -z "$MANIFEST" ] && MANIFEST="$OUTPUT_DIR/manifest.xml"
128[ ! -f $MANIFEST ] && repo manifest -r -o $MANIFEST
Kelvin Zhang0322c7e2022-04-25 18:19:41 +0800129
Kelvin Zhang461d2e12022-11-21 20:51:42 +0800130[ -z "$GERRIT_SERVER" ] && GERRIT_SERVER="scgit.amlogic.com"
Kelvin Zhang3664eec2022-09-07 11:04:32 +0800131[ -z "$GERRIT_PORT" ] && GERRIT_PORT="29418"
Kelvin Zhang461d2e12022-11-21 20:51:42 +0800132[ -z "$GERRIT_QUERY_RESULT" ] && GERRIT_QUERY_RESULT="$OUTPUT_DIR/topic_changes.txt"
Kelvin Zhang0322c7e2022-04-25 18:19:41 +0800133
Kelvin Zhang6305ae32022-09-06 17:55:51 +0800134apply_patch_by_change_number
135apply_patch_by_gerrit_topic