2016-03-23 20:18:33 -04:00
|
|
|
load common
|
|
|
|
load_fixtures
|
2016-04-06 13:33:42 -04:00
|
|
|
status=;output=; #; populated by bats run()
|
2016-03-23 20:18:33 -04:00
|
|
|
|
|
|
|
IN_REPO=(.bash_profile .vimrc)
|
|
|
|
T_DIR_REMOTE="$T_TMP/remote"
|
|
|
|
REMOTE_URL="file:///$T_TMP/remote"
|
|
|
|
|
|
|
|
setup() {
|
|
|
|
destroy_tmp
|
|
|
|
build_repo "${IN_REPO[@]}"
|
|
|
|
cp -rp "$T_DIR_REPO" "$T_DIR_REMOTE"
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "Command 'clone' (bad remote)" {
|
|
|
|
echo "
|
|
|
|
When 'clone' command is provided,
|
|
|
|
and the remote is bad,
|
|
|
|
Report error
|
|
|
|
Remove the YADM_REPO
|
|
|
|
Exit with 1
|
|
|
|
"
|
|
|
|
|
|
|
|
#; remove existing worktree and repo
|
|
|
|
rm -rf "$T_DIR_WORK"
|
|
|
|
mkdir -p "$T_DIR_WORK"
|
|
|
|
rm -rf "$T_DIR_REPO"
|
|
|
|
|
|
|
|
#; run clone
|
2016-04-06 13:33:42 -04:00
|
|
|
run "${T_YADM_Y[@]}" clone -w "$T_DIR_WORK" "file:///bogus-repo"
|
2016-03-23 20:18:33 -04:00
|
|
|
|
|
|
|
#; validate status and output
|
|
|
|
[ "$status" -eq 1 ]
|
|
|
|
[[ "$output" =~ Unable\ to\ fetch\ origin ]]
|
|
|
|
|
|
|
|
#; confirm repo directory is removed
|
|
|
|
[ ! -d "$T_DIR_REPO" ]
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "Command 'clone'" {
|
|
|
|
echo "
|
|
|
|
When 'clone' command is provided,
|
|
|
|
Create new repo with attributes:
|
|
|
|
- 0600 permissions
|
|
|
|
- not bare
|
|
|
|
- worktree = \$YADM_WORK
|
|
|
|
- showUntrackedFiles = no
|
|
|
|
- yadm.managed = true
|
|
|
|
Report the repo as cloned
|
|
|
|
A remote named origin exists
|
|
|
|
Exit with 0
|
|
|
|
"
|
|
|
|
|
|
|
|
#; remove existing worktree and repo
|
|
|
|
rm -rf "$T_DIR_WORK"
|
|
|
|
mkdir -p "$T_DIR_WORK"
|
|
|
|
rm -rf "$T_DIR_REPO"
|
|
|
|
|
|
|
|
#; run clone
|
2016-04-06 13:33:42 -04:00
|
|
|
run "${T_YADM_Y[@]}" clone -w "$T_DIR_WORK" "$REMOTE_URL"
|
2016-03-23 20:18:33 -04:00
|
|
|
|
|
|
|
#; validate status and output
|
|
|
|
[ "$status" -eq 0 ]
|
|
|
|
[[ "$output" =~ Initialized ]]
|
|
|
|
|
|
|
|
#; validate repo attributes
|
2016-04-06 13:33:42 -04:00
|
|
|
test_perms "$T_DIR_REPO" "drw.--.--."
|
|
|
|
test_repo_attribute "$T_DIR_REPO" core.bare false
|
|
|
|
test_repo_attribute "$T_DIR_REPO" core.worktree "$T_DIR_WORK"
|
|
|
|
test_repo_attribute "$T_DIR_REPO" status.showUntrackedFiles no
|
|
|
|
test_repo_attribute "$T_DIR_REPO" yadm.managed true
|
2016-03-23 20:18:33 -04:00
|
|
|
|
|
|
|
#; test the remote
|
2016-04-06 13:33:42 -04:00
|
|
|
local remote_output
|
|
|
|
remote_output=$(GIT_DIR="$T_DIR_REPO" git remote show)
|
2016-03-23 20:18:33 -04:00
|
|
|
[ "$remote_output" = "origin" ]
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "Command 'clone' (existing repo)" {
|
|
|
|
echo "
|
|
|
|
When 'clone' command is provided,
|
|
|
|
and a repo already exists,
|
|
|
|
Report error
|
|
|
|
Exit with 1
|
|
|
|
"
|
|
|
|
|
|
|
|
#; run clone
|
2016-04-06 13:33:42 -04:00
|
|
|
run "${T_YADM_Y[@]}" clone -w "$T_DIR_WORK" "$REMOTE_URL"
|
2016-03-23 20:18:33 -04:00
|
|
|
|
|
|
|
#; validate status and output
|
|
|
|
[ "$status" -eq 1 ]
|
|
|
|
[[ "$output" =~ Git\ repo\ already\ exists ]]
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "Command 'clone' -f (force overwrite)" {
|
|
|
|
echo "
|
|
|
|
When 'clone' command is provided,
|
|
|
|
and '-f' is provided,
|
|
|
|
and a repo already exists,
|
|
|
|
Overwrite the repo with attributes:
|
|
|
|
- 0600 permissions
|
|
|
|
- not bare
|
|
|
|
- worktree = \$YADM_WORK
|
|
|
|
- showUntrackedFiles = no
|
|
|
|
- yadm.managed = true
|
|
|
|
Report the repo as cloned
|
|
|
|
A remote named origin exists
|
|
|
|
Exit with 0
|
|
|
|
"
|
|
|
|
|
|
|
|
#; remove existing worktree
|
|
|
|
rm -rf "$T_DIR_WORK"
|
|
|
|
mkdir -p "$T_DIR_WORK"
|
|
|
|
|
|
|
|
#; run clone
|
2016-04-06 13:33:42 -04:00
|
|
|
run "${T_YADM_Y[@]}" clone -w "$T_DIR_WORK" -f "$REMOTE_URL"
|
2016-03-23 20:18:33 -04:00
|
|
|
|
|
|
|
#; validate status and output
|
|
|
|
[ "$status" -eq 0 ]
|
|
|
|
[[ "$output" =~ Initialized ]]
|
|
|
|
|
|
|
|
#; validate repo attributes
|
2016-04-06 13:33:42 -04:00
|
|
|
test_perms "$T_DIR_REPO" "drw.--.--."
|
|
|
|
test_repo_attribute "$T_DIR_REPO" core.bare false
|
|
|
|
test_repo_attribute "$T_DIR_REPO" core.worktree "$T_DIR_WORK"
|
|
|
|
test_repo_attribute "$T_DIR_REPO" status.showUntrackedFiles no
|
|
|
|
test_repo_attribute "$T_DIR_REPO" yadm.managed true
|
2016-03-23 20:18:33 -04:00
|
|
|
|
|
|
|
#; test the remote
|
2016-04-06 13:33:42 -04:00
|
|
|
local remote_output
|
|
|
|
remote_output=$(GIT_DIR="$T_DIR_REPO" git remote show)
|
2016-03-23 20:18:33 -04:00
|
|
|
[ "$remote_output" = "origin" ]
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "Command 'clone' (existing conflicts)" {
|
|
|
|
echo "
|
|
|
|
When 'clone' command is provided,
|
|
|
|
and '-f' is provided,
|
|
|
|
and a repo already exists,
|
|
|
|
Overwrite the repo with attributes:
|
|
|
|
- 0600 permissions
|
|
|
|
- not bare
|
|
|
|
- worktree = \$YADM_WORK
|
|
|
|
- showUntrackedFiles = no
|
|
|
|
- yadm.managed = true
|
|
|
|
Report the repo as cloned
|
|
|
|
A remote named origin exists
|
|
|
|
Exit with 0
|
|
|
|
"
|
|
|
|
|
|
|
|
#; remove existing repo
|
|
|
|
rm -rf "$T_DIR_REPO"
|
|
|
|
|
|
|
|
#; cause a conflict
|
|
|
|
echo "conflict" >> "$T_DIR_WORK/.bash_profile"
|
|
|
|
|
|
|
|
#; run clone
|
2016-04-06 13:33:42 -04:00
|
|
|
run "${T_YADM_Y[@]}" clone -w "$T_DIR_WORK" "$REMOTE_URL"
|
2016-03-23 20:18:33 -04:00
|
|
|
|
|
|
|
#; validate status and output
|
|
|
|
[ "$status" -eq 0 ]
|
|
|
|
[[ "$output" =~ Initialized ]]
|
|
|
|
|
|
|
|
#; validate merging note
|
2016-04-06 13:33:42 -04:00
|
|
|
[[ "$output" =~ Merging\ origin/master\ failed ]]
|
2016-03-23 20:18:33 -04:00
|
|
|
[[ "$output" =~ NOTE ]]
|
|
|
|
|
|
|
|
#; validate repo attributes
|
2016-04-06 13:33:42 -04:00
|
|
|
test_perms "$T_DIR_REPO" "drw.--.--."
|
|
|
|
test_repo_attribute "$T_DIR_REPO" core.bare false
|
|
|
|
test_repo_attribute "$T_DIR_REPO" core.worktree "$T_DIR_WORK"
|
|
|
|
test_repo_attribute "$T_DIR_REPO" status.showUntrackedFiles no
|
|
|
|
test_repo_attribute "$T_DIR_REPO" yadm.managed true
|
2016-03-23 20:18:33 -04:00
|
|
|
|
|
|
|
#; test the remote
|
2016-04-06 13:33:42 -04:00
|
|
|
local remote_output
|
|
|
|
remote_output=$(GIT_DIR="$T_DIR_REPO" git remote show)
|
2016-03-23 20:18:33 -04:00
|
|
|
[ "$remote_output" = "origin" ]
|
2017-01-20 17:31:51 -05:00
|
|
|
|
|
|
|
#; confirm yadm repo is clean
|
|
|
|
cd "$T_DIR_WORK" ||:
|
|
|
|
clean_status=$("${T_YADM_Y[@]}" status -uno --porcelain)
|
|
|
|
echo "clean_status:'$clean_status'"
|
|
|
|
[ -z "$clean_status" ]
|
|
|
|
|
|
|
|
#; confirm conflicts are stashed
|
|
|
|
existing_stash=$("${T_YADM_Y[@]}" stash list)
|
|
|
|
echo "existing_stash:'$existing_stash'"
|
|
|
|
[[ "$existing_stash" =~ Conflicts\ preserved ]]
|
|
|
|
|
|
|
|
stashed_conflicts=$("${T_YADM_Y[@]}" stash show -p)
|
|
|
|
echo "stashed_conflicts:'$stashed_conflicts'"
|
|
|
|
[[ "$stashed_conflicts" =~ \+conflict ]]
|
|
|
|
|
2016-03-23 20:18:33 -04:00
|
|
|
}
|