Rename project to actions-sync
This commit is contained in:
37
script/bootstrap
Executable file
37
script/bootstrap
Executable file
@@ -0,0 +1,37 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
set -o errexit
|
||||
set -o nounset
|
||||
|
||||
test -z "${DEBUG:-}" || {
|
||||
set -x
|
||||
}
|
||||
|
||||
tools=$(pwd)/_tools
|
||||
export GOBIN="${tools}/bin"
|
||||
export GO111MODULE=on
|
||||
|
||||
mkdir -p "${GOBIN}"
|
||||
cd "${tools}"
|
||||
|
||||
if [ ! -f go.mod ]; then
|
||||
go mod init tools
|
||||
fi
|
||||
|
||||
go get golang.org/x/tools/go/packages@master
|
||||
|
||||
if [ ! -f "${GOBIN}/mockgen" ]; then
|
||||
echo "mockgen was not found, installing..."
|
||||
go get github.com/golang/mock/gomock@master
|
||||
go get github.com/golang/mock/mockgen@master
|
||||
fi
|
||||
|
||||
if [ ! -f "${GOBIN}/golangci-lint" ]; then
|
||||
echo "golangci was not found, installing..."
|
||||
go get github.com/golangci/golangci-lint/cmd/golangci-lint@master
|
||||
fi
|
||||
|
||||
if [ ! -f "${GOBIN}/goimports" ]; then
|
||||
echo "goimports was not found, installing..."
|
||||
go get golang.org/x/tools/cmd/goimports@master
|
||||
fi
|
||||
10
script/build
Executable file
10
script/build
Executable file
@@ -0,0 +1,10 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
set -o errexit
|
||||
set -o nounset
|
||||
|
||||
test -z "${DEBUG:-}" || {
|
||||
set -x
|
||||
}
|
||||
|
||||
go build -o bin/actions-sync main.go
|
||||
23
script/format
Executable file
23
script/format
Executable file
@@ -0,0 +1,23 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
set -o nounset
|
||||
|
||||
test -z "${DEBUG:-}" || {
|
||||
set -x
|
||||
}
|
||||
|
||||
module="github.com/actions/actions-sync"
|
||||
|
||||
function fmt {
|
||||
gofmt -w -s "${1}"
|
||||
_tools/bin/goimports -l -w "${1}"
|
||||
}
|
||||
|
||||
files=$(go list ./... 2>/dev/null | grep -v "^${module}\$" | sed -e "s|${module}/|./|" | xargs -I {} find {} -type f -name '*.go')
|
||||
|
||||
echo Run go fmt...
|
||||
for f in $files; do
|
||||
fmt "${f}" &
|
||||
done
|
||||
|
||||
wait
|
||||
10
script/lint
Executable file
10
script/lint
Executable file
@@ -0,0 +1,10 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
set -o errexit
|
||||
set -o nounset
|
||||
|
||||
test -z "${DEBUG:-}" || {
|
||||
set -x
|
||||
}
|
||||
|
||||
_tools/bin/golangci-lint run --config .golangci.yaml
|
||||
14
script/release
Executable file
14
script/release
Executable file
@@ -0,0 +1,14 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
set -o errexit
|
||||
set -o nounset
|
||||
|
||||
test -z "${DEBUG:-}" || {
|
||||
set -x
|
||||
}
|
||||
|
||||
tag=$(date +'%Y%m%d%H%M')
|
||||
git commit --allow-empty -m "Release $tag"
|
||||
git tag "v${tag}"
|
||||
git push --tags
|
||||
git push
|
||||
10
script/test
Executable file
10
script/test
Executable file
@@ -0,0 +1,10 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
set -o errexit
|
||||
set -o nounset
|
||||
|
||||
test -z "${DEBUG:-}" || {
|
||||
set -x
|
||||
}
|
||||
|
||||
go test -cover ./...
|
||||
304
script/test-build
Executable file
304
script/test-build
Executable file
@@ -0,0 +1,304 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
script/build
|
||||
|
||||
OUTPUT=$(mktemp)
|
||||
RESULT=-1
|
||||
|
||||
SRC_GIT_DAEMON_PORT=9419
|
||||
SRC_GIT_DAEMON_OUTPUT=$(mktemp)
|
||||
SRC_GIT_DAEMON_PID=-1
|
||||
|
||||
DEST_GIT_DAEMON_PORT=9420
|
||||
DEST_GIT_DAEMON_OUTPUT=$(mktemp)
|
||||
DEST_GIT_DAEMON_PID=-1
|
||||
|
||||
DEST_API_PORT=8081
|
||||
DEST_API_OUTPUT=$(mktemp)
|
||||
DEST_API_PID=-1
|
||||
trap "after_suite" EXIT
|
||||
trap "after_suite" SIGINT
|
||||
|
||||
function test_pull() {
|
||||
# Pull new repo
|
||||
setup_src "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
setup_cache
|
||||
pull --repo-name "org/repo" "pulling new repo"
|
||||
assert_cache_sha "org/repo" "heads/master" "a5984bb887dd2fcdc2892cd906d6f004844d1142" "pulling new repo org/repo"
|
||||
|
||||
echo "all pull tests passed successfully"
|
||||
}
|
||||
|
||||
function test_push() {
|
||||
# Push with a new change to master
|
||||
setup_cache "org/repo:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52"
|
||||
setup_dest "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
|
||||
push "pushing new commit to master"
|
||||
assert_dest_sha "org/repo" "heads/master" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "updating org/repo:heads/master to new commit"
|
||||
|
||||
# Push a non-linear change
|
||||
setup_cache "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
setup_dest "org/repo:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52"
|
||||
|
||||
push "pushing to an old commit to master"
|
||||
assert_dest_sha "org/repo" "heads/master" "a5984bb887dd2fcdc2892cd906d6f004844d1142" "updating heads/master to an old commit"
|
||||
|
||||
# Push with no changes to master
|
||||
setup_cache "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
setup_dest "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
push "pushing no changes to master"
|
||||
assert_dest_sha "org/repo" "heads/master" "a5984bb887dd2fcdc2892cd906d6f004844d1142" "leaving org/repo:heads/master at existing commit"
|
||||
|
||||
# Push multiple branches
|
||||
setup_cache "org/repo:heads/change:e9009d51dd6da2c363d1d14779c53dd27fcb0c52" \
|
||||
"org/repo:heads/nochange:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
setup_dest "org/repo:heads/change:a5984bb887dd2fcdc2892cd906d6f004844d1142" \
|
||||
"org/repo:heads/nochange:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
|
||||
push "pushing multiple branches"
|
||||
assert_dest_sha "org/repo" "heads/change" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "updating org/repo:heads/change to new commit"
|
||||
assert_dest_sha "org/repo" "heads/nochange" "a5984bb887dd2fcdc2892cd906d6f004844d1142" "leaving org/repo:heads/nochange at existing commit"
|
||||
|
||||
# Pushing multiple branches and tags
|
||||
setup_cache "org/repo:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52" \
|
||||
"org/repo:tags/v1:e9009d51dd6da2c363d1d14779c53dd27fcb0c52"
|
||||
setup_dest "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142" \
|
||||
"org/repo:tags/v1:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
|
||||
push "pushing multiple branches and tags"
|
||||
assert_dest_sha "org/repo" "heads/master" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "updating org/repo:heads/master to new commit"
|
||||
assert_dest_sha "org/repo" "tags/v1" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "updating org/repo:tags/v1 to new commit"
|
||||
|
||||
# Pushing multiple repositories
|
||||
setup_cache "org1/repo1:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52" \
|
||||
"org1/repo2:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52" \
|
||||
"org1/repo2:tags/v1:e9009d51dd6da2c363d1d14779c53dd27fcb0c52" \
|
||||
"org2/repo1:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52"
|
||||
setup_dest "org1/repo1:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142" \
|
||||
"org1/repo2:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142" \
|
||||
"org1/repo2:tags/v1:a5984bb887dd2fcdc2892cd906d6f004844d1142" \
|
||||
"org2/repo1:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
|
||||
push "pushing multiple repositories"
|
||||
assert_dest_sha "org1/repo1" "heads/master" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "updating org1/repo1:heads/master to new commit"
|
||||
assert_dest_sha "org1/repo2" "heads/master" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "updating org1/repo2:heads/master to new commit"
|
||||
assert_dest_sha "org1/repo2" "tags/v1" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "updating org1/repo2:tags/v1 to new commit"
|
||||
assert_dest_sha "org2/repo1" "heads/master" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "updating org2/repo1:tags/v1 to new commit"
|
||||
|
||||
echo "all push tests passed successfully"
|
||||
}
|
||||
|
||||
function test_sync() {
|
||||
# Sync no change without cached
|
||||
setup_src "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
setup_cache
|
||||
setup_dest "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
sync --repo-name "org/repo" "syncing a new commit in an uncached repo"
|
||||
assert_dest_sha "org/repo" "heads/master" "a5984bb887dd2fcdc2892cd906d6f004844d1142" "syncing no changes without cache"
|
||||
|
||||
# Sync a new commit without cache
|
||||
setup_src "org/repo:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52"
|
||||
setup_cache
|
||||
setup_dest "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
sync --repo-name "org/repo" "syncing a new commit in an uncached repo"
|
||||
assert_dest_sha "org/repo" "heads/master" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "syncing a new commit without cache"
|
||||
|
||||
# Sync no change with uncached
|
||||
setup_src "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
setup_cache "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
setup_dest "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
sync --repo-name "org/repo" "syncing a new commit in an uncached repo"
|
||||
assert_dest_sha "org/repo" "heads/master" "a5984bb887dd2fcdc2892cd906d6f004844d1142" "syncing no changes with cache"
|
||||
|
||||
# Sync a new commit with cache
|
||||
setup_src "org/repo:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52"
|
||||
setup_cache "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
setup_dest "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
sync --repo-name "org/repo" "syncing a new commit in an uncached repo"
|
||||
assert_dest_sha "org/repo" "heads/master" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "syncing a new commit with cache"
|
||||
|
||||
# Sync a non-linear change without cache
|
||||
setup_src "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
setup_cache
|
||||
setup_dest "org/repo:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52"
|
||||
|
||||
sync --repo-name "org/repo" "syncing an old commit in an uncached repo"
|
||||
assert_dest_sha "org/repo" "heads/master" "a5984bb887dd2fcdc2892cd906d6f004844d1142" "syncing heads/master to an old commit without cache"
|
||||
|
||||
# Sync a non-linear change with cache
|
||||
setup_src "org/repo:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
setup_cache "org/repo:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52"
|
||||
setup_dest "org/repo:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52"
|
||||
|
||||
sync --repo-name "org/repo" "syncing an old commit in an cached repo"
|
||||
assert_dest_sha "org/repo" "heads/master" "a5984bb887dd2fcdc2892cd906d6f004844d1142" "syncing heads/master to an old commit with cache"
|
||||
|
||||
# Sync to a different repo
|
||||
setup_src "org/repo:heads/master:e9009d51dd6da2c363d1d14779c53dd27fcb0c52"
|
||||
setup_cache
|
||||
setup_dest "org2/repo2:heads/master:a5984bb887dd2fcdc2892cd906d6f004844d1142"
|
||||
|
||||
sync --repo-name "org/repo:org2/repo2" "syncing org/repo aliased to org2/repo2"
|
||||
assert_dest_sha "org2/repo2" "heads/master" "e9009d51dd6da2c363d1d14779c53dd27fcb0c52" "syncing org/repo aliased to org2/repo2"
|
||||
|
||||
echo "all sync tests passed successfully"
|
||||
}
|
||||
|
||||
function before_suite() {
|
||||
set -e
|
||||
$(
|
||||
rm -rf test/tmp
|
||||
mkdir -p test/tmp/dest
|
||||
mkdir -p test/tmp/src
|
||||
) > /dev/null
|
||||
|
||||
git daemon \
|
||||
--reuseaddr \
|
||||
--verbose \
|
||||
--export-all \
|
||||
--enable=receive-pack \
|
||||
--port="$SRC_GIT_DAEMON_PORT" \
|
||||
--base-path=test/tmp/src &> $SRC_GIT_DAEMON_OUTPUT &
|
||||
SRC_GIT_DAEMON_PID=$!
|
||||
|
||||
git daemon \
|
||||
--reuseaddr \
|
||||
--verbose \
|
||||
--export-all \
|
||||
--enable=receive-pack \
|
||||
--port="$DEST_GIT_DAEMON_PORT" \
|
||||
--base-path=test/tmp/dest &> $DEST_GIT_DAEMON_OUTPUT &
|
||||
DEST_GIT_DAEMON_PID=$!
|
||||
|
||||
go run test/github.go \
|
||||
-p "$DEST_API_PORT" \
|
||||
-git-daemon-url "git://localhost:$DEST_GIT_DAEMON_PORT/" &> $DEST_API_OUTPUT &
|
||||
DEST_API_PID=$!
|
||||
|
||||
script/build
|
||||
|
||||
until $(curl --output /dev/null --silent --head --fail "http://localhost:$DEST_API_PORT/ping"); do
|
||||
sleep 0.1
|
||||
done
|
||||
|
||||
set +e
|
||||
}
|
||||
|
||||
function after_suite() {
|
||||
kill "$SRC_GIT_DAEMON_PID" "$DEST_GIT_DAEMON_PID" "$DEST_API_PID"
|
||||
}
|
||||
|
||||
function setup_src() {
|
||||
rm -rf test/tmp/src
|
||||
mkdir -p test/tmp/src
|
||||
|
||||
for r in "$@"; do
|
||||
local nwo=$(echo $r | cut -d':' -f1)
|
||||
local refname=$(echo $r | cut -d':' -f2)
|
||||
local sha=$(echo $r | cut -d':' -f3)
|
||||
|
||||
local org=$(echo $nwo | cut -d'/' -f1)
|
||||
mkdir -p test/tmp/src/$org && cp -R test/fixtures/repo.git test/tmp/src/$nwo
|
||||
echo "$sha" > "test/tmp/src/$nwo/refs/$refname"
|
||||
done
|
||||
}
|
||||
|
||||
function setup_cache() {
|
||||
rm -rf test/tmp/cache
|
||||
mkdir -p test/tmp/cache
|
||||
|
||||
for r in "$@"; do
|
||||
local nwo=$(echo $r | cut -d':' -f1)
|
||||
local refname=$(echo $r | cut -d':' -f2)
|
||||
local sha=$(echo $r | cut -d':' -f3)
|
||||
mkdir -p test/tmp/cache/$nwo && cp -R test/fixtures/repo.git test/tmp/cache/$nwo/.git
|
||||
echo "$sha" > "test/tmp/cache/$nwo/.git/refs/$refname"
|
||||
done
|
||||
}
|
||||
|
||||
function setup_dest() {
|
||||
rm -rf test/tmp/dest
|
||||
mkdir -p test/tmp/dest
|
||||
|
||||
for r in "$@"; do
|
||||
local nwo=$(echo $r | cut -d':' -f1)
|
||||
local refname=$(echo $r | cut -d':' -f2)
|
||||
local sha=$(echo $r | cut -d':' -f3)
|
||||
mkdir -p test/tmp/dest/$nwo && cp -R test/fixtures/repo.git test/tmp/dest/$nwo/.git
|
||||
echo "$sha" > "test/tmp/dest/$nwo/.git/refs/$refname"
|
||||
done
|
||||
}
|
||||
|
||||
function pull() {
|
||||
bin/actions-sync pull \
|
||||
--cache-dir "test/tmp/cache" \
|
||||
--source-url "git://localhost:$SRC_GIT_DAEMON_PORT" \
|
||||
"$1" "$2" \
|
||||
&> $OUTPUT ||
|
||||
fail $3
|
||||
}
|
||||
|
||||
function push() {
|
||||
bin/actions-sync push \
|
||||
--cache-dir "test/tmp/cache" \
|
||||
--disable-push-git-auth \
|
||||
--destination-token "token" \
|
||||
--destination-url "http://localhost:$DEST_API_PORT" \
|
||||
&> $OUTPUT ||
|
||||
fail "$1"
|
||||
}
|
||||
|
||||
function sync() {
|
||||
bin/actions-sync sync \
|
||||
--cache-dir "test/tmp/cache" \
|
||||
--source-url "git://localhost:$SRC_GIT_DAEMON_PORT" \
|
||||
--disable-push-git-auth \
|
||||
--destination-token "token" \
|
||||
--destination-url "http://localhost:$DEST_API_PORT" \
|
||||
"$1" "$2" \
|
||||
&> $OUTPUT ||
|
||||
fail $3
|
||||
}
|
||||
|
||||
function assert_cache_sha() {
|
||||
nwo=$1
|
||||
ref=$2
|
||||
expected=$3
|
||||
actual=$(cat "test/tmp/cache/$nwo/.git/refs/$ref")
|
||||
[ "$actual" == "$expected" ] || fail "unexpected cache sha \`$expected != $actual\` - \`$nwo\` \`$ref\` - \`$4\`"
|
||||
}
|
||||
|
||||
function assert_dest_sha() {
|
||||
nwo=$1
|
||||
ref=$2
|
||||
expected=$3
|
||||
actual=$(cat "test/tmp/dest/$nwo/.git/refs/$ref")
|
||||
[ "$actual" == "$expected" ] || fail "unexpected dest sha \`$expected != $actual\` - \`$nwo\` \`$ref\` - \`$4\`"
|
||||
}
|
||||
|
||||
function fail() {
|
||||
MSG=$1
|
||||
echo "FAIL: Failed $MSG"
|
||||
echo -----output-----
|
||||
cat $OUTPUT
|
||||
echo -----/output-----
|
||||
|
||||
echo -----github git daemon output-----
|
||||
cat $SRC_GIT_DAEMON_OUTPUT
|
||||
echo -----/github git daemon output-----
|
||||
|
||||
echo -----ghes git daemon output-----
|
||||
cat $DEST_GIT_DAEMON_OUTPUT
|
||||
echo -----/ghes git daemon output-----
|
||||
|
||||
echo -----ghes api output-----
|
||||
cat $DEST_API_OUTPUT
|
||||
echo -----/ghes api output-----
|
||||
exit 1
|
||||
}
|
||||
|
||||
before_suite
|
||||
test_pull
|
||||
test_push
|
||||
test_sync
|
||||
Reference in New Issue
Block a user