On Fri, Oct 29 2021, Phillip Wood wrote: > Hi Junio > > On 28/10/2021 22:32, Junio C Hamano wrote: >> "Phillip Wood via GitGitGadget" <gitgitgadget@xxxxxxxxx> writes: >> >>> From: Phillip Wood <phillip.wood@xxxxxxxxxxxxx> >>> >>> Add some tests so we can monitor changes to the performance of the >>> move detection code. The tests record the performance of a single >>> large diff and a sequence of smaller diffs. >> "A single large diff" meaning...? > > The diff of two commits that are far apart in the history so have lots > of changes between them > >>> +if ! git rev-parse --verify v2.29.0^{commit} >/dev/null >>> +then >>> + skip_all='skipping because tag v2.29.0 was not found' >>> + test_done >>> +fi >> Hmph. So this is designed only to be run in a clone of git.git with >> that tag (and a bit of history, at least to v2.28.0 and 1000 commits)? >> I am asking primarily because this seems to be the first instance of >> a test that hardcodes the dependency on our history, instead of >> allowing the tester to use their favourite history by using the >> GIT_PERF_LARGE_REPO and GIT_PERF_REPO environment variables. > > p3404-rebase-interactive does the same thing. The aim is to have a > repeatable test rather than just using whatever commit HEAD happens to > be pointing at when the test is run as the starting point, if you have > any ideas for doing that another way I'm happy to change it. I don't know if it's worth it here, but the following would work: 1. List all tags in the repository, sorted in reverse order, so e.g.: git tag -l 'v*.0' --sort=version:refname (The glob can be configurable as an env variable, or we could fall back) 2. Go down that list and find the first pair that matches some limit, I think say the first "major" release with 500 commits would qualify 3. Make it a GIT_PERF_LARGE_REPO test We've got some perf tests that do similar things. I think you'd find that with something like this you should able to hand the perf test a path to git.git, or linux.git, and probably any "major" repository" as long as it follows a common "we tag our releases at some interval" pattern. Or perhaps more simply: 1. Note the number of commits in the history, per "git rev-list HEAD | wc -l" 2. 2. Then round that down to the nearest 10^x, so for a 250k commit repository round down to 100k and diff say the 90k..100kth commits, for git.git which has 60k that would be 10k, and the diff is commits 9k..10k.. It means you'll get a "bump" eventually when say git.git crosses 100k commits, but it will prorably be stable for any measurement anyone cares to do, and means that you can get "realistic" measurements for diffing a big chuck on of history from anything from a tiny repository with >=10 commits, to something truly gargantuan where you'd end up diffing say 900k..1m.