mirror of https://github.com/containers/podman.git
				
				
				
			
		
			
				
	
	
		
			138 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
| #!/bin/bash
 | |
| #
 | |
| # tests for pr-should-include-tests.t
 | |
| #
 | |
| # FIXME: I don't think this will work in CI, because IIRC the git-checkout
 | |
| # is a shallow one. But it works fine in a developer tree.
 | |
| #
 | |
| ME=$(basename $0)
 | |
| 
 | |
| # As of 2024-02 our test script queries github, for which we need token
 | |
| if [[ -z "$GITHUB_TOKEN" ]]; then
 | |
|     echo "$ME: Please set \$GITHUB_TOKEN" >&2
 | |
|     exit 1
 | |
| fi
 | |
| export CIRRUS_REPO_CLONE_TOKEN="$GITHUB_TOKEN"
 | |
| 
 | |
| ###############################################################################
 | |
| # BEGIN test cases
 | |
| #
 | |
| # Feel free to add as needed. Syntax is:
 | |
| #    <exit status>  <sha of commit>  <branch>=<sha of merge base>  # comments
 | |
| #
 | |
| # Where:
 | |
| #    exit status       is the expected exit status of the script
 | |
| #    sha of merge base is the SHA of the branch point of the commit
 | |
| #    sha of commit     is the SHA of a real commit in the podman repo
 | |
| #
 | |
| # We need the actual sha of the merge base because once a branch is
 | |
| # merged 'git merge-base' (used in our test script) becomes useless.
 | |
| #
 | |
| #
 | |
| # FIXME: as of 2021-01-07 we don't have "no tests needed" in our git
 | |
| #        commit history, but once we do, please add a new '0' test here.
 | |
| #
 | |
| tests="
 | |
| 0  68c9e02df  db71759b1   8821  multiple commits, includes tests
 | |
| 0  bb82c37b7  eeb4c129b   8832  single commit, w/tests, merge-base test
 | |
| 1  1f5927699  864592c74   8685  multiple commits, no tests
 | |
| 0  7592f8fbb  6bbe54f2b   8766  no tests, but CI:DOCS in commit message
 | |
| 0  355e38769  bfbd915d6   8884  a vendor bump
 | |
| 0  ffe2b1e95  e467400eb   8899  only .cirrus.yml
 | |
| 0  06a6fd9f2  3cc080151   8695  docs-only, without CI:DOCS
 | |
| 0  a47515008  ecedda63a   8816  unit tests only
 | |
| 0  caa84cd35  e55320efd   8565  hack/podman-socat only
 | |
| 0  c342583da  12f835d12   8523  version.go + podman.spec.in
 | |
| 0  8f75ed958  7b3ad6d89   8835  only a README.md change
 | |
| 0  b6db60e58  f06dd45e0   9420  a test rename
 | |
| 0  c6a896b0c  4ea5d6971  11833  includes magic string
 | |
| "
 | |
| 
 | |
| # The script we're testing
 | |
| test_script=$(dirname $0)/$(basename $0 .t)
 | |
| 
 | |
| # END   test cases
 | |
| ###############################################################################
 | |
| # BEGIN test-script runner and status checker
 | |
| 
 | |
| function run_test_script() {
 | |
|     local expected_rc=$1
 | |
|     local testname=$2
 | |
| 
 | |
|     testnum=$(( testnum + 1 ))
 | |
| 
 | |
|     # DO NOT COMBINE 'local output=...' INTO ONE LINE. If you do, you lose $?
 | |
|     local output
 | |
|     output=$( $test_script )
 | |
|     local actual_rc=$?
 | |
| 
 | |
|     if [[ $actual_rc != $expected_rc ]]; then
 | |
|         echo "not ok $testnum $testname"
 | |
|         echo "#  expected rc $expected_rc"
 | |
|         echo "#  actual rc   $actual_rc"
 | |
|         if [[ -n "$output" ]]; then
 | |
|             echo "# script output: $output"
 | |
|         fi
 | |
|         rc=1
 | |
|     else
 | |
|         if [[ $expected_rc == 1 ]]; then
 | |
|             # Confirm we get an error message
 | |
|             if [[ ! "$output" =~ "Please write a regression test" ]]; then
 | |
|                 echo "not ok $testnum $testname"
 | |
|                 echo "# Expected: ~ 'Please write a regression test'"
 | |
|                 echo "# Actual:   $output"
 | |
|                 rc=1
 | |
|             else
 | |
|                 echo "ok $testnum $testname - rc=$expected_rc"
 | |
|             fi
 | |
|         else
 | |
|             echo "ok $testnum $testname - rc=$expected_rc"
 | |
|         fi
 | |
|     fi
 | |
| 
 | |
|     # If we expect an error, confirm that we can override it. We only need
 | |
|     # to do this once.
 | |
|     if [[ $expected_rc == 1 ]]; then
 | |
|         if [[ -z "$tested_override" ]]; then
 | |
|             testnum=$(( testnum + 1 ))
 | |
| 
 | |
|             CIRRUS_CHANGE_TITLE="[CI:DOCS] hi there" $test_script &>/dev/null
 | |
|             if [[ $? -ne 1 ]]; then
 | |
|                 echo "not ok $testnum $rest (override with CI:DOCS)"
 | |
|                 rc=1
 | |
|             else
 | |
|                 echo "ok $testnum $rest (override with CI:DOCS)"
 | |
|             fi
 | |
| 
 | |
|             tested_override=1
 | |
|         fi
 | |
|     fi
 | |
| }
 | |
| 
 | |
| # END   test-script runner and status checker
 | |
| ###############################################################################
 | |
| # BEGIN test-case parsing
 | |
| 
 | |
| rc=0
 | |
| testnum=0
 | |
| tested_override=
 | |
| 
 | |
| while read expected_rc parent_sha  commit_sha pr rest; do
 | |
|     # Skip blank lines
 | |
|     test -z "$expected_rc" && continue
 | |
| 
 | |
|     export DEST_BRANCH=$parent_sha
 | |
|     export CIRRUS_CHANGE_IN_REPO=$commit_sha
 | |
|     export CIRRUS_CHANGE_TITLE=$(git log -1 --format=%s $commit_sha)
 | |
|     export CIRRUS_CHANGE_MESSAGE=
 | |
|     export CIRRUS_PR=$pr
 | |
| 
 | |
|     run_test_script $expected_rc "PR $pr - $rest"
 | |
| done <<<"$tests"
 | |
| 
 | |
| echo "1..$testnum"
 | |
| exit $rc
 | |
| 
 | |
| # END   Test-case parsing
 | |
| ###############################################################################
 |