mirror of
https://code.forgejo.org/actions/cascading-pr.git
synced 2025-07-21 23:08:23 +02:00
Reviewed-on: https://code.forgejo.org/actions/cascading-pr/pulls/36 Co-authored-by: Earl Warren <contact@earl-warren.org> Co-committed-by: Earl Warren <contact@earl-warren.org>
This commit is contained in:
parent
98b48e57d7
commit
06248c771c
5 changed files with 526 additions and 518 deletions
221
tests/run.sh
221
tests/run.sh
|
@ -4,7 +4,7 @@
|
|||
set -e
|
||||
set -o posix
|
||||
|
||||
SELF_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
||||
SELF_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
TMPDIR=/tmp/cascading-pr-test
|
||||
export LOOP_DELAY=5
|
||||
mkdir -p $TMPDIR
|
||||
|
@ -18,9 +18,9 @@ function push_self() {
|
|||
function user_login() {
|
||||
local username=$1
|
||||
(
|
||||
export DOT=$TMPDIR/$username
|
||||
forgejo-curl.sh logout
|
||||
forgejo-curl.sh --user $username --password "${options[password]}" login ${options[url]}
|
||||
export DOT=$TMPDIR/$username
|
||||
forgejo-curl.sh logout
|
||||
forgejo-curl.sh --user $username --password "${options[password]}" login ${options[url]}
|
||||
)
|
||||
}
|
||||
|
||||
|
@ -33,7 +33,7 @@ function user_curl() {
|
|||
function user_token() {
|
||||
local username=$1 name=$2
|
||||
|
||||
curl -sS -f -H Content-Type:application/json --user "$username:${options[password]}" --data '{"name":"'$name'","scopes":["write:repository","write:issue","read:organization","read:user"]}' ${options[url]}/api/v1/users/$username/tokens | jq --raw-output .sha1 | tee $TMPDIR/$username/repo-token
|
||||
curl -sS -f -H Content-Type:application/json --user "$username:${options[password]}" --data '{"name":"'$name'","scopes":["write:repository","write:issue","read:organization","read:user"]}' ${options[url]}/api/v1/users/$username/tokens | jq --raw-output .sha1 | tee $TMPDIR/$username/repo-token
|
||||
}
|
||||
|
||||
function user_secret() {
|
||||
|
@ -44,18 +44,18 @@ function user_secret() {
|
|||
}
|
||||
|
||||
function orgs_delete() {
|
||||
forgejo-curl.sh api_json ${options[url]}/api/v1/orgs | jq --raw-output '.[] | .name' | while read owner ; do
|
||||
forgejo-curl.sh api_json ${options[url]}/api/v1/orgs/$owner/repos | jq --raw-output '.[] | .name' | while read repo ; do
|
||||
forgejo-curl.sh api_json -X DELETE ${options[url]}/api/v1/repos/$owner/$repo
|
||||
done
|
||||
forgejo-curl.sh api_json -X DELETE ${options[url]}/api/v1/orgs/$owner
|
||||
forgejo-curl.sh api_json ${options[url]}/api/v1/orgs | jq --raw-output '.[] | .name' | while read owner; do
|
||||
forgejo-curl.sh api_json ${options[url]}/api/v1/orgs/$owner/repos | jq --raw-output '.[] | .name' | while read repo; do
|
||||
forgejo-curl.sh api_json -X DELETE ${options[url]}/api/v1/repos/$owner/$repo
|
||||
done
|
||||
forgejo-curl.sh api_json -X DELETE ${options[url]}/api/v1/orgs/$owner
|
||||
done
|
||||
}
|
||||
|
||||
function user_create() {
|
||||
local username="$1" email="$2"
|
||||
log_verbose "(re)create user $username"
|
||||
forgejo-curl.sh api_json -X DELETE ${options[url]}/api/v1/admin/users/$username?purge=true >& /dev/null || true
|
||||
forgejo-curl.sh api_json -X DELETE ${options[url]}/api/v1/admin/users/$username?purge=true >&/dev/null || true
|
||||
forgejo-curl.sh api_json --data '{"username":"'$username'","email":"'$email'","password":"'${options[password]}'","must_change_password":false}' ${options[url]}/api/v1/admin/users
|
||||
user_login $username
|
||||
}
|
||||
|
@ -64,8 +64,8 @@ function close_pull_request() {
|
|||
local repo=$1
|
||||
|
||||
log_verbose "close all pull requests in user1/$repo"
|
||||
forgejo-curl.sh api_json ${options[url]}/api/v1/repos/user1/${repo}/pulls | jq --raw-output '.[] | .number' | while read pr ; do
|
||||
forgejo-curl.sh api_json -X PATCH --data '{"state":"closed"}' ${options[url]}/api/v1/repos/user1/${repo}/issues/$pr
|
||||
forgejo-curl.sh api_json ${options[url]}/api/v1/repos/user1/${repo}/pulls | jq --raw-output '.[] | .number' | while read pr; do
|
||||
forgejo-curl.sh api_json -X PATCH --data '{"state":"closed"}' ${options[url]}/api/v1/repos/user1/${repo}/issues/$pr
|
||||
done
|
||||
}
|
||||
|
||||
|
@ -73,8 +73,8 @@ function merge_pull_request() {
|
|||
local repo=$1
|
||||
|
||||
log_verbose "merge all pull requests in user1/$repo"
|
||||
forgejo-curl.sh api_json ${options[url]}/api/v1/repos/user1/${repo}/pulls | jq --raw-output '.[] | .number' | while read pr ; do
|
||||
forgejo-curl.sh api_json --data '{"Do":"merge"}' ${options[url]}/api/v1/repos/user1/${repo}/pulls/$pr/merge
|
||||
forgejo-curl.sh api_json ${options[url]}/api/v1/repos/user1/${repo}/pulls | jq --raw-output '.[] | .number' | while read pr; do
|
||||
forgejo-curl.sh api_json --data '{"Do":"merge"}' ${options[url]}/api/v1/repos/user1/${repo}/pulls/$pr/merge
|
||||
done
|
||||
}
|
||||
|
||||
|
@ -120,46 +120,45 @@ function create_branch1() {
|
|||
local owner=$1 repo=$2 modify=$3
|
||||
|
||||
log_verbose "(re)create branch1 in $owner/$repo"
|
||||
forgejo-curl.sh api_json -X DELETE ${options[url]}/api/v1/repos/$owner/${repo}/branches/branch1 >& /dev/null || true
|
||||
forgejo-curl.sh api_json -X DELETE ${options[url]}/api/v1/repos/$owner/${repo}/branches/branch1 >&/dev/null || true
|
||||
forgejo-curl.sh api_json --data '{"new_branch_name":"branch1"}' ${options[url]}/api/v1/repos/$owner/${repo}/branches
|
||||
(
|
||||
cd $TMPDIR
|
||||
rm -fr ${repo}
|
||||
git clone -b branch1 http://user1:admin1234@${options[host_port]}/$owner/${repo}
|
||||
cd ${repo}
|
||||
echo CONTENT > README
|
||||
if test "$modify" ; then
|
||||
log_verbose "modify branch1 in $owner/$repo with $modify"
|
||||
$modify
|
||||
fi
|
||||
git config user.email root@example.com
|
||||
git config user.name username
|
||||
git add .
|
||||
git commit -m 'update'
|
||||
git push origin branch1
|
||||
git rev-parse HEAD > ../${owner}-${repo}.sha
|
||||
cd $TMPDIR
|
||||
rm -fr ${repo}
|
||||
git clone -b branch1 http://user1:admin1234@${options[host_port]}/$owner/${repo}
|
||||
cd ${repo}
|
||||
echo CONTENT >README
|
||||
if test "$modify"; then
|
||||
log_verbose "modify branch1 in $owner/$repo with $modify"
|
||||
$modify
|
||||
fi
|
||||
git config user.email root@example.com
|
||||
git config user.name username
|
||||
git add .
|
||||
git commit -m 'update'
|
||||
git push origin branch1
|
||||
git rev-parse HEAD >../${owner}-${repo}.sha
|
||||
)
|
||||
}
|
||||
|
||||
function delete_pull_requests() {
|
||||
local owner=$1 repo=$2
|
||||
|
||||
forgejo-curl.sh api_json ${options[url]}/api/v1/repos/$owner/${repo}/pulls | jq --raw-output '.[] | .number' | while read pr ; do
|
||||
forgejo-curl.sh api_json -X DELETE ${options[url]}/api/v1/repos/$owner/${repo}/issues/$pr
|
||||
forgejo-curl.sh api_json ${options[url]}/api/v1/repos/$owner/${repo}/pulls | jq --raw-output '.[] | .number' | while read pr; do
|
||||
forgejo-curl.sh api_json -X DELETE ${options[url]}/api/v1/repos/$owner/${repo}/issues/$pr
|
||||
done
|
||||
}
|
||||
|
||||
|
||||
function create_pull_request() {
|
||||
local baseowner=$1 headowner=$2 repo=$3
|
||||
|
||||
local head
|
||||
if test $baseowner == $headowner; then
|
||||
head=branch1
|
||||
head=branch1
|
||||
else
|
||||
head=$headowner:branch1
|
||||
head=$headowner:branch1
|
||||
fi
|
||||
cat > $TMPDIR/data <<EOF
|
||||
cat >$TMPDIR/data <<EOF
|
||||
{"title":"PR","base":"main","head":"$head"}
|
||||
EOF
|
||||
log_verbose "create pull request in $baseowner/$repo from $head"
|
||||
|
@ -184,12 +183,12 @@ function unit_finalize_options() {
|
|||
function unit_retry_fail() {
|
||||
local file=$1
|
||||
local value=$(cat $file)
|
||||
expr $value - 1 > $file
|
||||
expr $value - 1 >$file
|
||||
echo RESULT
|
||||
if test $value -gt 0 ; then
|
||||
return 1
|
||||
if test $value -gt 0; then
|
||||
return 1
|
||||
else
|
||||
return 0
|
||||
return 0
|
||||
fi
|
||||
}
|
||||
|
||||
|
@ -201,43 +200,43 @@ function unit_retry() {
|
|||
#
|
||||
# Succeeds after two tries
|
||||
#
|
||||
echo 2 > $TMPDIR/unit_retry_two
|
||||
if ! RETRY_DELAYS='1 1 1 1' retry unit_retry_fail $two > $TMPDIR/retry.test-result 2> $TMPDIR/retry.test-log ; then
|
||||
cat $TMPDIR/retry.test-result $TMPDIR/retry.test-log
|
||||
return 1
|
||||
echo 2 >$TMPDIR/unit_retry_two
|
||||
if ! RETRY_DELAYS='1 1 1 1' retry unit_retry_fail $two >$TMPDIR/retry.test-result 2>$TMPDIR/retry.test-log; then
|
||||
cat $TMPDIR/retry.test-result $TMPDIR/retry.test-log
|
||||
return 1
|
||||
fi
|
||||
test "$(cat $TMPDIR/retry.test-result)" = "RESULT"
|
||||
if test "$(grep -c '^waiting 1 unit_retry_fail' $TMPDIR/retry.test-log)" != 2 ; then
|
||||
cat $TMPDIR/retry.test-log
|
||||
return 1
|
||||
if test "$(grep -c '^waiting 1 unit_retry_fail' $TMPDIR/retry.test-log)" != 2; then
|
||||
cat $TMPDIR/retry.test-log
|
||||
return 1
|
||||
fi
|
||||
#
|
||||
# Succeeds immediately
|
||||
#
|
||||
if ! RETRY_DELAYS='1' retry unit_retry_fail $two > $TMPDIR/retry.test-result 2> $TMPDIR/retry.test-log ; then
|
||||
cat $TMPDIR/retry.test-result $TMPDIR/retry.test-log
|
||||
return 1
|
||||
if ! RETRY_DELAYS='1' retry unit_retry_fail $two >$TMPDIR/retry.test-result 2>$TMPDIR/retry.test-log; then
|
||||
cat $TMPDIR/retry.test-result $TMPDIR/retry.test-log
|
||||
return 1
|
||||
fi
|
||||
test "$(cat $TMPDIR/retry.test-result)" = "RESULT"
|
||||
if test "$(grep -c 'waiting 1 unit_retry_fail' $TMPDIR/retry.test-log)" != 0 ; then
|
||||
cat $TMPDIR/retry.test-log
|
||||
return 1
|
||||
if test "$(grep -c 'waiting 1 unit_retry_fail' $TMPDIR/retry.test-log)" != 0; then
|
||||
cat $TMPDIR/retry.test-log
|
||||
return 1
|
||||
fi
|
||||
|
||||
#
|
||||
# Verify the output is only the output of the last run and is not polluted by
|
||||
# unrelated output
|
||||
#
|
||||
echo 2 > $TMPDIR/unit_retry_two
|
||||
echo 2 >$TMPDIR/unit_retry_two
|
||||
test "$(RETRY_DELAYS='1 1 1' retry unit_retry_fail $two)" = "RESULT"
|
||||
|
||||
#
|
||||
# Fails after one try
|
||||
#
|
||||
echo 2 > $TMPDIR/unit_retry_two
|
||||
if RETRY_DELAYS='1' retry unit_retry_fail $two > $TMPDIR/retry.test-result 2> $TMPDIR/retry.test-log ; then
|
||||
cat $TMPDIR/retry.test-result $TMPDIR/retry.test-log
|
||||
return 1
|
||||
echo 2 >$TMPDIR/unit_retry_two
|
||||
if RETRY_DELAYS='1' retry unit_retry_fail $two >$TMPDIR/retry.test-result 2>$TMPDIR/retry.test-log; then
|
||||
cat $TMPDIR/retry.test-result $TMPDIR/retry.test-log
|
||||
return 1
|
||||
fi
|
||||
grep --quiet 'retry failed' $TMPDIR/retry.test-log
|
||||
}
|
||||
|
@ -323,11 +322,11 @@ function create_and_close() {
|
|||
}
|
||||
|
||||
function taint_update() {
|
||||
if ! test -f upgraded ; then
|
||||
echo upgraded file not found
|
||||
return 1
|
||||
if ! test -f upgraded; then
|
||||
echo upgraded file not found
|
||||
return 1
|
||||
fi
|
||||
echo 'TAINTED' > upgraded
|
||||
echo 'TAINTED' >upgraded
|
||||
}
|
||||
|
||||
function create_from_origin_fork_and_close() {
|
||||
|
@ -423,20 +422,20 @@ function run() {
|
|||
shift
|
||||
|
||||
echo "Start running $fun ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
|
||||
if $DEBUG ; then
|
||||
$fun "$@"
|
||||
if $DEBUG; then
|
||||
$fun "$@"
|
||||
else
|
||||
mkdir -p $TMPDIR
|
||||
> $TMPDIR/$fun.out
|
||||
tail --follow $TMPDIR/$fun.out | sed --unbuffered -n -e "/^$PREFIX/s/^$PREFIX //p" &
|
||||
pid=$!
|
||||
if ! ${BASH_SOURCE[0]} --debug ${options[args]} $fun "$@" >& $TMPDIR/$fun.out ; then
|
||||
kill $pid
|
||||
cat $TMPDIR/$fun.out
|
||||
echo Failure running $fun
|
||||
return 1
|
||||
fi
|
||||
kill $pid
|
||||
mkdir -p $TMPDIR
|
||||
>$TMPDIR/$fun.out
|
||||
tail --follow $TMPDIR/$fun.out | sed --unbuffered -n -e "/^$PREFIX/s/^$PREFIX //p" &
|
||||
pid=$!
|
||||
if ! ${BASH_SOURCE[0]} --debug ${options[args]} $fun "$@" >&$TMPDIR/$fun.out; then
|
||||
kill $pid
|
||||
cat $TMPDIR/$fun.out
|
||||
echo Failure running $fun
|
||||
return 1
|
||||
fi
|
||||
kill $pid
|
||||
fi
|
||||
echo "Success running $fun ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
|
||||
}
|
||||
|
@ -467,11 +466,11 @@ function run_tests() {
|
|||
|
||||
function finalize_options() {
|
||||
if test -f $DIR/forgejo-ip; then
|
||||
: ${options[host_port]:=$(cat $DIR/forgejo-ip):3000}
|
||||
: ${options[host_port]:=$(cat $DIR/forgejo-ip):3000}
|
||||
fi
|
||||
options[url]=http://${options[host_port]}
|
||||
if test -f $DIR/forgejo-token; then
|
||||
: ${options[token]:=$(cat $DIR/forgejo-token)}
|
||||
: ${options[token]:=$(cat $DIR/forgejo-token)}
|
||||
fi
|
||||
options[password]=admin1234
|
||||
}
|
||||
|
@ -480,39 +479,39 @@ function main() {
|
|||
local command=run
|
||||
|
||||
while true; do
|
||||
case "$1" in
|
||||
--verbose)
|
||||
shift
|
||||
verbose
|
||||
;;
|
||||
--debug)
|
||||
shift
|
||||
debug
|
||||
;;
|
||||
--host_port)
|
||||
shift
|
||||
options[args]="${options[args]} --host_port $1"
|
||||
options[host_port]=$1
|
||||
shift
|
||||
;;
|
||||
--url)
|
||||
shift
|
||||
options[args]="${options[args]} --url $1"
|
||||
options[url]=$1
|
||||
shift
|
||||
;;
|
||||
--token)
|
||||
shift
|
||||
options[args]="${options[args]} --token $1"
|
||||
options[token]=$1
|
||||
shift
|
||||
;;
|
||||
*)
|
||||
finalize_options
|
||||
"${1:-run_tests}" "${@:2}"
|
||||
return 0
|
||||
;;
|
||||
esac
|
||||
case "$1" in
|
||||
--verbose)
|
||||
shift
|
||||
verbose
|
||||
;;
|
||||
--debug)
|
||||
shift
|
||||
debug
|
||||
;;
|
||||
--host_port)
|
||||
shift
|
||||
options[args]="${options[args]} --host_port $1"
|
||||
options[host_port]=$1
|
||||
shift
|
||||
;;
|
||||
--url)
|
||||
shift
|
||||
options[args]="${options[args]} --url $1"
|
||||
options[url]=$1
|
||||
shift
|
||||
;;
|
||||
--token)
|
||||
shift
|
||||
options[args]="${options[args]} --token $1"
|
||||
options[token]=$1
|
||||
shift
|
||||
;;
|
||||
*)
|
||||
finalize_options
|
||||
"${1:-run_tests}" "${@:2}"
|
||||
return 0
|
||||
;;
|
||||
esac
|
||||
done
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue