зеркало из https://github.com/microsoft/git.git
Merge branch 'nd/upload-pack-shallow'
Serving objects from a shallow repository needs to write a temporary file to be used, but the serving upload-pack may not have write access to the repository which is meant to be read-only. Instead feed these temporary shallow bounds from the standard input of pack-objects so that we do not have to use a temporary file. * nd/upload-pack-shallow: upload-pack: send shallow info over stdin to pack-objects
This commit is contained in:
Коммит
1ddb4d7e5e
|
@ -64,6 +64,8 @@ base-name::
|
||||||
the same way as 'git rev-list' with the `--objects` flag
|
the same way as 'git rev-list' with the `--objects` flag
|
||||||
uses its `commit` arguments to build the list of objects it
|
uses its `commit` arguments to build the list of objects it
|
||||||
outputs. The objects on the resulting list are packed.
|
outputs. The objects on the resulting list are packed.
|
||||||
|
Besides revisions, `--not` or `--shallow <SHA-1>` lines are
|
||||||
|
also accepted.
|
||||||
|
|
||||||
--unpacked::
|
--unpacked::
|
||||||
This implies `--revs`. When processing the list of
|
This implies `--revs`. When processing the list of
|
||||||
|
|
|
@ -2449,6 +2449,9 @@ static void get_object_list(int ac, const char **av)
|
||||||
save_commit_buffer = 0;
|
save_commit_buffer = 0;
|
||||||
setup_revisions(ac, av, &revs, NULL);
|
setup_revisions(ac, av, &revs, NULL);
|
||||||
|
|
||||||
|
/* make sure shallows are read */
|
||||||
|
is_repository_shallow();
|
||||||
|
|
||||||
while (fgets(line, sizeof(line), stdin) != NULL) {
|
while (fgets(line, sizeof(line), stdin) != NULL) {
|
||||||
int len = strlen(line);
|
int len = strlen(line);
|
||||||
if (len && line[len - 1] == '\n')
|
if (len && line[len - 1] == '\n')
|
||||||
|
@ -2461,6 +2464,13 @@ static void get_object_list(int ac, const char **av)
|
||||||
write_bitmap_index = 0;
|
write_bitmap_index = 0;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (starts_with(line, "--shallow ")) {
|
||||||
|
unsigned char sha1[20];
|
||||||
|
if (get_sha1_hex(line + 10, sha1))
|
||||||
|
die("not an SHA-1 '%s'", line + 10);
|
||||||
|
register_shallow(sha1);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
die("not a rev '%s'", line);
|
die("not a rev '%s'", line);
|
||||||
}
|
}
|
||||||
if (handle_revision_arg(line, &revs, flags, REVARG_CANNOT_BE_FILENAME))
|
if (handle_revision_arg(line, &revs, flags, REVARG_CANNOT_BE_FILENAME))
|
||||||
|
|
|
@ -173,4 +173,45 @@ EOF
|
||||||
)
|
)
|
||||||
'
|
'
|
||||||
|
|
||||||
|
if test -n "$NO_CURL" -o -z "$GIT_TEST_HTTPD"; then
|
||||||
|
say 'skipping remaining tests, git built without http support'
|
||||||
|
test_done
|
||||||
|
fi
|
||||||
|
|
||||||
|
LIB_HTTPD_PORT=${LIB_HTTPD_PORT-'5537'}
|
||||||
|
. "$TEST_DIRECTORY"/lib-httpd.sh
|
||||||
|
start_httpd
|
||||||
|
|
||||||
|
test_expect_success 'clone http repository' '
|
||||||
|
git clone --bare --no-local shallow "$HTTPD_DOCUMENT_ROOT_PATH/repo.git" &&
|
||||||
|
git clone $HTTPD_URL/smart/repo.git clone &&
|
||||||
|
(
|
||||||
|
cd clone &&
|
||||||
|
git fsck &&
|
||||||
|
git log --format=%s origin/master >actual &&
|
||||||
|
cat <<EOF >expect &&
|
||||||
|
7
|
||||||
|
6
|
||||||
|
5
|
||||||
|
4
|
||||||
|
3
|
||||||
|
EOF
|
||||||
|
test_cmp expect actual
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success POSIXPERM,SANITY 'shallow fetch from a read-only repo' '
|
||||||
|
cp -R .git read-only.git &&
|
||||||
|
find read-only.git -print | xargs chmod -w &&
|
||||||
|
test_when_finished "find read-only.git -type d -print | xargs chmod +w" &&
|
||||||
|
git clone --no-local --depth=2 read-only.git from-read-only &&
|
||||||
|
git --git-dir=from-read-only/.git log --format=%s >actual &&
|
||||||
|
cat >expect <<EOF &&
|
||||||
|
add-1-back
|
||||||
|
4
|
||||||
|
EOF
|
||||||
|
test_cmp expect actual
|
||||||
|
'
|
||||||
|
|
||||||
|
stop_httpd
|
||||||
test_done
|
test_done
|
||||||
|
|
|
@ -70,6 +70,14 @@ static ssize_t send_client_data(int fd, const char *data, ssize_t sz)
|
||||||
return sz;
|
return sz;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int write_one_shallow(const struct commit_graft *graft, void *cb_data)
|
||||||
|
{
|
||||||
|
FILE *fp = cb_data;
|
||||||
|
if (graft->nr_parent == -1)
|
||||||
|
fprintf(fp, "--shallow %s\n", sha1_to_hex(graft->sha1));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static void create_pack_file(void)
|
static void create_pack_file(void)
|
||||||
{
|
{
|
||||||
struct child_process pack_objects;
|
struct child_process pack_objects;
|
||||||
|
@ -81,12 +89,10 @@ static void create_pack_file(void)
|
||||||
const char *argv[12];
|
const char *argv[12];
|
||||||
int i, arg = 0;
|
int i, arg = 0;
|
||||||
FILE *pipe_fd;
|
FILE *pipe_fd;
|
||||||
const char *shallow_file = NULL;
|
|
||||||
|
|
||||||
if (shallow_nr) {
|
if (shallow_nr) {
|
||||||
shallow_file = setup_temporary_shallow(NULL);
|
|
||||||
argv[arg++] = "--shallow-file";
|
argv[arg++] = "--shallow-file";
|
||||||
argv[arg++] = shallow_file;
|
argv[arg++] = "";
|
||||||
}
|
}
|
||||||
argv[arg++] = "pack-objects";
|
argv[arg++] = "pack-objects";
|
||||||
argv[arg++] = "--revs";
|
argv[arg++] = "--revs";
|
||||||
|
@ -114,6 +120,9 @@ static void create_pack_file(void)
|
||||||
|
|
||||||
pipe_fd = xfdopen(pack_objects.in, "w");
|
pipe_fd = xfdopen(pack_objects.in, "w");
|
||||||
|
|
||||||
|
if (shallow_nr)
|
||||||
|
for_each_commit_graft(write_one_shallow, pipe_fd);
|
||||||
|
|
||||||
for (i = 0; i < want_obj.nr; i++)
|
for (i = 0; i < want_obj.nr; i++)
|
||||||
fprintf(pipe_fd, "%s\n",
|
fprintf(pipe_fd, "%s\n",
|
||||||
sha1_to_hex(want_obj.objects[i].item->sha1));
|
sha1_to_hex(want_obj.objects[i].item->sha1));
|
||||||
|
|
Загрузка…
Ссылка в новой задаче