import UBI git-2.43.5-2.el8_10
This commit is contained in:
parent
697d6a3c5c
commit
61787178c4
115
SOURCES/git-2.43.0-slow-shallow-clones.patch
Normal file
115
SOURCES/git-2.43.0-slow-shallow-clones.patch
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
From 51441e6460b505c07b4a8a6deeaa7de4bf6e8e33 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Junio C Hamano <gitster@pobox.com>
|
||||||
|
Date: Fri, 3 May 2024 08:34:27 -0700
|
||||||
|
Subject: [PATCH] stop using HEAD for attributes in bare repository by default
|
||||||
|
|
||||||
|
With 23865355 (attr: read attributes from HEAD when bare repo,
|
||||||
|
2023-10-13), we started to use the HEAD tree as the default
|
||||||
|
attribute source in a bare repository. One argument for such a
|
||||||
|
behaviour is that it would make things like "git archive" run in
|
||||||
|
bare and non-bare repositories for the same commit consistent.
|
||||||
|
This changes was merged to Git 2.43 but without an explicit mention
|
||||||
|
in its release notes.
|
||||||
|
|
||||||
|
It turns out that this change destroys performance of shallowly
|
||||||
|
cloning from a bare repository. As the "server" installations are
|
||||||
|
expected to be mostly bare, and "git pack-objects", which is the
|
||||||
|
core of driving the other side of "git clone" and "git fetch" wants
|
||||||
|
to see if a path is set not to delta with blobs from other paths via
|
||||||
|
the attribute system, the change forces the server side to traverse
|
||||||
|
the tree of the HEAD commit needlessly to find if each and every
|
||||||
|
paths the objects it sends out has the attribute that controls the
|
||||||
|
deltification. Given that (1) most projects do not configure such
|
||||||
|
an attribute, and (2) it is dubious for the server side to honor
|
||||||
|
such an end-user supplied attribute anyway, this was a poor choice
|
||||||
|
of the default.
|
||||||
|
|
||||||
|
To mitigate the current situation, let's revert the change that uses
|
||||||
|
the tree of HEAD in a bare repository by default as the attribute
|
||||||
|
source. This will help most people who have been happy with the
|
||||||
|
behaviour of Git 2.42 and before.
|
||||||
|
|
||||||
|
Two things to note:
|
||||||
|
|
||||||
|
* If you are stuck with versions of Git 2.43 or newer, that is
|
||||||
|
older than the release this fix appears in, you can explicitly
|
||||||
|
set the attr.tree configuration variable to point at an empty
|
||||||
|
tree object, i.e.
|
||||||
|
|
||||||
|
$ git config attr.tree 4b825dc642cb6eb9a060e54bf8d69288fbee4904
|
||||||
|
|
||||||
|
* If you like the behaviour we are reverting, you can explicitly
|
||||||
|
set the attr.tree configuration variable to HEAD, i.e.
|
||||||
|
|
||||||
|
$ git config attr.tree HEAD
|
||||||
|
|
||||||
|
The right fix for this is to optimize the code paths that allow
|
||||||
|
accesses to attributes in tree objects, but that is a much more
|
||||||
|
involved change and is left as a longer-term project, outside the
|
||||||
|
scope of this "first step" fix.
|
||||||
|
|
||||||
|
Signed-off-by: Junio C Hamano <gitster@pobox.com>
|
||||||
|
---
|
||||||
|
attr.c | 7 -------
|
||||||
|
t/t0003-attributes.sh | 10 ++++++++--
|
||||||
|
t/t5001-archive-attr.sh | 3 ++-
|
||||||
|
3 files changed, 10 insertions(+), 10 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/attr.c b/attr.c
|
||||||
|
index e62876dfd3e9be..02ab8436266289 100644
|
||||||
|
--- a/attr.c
|
||||||
|
+++ b/attr.c
|
||||||
|
@@ -1213,13 +1213,6 @@ static void compute_default_attr_source(struct object_id *attr_source)
|
||||||
|
ignore_bad_attr_tree = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (!default_attr_source_tree_object_name &&
|
||||||
|
- startup_info->have_repository &&
|
||||||
|
- is_bare_repository()) {
|
||||||
|
- default_attr_source_tree_object_name = "HEAD";
|
||||||
|
- ignore_bad_attr_tree = 1;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
if (!default_attr_source_tree_object_name || !is_null_oid(attr_source))
|
||||||
|
return;
|
||||||
|
|
||||||
|
diff --git a/t/t0003-attributes.sh b/t/t0003-attributes.sh
|
||||||
|
index aee2298f01331a..5de46ddf67f7ff 100755
|
||||||
|
--- a/t/t0003-attributes.sh
|
||||||
|
+++ b/t/t0003-attributes.sh
|
||||||
|
@@ -384,13 +384,19 @@ test_expect_success 'bad attr source defaults to reading .gitattributes file' '
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
-test_expect_success 'bare repo defaults to reading .gitattributes from HEAD' '
|
||||||
|
+test_expect_success 'bare repo no longer defaults to reading .gitattributes from HEAD' '
|
||||||
|
test_when_finished rm -rf test bare_with_gitattribute &&
|
||||||
|
git init test &&
|
||||||
|
test_commit -C test gitattributes .gitattributes "f/path test=val" &&
|
||||||
|
git clone --bare test bare_with_gitattribute &&
|
||||||
|
- echo "f/path: test: val" >expect &&
|
||||||
|
+
|
||||||
|
+ echo "f/path: test: unspecified" >expect &&
|
||||||
|
git -C bare_with_gitattribute check-attr test -- f/path >actual &&
|
||||||
|
+ test_cmp expect actual &&
|
||||||
|
+
|
||||||
|
+ echo "f/path: test: val" >expect &&
|
||||||
|
+ git -C bare_with_gitattribute -c attr.tree=HEAD \
|
||||||
|
+ check-attr test -- f/path >actual &&
|
||||||
|
test_cmp expect actual
|
||||||
|
'
|
||||||
|
|
||||||
|
diff --git a/t/t5001-archive-attr.sh b/t/t5001-archive-attr.sh
|
||||||
|
index eaf959d8f63f15..7310774af5efea 100755
|
||||||
|
--- a/t/t5001-archive-attr.sh
|
||||||
|
+++ b/t/t5001-archive-attr.sh
|
||||||
|
@@ -133,7 +133,8 @@ test_expect_success 'git archive vs. bare' '
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success 'git archive with worktree attributes, bare' '
|
||||||
|
- (cd bare && git archive --worktree-attributes HEAD) >bare-worktree.tar &&
|
||||||
|
+ (cd bare &&
|
||||||
|
+ git -c attr.tree=HEAD archive --worktree-attributes HEAD) >bare-worktree.tar &&
|
||||||
|
(mkdir bare-worktree && cd bare-worktree && "$TAR" xf -) <bare-worktree.tar
|
||||||
|
'
|
||||||
|
|
@ -93,7 +93,7 @@
|
|||||||
|
|
||||||
Name: git
|
Name: git
|
||||||
Version: 2.43.5
|
Version: 2.43.5
|
||||||
Release: 1%{?rcrev}%{?dist}
|
Release: 2%{?rcrev}%{?dist}
|
||||||
Summary: Fast Version Control System
|
Summary: Fast Version Control System
|
||||||
License: GPLv2
|
License: GPLv2
|
||||||
URL: https://git-scm.com/
|
URL: https://git-scm.com/
|
||||||
@ -138,6 +138,11 @@ Patch4: 0002-t-lib-git-daemon-try-harder-to-find-a-port.patch
|
|||||||
# https://github.com/tmzullinger/git/commit/aa5105dc11
|
# https://github.com/tmzullinger/git/commit/aa5105dc11
|
||||||
Patch5: 0003-t-lib-git-svn-try-harder-to-find-a-port.patch
|
Patch5: 0003-t-lib-git-svn-try-harder-to-find-a-port.patch
|
||||||
|
|
||||||
|
# attr: read attributes from HEAD when bare repo
|
||||||
|
#
|
||||||
|
# https://github.com/git/git/commit/2386535511d1181afd4e892e2a866ffe5e1d7d21
|
||||||
|
Patch6: git-2.43.0-slow-shallow-clones.patch
|
||||||
|
|
||||||
%if %{with docs}
|
%if %{with docs}
|
||||||
# pod2man is needed to build Git.3pm
|
# pod2man is needed to build Git.3pm
|
||||||
BuildRequires: %{_bindir}/pod2man
|
BuildRequires: %{_bindir}/pod2man
|
||||||
@ -1099,13 +1104,14 @@ rmdir --ignore-fail-on-non-empty "$testdir"
|
|||||||
%{?with_docs:%{_pkgdocdir}/git-svn.html}
|
%{?with_docs:%{_pkgdocdir}/git-svn.html}
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
* Wed Jun 05 2024 Ondřej Pohořelský <opohorel@redhat.com> - 2.43.5-1
|
* Fri Nov 15 2024 Ondřej Pohořelský <opohorel@redhat.com> - 2.43.5-2
|
||||||
- Update to 2.43.5
|
- Sync version with the hotfix branch
|
||||||
- Related: RHEL-36399, RHEL-36411
|
- Related: RHEL-64984
|
||||||
|
|
||||||
* Wed May 15 2024 Ondřej Pohořelský <opohorel@redhat.com> - 2.43.4-1
|
* Thu Nov 14 2024 Ondřej Pohořelský <opohorel@redhat.com> - 2.43.0-2
|
||||||
- Update to 2.43.4
|
- Add fix for extremely slow shallow clones
|
||||||
- Resolves: RHEL-36399, RHEL-36411
|
- Repair t6300 on s390x
|
||||||
|
- Resolves: RHEL-64984
|
||||||
|
|
||||||
* Wed Dec 06 2023 Ondřej Pohořelský <opohorel@redhat.com> - 2.43.0-1
|
* Wed Dec 06 2023 Ondřej Pohořelský <opohorel@redhat.com> - 2.43.0-1
|
||||||
- Update to 2.43.0
|
- Update to 2.43.0
|
||||||
|
Loading…
Reference in New Issue
Block a user