diff options
| author | Junio C Hamano <gitster@pobox.com> | 2020-08-04 13:53:58 -0700 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2020-08-04 13:53:58 -0700 |
| commit | 5b137e84410ff7c83b854cb7b9e933c4d3673555 (patch) | |
| tree | 3ae3acf1f19afaba2c07a35fbd9992f300a00720 | |
| parent | Merge branch 'jt/pack-objects-prefetch-in-batch' (diff) | |
| parent | sha1-file: make pretend_object_file() not prefetch (diff) | |
| download | git-5b137e84410ff7c83b854cb7b9e933c4d3673555.tar.gz git-5b137e84410ff7c83b854cb7b9e933c4d3673555.zip | |
Merge branch 'jt/pretend-object-never-come-from-elsewhere'
The pretend-object mechanism checks if the given object already
exists in the object store before deciding to keep the data
in-core, but the check would have triggered lazy fetching of such
an object from a promissor remote.
* jt/pretend-object-never-come-from-elsewhere:
sha1-file: make pretend_object_file() not prefetch
| -rw-r--r-- | sha1-file.c | 3 | ||||
| -rwxr-xr-x | t/t8002-blame.sh | 11 |
2 files changed, 13 insertions, 1 deletions
diff --git a/sha1-file.c b/sha1-file.c index ccd34dd9e8..45fdb8415c 100644 --- a/sha1-file.c +++ b/sha1-file.c @@ -1600,7 +1600,8 @@ int pretend_object_file(void *buf, unsigned long len, enum object_type type, struct cached_object *co; hash_object_file(the_hash_algo, buf, len, type_name(type), oid); - if (has_object_file(oid) || find_cached_object(oid)) + if (has_object_file_with_flags(oid, OBJECT_INFO_QUICK | OBJECT_INFO_SKIP_FETCH_OBJECT) || + find_cached_object(oid)) return 0; ALLOC_GROW(cached_objects, cached_object_nr + 1, cached_object_alloc); co = &cached_objects[cached_object_nr++]; diff --git a/t/t8002-blame.sh b/t/t8002-blame.sh index eea048e52c..2ed6aaae35 100755 --- a/t/t8002-blame.sh +++ b/t/t8002-blame.sh @@ -122,4 +122,15 @@ test_expect_success '--exclude-promisor-objects does not BUG-crash' ' test_must_fail git blame --exclude-promisor-objects one ' +test_expect_success 'blame with uncommitted edits in partial clone does not crash' ' + git init server && + echo foo >server/file.txt && + git -C server add file.txt && + git -C server commit -m file && + + git clone --filter=blob:none "file://$(pwd)/server" client && + echo bar >>client/file.txt && + git -C client blame file.txt +' + test_done |
