Merge branch 'jk/http-push-to-empty' into maint
* jk/http-push-to-empty: remote-curl: don't pass back fake refs Conflicts: remote-curl.c
This commit is contained in:
commit
b5c12797b4
@ -188,7 +188,7 @@ static int write_discovery(int in, int out, void *data)
|
||||
return err;
|
||||
}
|
||||
|
||||
static struct ref *parse_git_refs(struct discovery *heads)
|
||||
static struct ref *parse_git_refs(struct discovery *heads, int for_push)
|
||||
{
|
||||
struct ref *list = NULL;
|
||||
struct async async;
|
||||
@ -200,7 +200,8 @@ static struct ref *parse_git_refs(struct discovery *heads)
|
||||
|
||||
if (start_async(&async))
|
||||
die("cannot start thread to parse advertised refs");
|
||||
get_remote_heads(async.out, &list, 0, NULL);
|
||||
get_remote_heads(async.out, &list,
|
||||
for_push ? REF_NORMAL : 0, NULL);
|
||||
close(async.out);
|
||||
if (finish_async(&async))
|
||||
die("ref parsing thread failed");
|
||||
@ -268,7 +269,7 @@ static struct ref *get_refs(int for_push)
|
||||
heads = discover_refs("git-upload-pack");
|
||||
|
||||
if (heads->proto_git)
|
||||
return parse_git_refs(heads);
|
||||
return parse_git_refs(heads, for_push);
|
||||
return parse_info_refs(heads);
|
||||
}
|
||||
|
||||
|
@ -154,5 +154,37 @@ test_expect_success 'push (chunked)' '
|
||||
test $HEAD = $(git rev-parse --verify HEAD))
|
||||
'
|
||||
|
||||
test_expect_success 'push --all can push to empty repo' '
|
||||
d=$HTTPD_DOCUMENT_ROOT_PATH/empty-all.git &&
|
||||
git init --bare "$d" &&
|
||||
git --git-dir="$d" config http.receivepack true &&
|
||||
git push --all "$HTTPD_URL"/smart/empty-all.git
|
||||
'
|
||||
|
||||
test_expect_success 'push --mirror can push to empty repo' '
|
||||
d=$HTTPD_DOCUMENT_ROOT_PATH/empty-mirror.git &&
|
||||
git init --bare "$d" &&
|
||||
git --git-dir="$d" config http.receivepack true &&
|
||||
git push --mirror "$HTTPD_URL"/smart/empty-mirror.git
|
||||
'
|
||||
|
||||
test_expect_success 'push --all to repo with alternates' '
|
||||
s=$HTTPD_DOCUMENT_ROOT_PATH/test_repo.git &&
|
||||
d=$HTTPD_DOCUMENT_ROOT_PATH/alternates-all.git &&
|
||||
git clone --bare --shared "$s" "$d" &&
|
||||
git --git-dir="$d" config http.receivepack true &&
|
||||
git --git-dir="$d" repack -adl &&
|
||||
git push --all "$HTTPD_URL"/smart/alternates-all.git
|
||||
'
|
||||
|
||||
test_expect_success 'push --mirror to repo with alternates' '
|
||||
s=$HTTPD_DOCUMENT_ROOT_PATH/test_repo.git &&
|
||||
d=$HTTPD_DOCUMENT_ROOT_PATH/alternates-mirror.git &&
|
||||
git clone --bare --shared "$s" "$d" &&
|
||||
git --git-dir="$d" config http.receivepack true &&
|
||||
git --git-dir="$d" repack -adl &&
|
||||
git push --mirror "$HTTPD_URL"/smart/alternates-mirror.git
|
||||
'
|
||||
|
||||
stop_httpd
|
||||
test_done
|
||||
|
Loading…
Reference in New Issue
Block a user