 98b01c9a59
			
		
	
	98b01c9a59
	
	
	
		
			
			This currently runs in the 'check' pipeline, as part of the pep8 job, which causes otherwise perfectly valid backports to report as failing CI. There's no reason a stable core shouldn't be encouraged to review these patches: we simply want to prevent them *merging* before their parent(s). Resolve this conflict by moving the check to separate voting job in the 'gate' pipeline as well as a non-voting job in the 'check' pipeline to catch more obvious issues. Change-Id: Id3e4452883f6a3cf44ff58b39ded82e882e28c23 Signed-off-by: Stephen Finucane <stephenfin@redhat.com>
		
			
				
	
	
		
			43 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| #
 | |
| # A tool to check the cherry-pick hashes from the current git commit message
 | |
| # to verify that they're all on either master or stable/ branches
 | |
| #
 | |
| 
 | |
| commit_hash=""
 | |
| 
 | |
| # Check if the patch is a merge patch by counting the number of parents.
 | |
| # If the patch has 2 parents, then the 2nd parent is the patch we want
 | |
| # to validate.
 | |
| parent_number=$(git show --format='%P' --quiet | awk '{print NF}')
 | |
| if [ $parent_number -eq 2 ]; then
 | |
|     commit_hash=$(git show --format='%P' --quiet | awk '{print $NF}')
 | |
| fi
 | |
| 
 | |
| hashes=$(git show --format='%b' --quiet $commit_hash | sed -nr 's/^.cherry picked from commit (.*).$/\1/p')
 | |
| checked=0
 | |
| branches+=""
 | |
| for hash in $hashes; do
 | |
|     branch=$(git branch -a --contains "$hash" 2>/dev/null| grep -oE '(master|stable/[a-z]+)')
 | |
|     if [ $? -ne 0 ]; then
 | |
|         echo "Cherry pick hash $hash not on any master or stable branches"
 | |
|         exit 1
 | |
|     fi
 | |
|     branches+=" $branch"
 | |
|     checked=$(($checked + 1))
 | |
| done
 | |
| 
 | |
| if [ $checked -eq 0 ]; then
 | |
|     if ! grep -q '^defaultbranch=stable/' .gitreview; then
 | |
|         echo "Checked $checked cherry-pick hashes: OK"
 | |
|         exit 0
 | |
|     else
 | |
|         if ! git show --format='%B' --quiet $commit_hash | grep -qi 'stable.*only'; then
 | |
|             echo 'Stable branch requires either cherry-pick -x headers or [stable-only] tag!'
 | |
|             exit 1
 | |
|         fi
 | |
|     fi
 | |
| else
 | |
|     echo Checked $checked cherry-pick hashes on branches: $(echo $branches | tr ' ' '\n' | sort | uniq)
 | |
| fi
 |