101 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Bash
		
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Bash
		
	
	
| # Helper functions for testing bitmap performance; see p5310.
 | |
| 
 | |
| test_full_bitmap () {
 | |
| 	test_perf 'simulated clone' '
 | |
| 		git pack-objects --stdout --all </dev/null >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'simulated fetch' '
 | |
| 		have=$(git rev-list HEAD~100 -1) &&
 | |
| 		{
 | |
| 			echo HEAD &&
 | |
| 			echo ^$have
 | |
| 		} | git pack-objects --revs --stdout >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'pack to file (bitmap)' '
 | |
| 		git pack-objects --use-bitmap-index --all pack1b </dev/null >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'rev-list (commits)' '
 | |
| 		git rev-list --all --use-bitmap-index >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'rev-list (objects)' '
 | |
| 		git rev-list --all --use-bitmap-index --objects >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'rev-list with tag negated via --not --all (objects)' '
 | |
| 		git rev-list perf-tag --not --all --use-bitmap-index --objects >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'rev-list with negative tag (objects)' '
 | |
| 		git rev-list HEAD --not perf-tag --use-bitmap-index --objects >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'rev-list count with blob:none' '
 | |
| 		git rev-list --use-bitmap-index --count --objects --all \
 | |
| 			--filter=blob:none >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'rev-list count with blob:limit=1k' '
 | |
| 		git rev-list --use-bitmap-index --count --objects --all \
 | |
| 			--filter=blob:limit=1k >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'rev-list count with tree:0' '
 | |
| 		git rev-list --use-bitmap-index --count --objects --all \
 | |
| 			--filter=tree:0 >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'simulated partial clone' '
 | |
| 		git pack-objects --stdout --all --filter=blob:none </dev/null >/dev/null
 | |
| 	'
 | |
| }
 | |
| 
 | |
| test_partial_bitmap () {
 | |
| 	test_perf 'clone (partial bitmap)' '
 | |
| 		git pack-objects --stdout --all </dev/null >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'pack to file (partial bitmap)' '
 | |
| 		git pack-objects --use-bitmap-index --all pack2b </dev/null >/dev/null
 | |
| 	'
 | |
| 
 | |
| 	test_perf 'rev-list with tree filter (partial bitmap)' '
 | |
| 		git rev-list --use-bitmap-index --count --objects --all \
 | |
| 			--filter=tree:0 >/dev/null
 | |
| 	'
 | |
| }
 | |
| 
 | |
| test_pack_bitmap () {
 | |
| 	test_perf "repack to disk" '
 | |
| 		git repack -ad
 | |
| 	'
 | |
| 
 | |
| 	test_full_bitmap
 | |
| 
 | |
| 	test_expect_success "create partial bitmap state" '
 | |
| 		# pick a commit to represent the repo tip in the past
 | |
| 		cutoff=$(git rev-list HEAD~100 -1) &&
 | |
| 		orig_tip=$(git rev-parse HEAD) &&
 | |
| 
 | |
| 		# now kill off all of the refs and pretend we had
 | |
| 		# just the one tip
 | |
| 		rm -rf .git/logs .git/refs/* .git/packed-refs &&
 | |
| 		git update-ref HEAD $cutoff &&
 | |
| 
 | |
| 		# and then repack, which will leave us with a nice
 | |
| 		# big bitmap pack of the "old" history, and all of
 | |
| 		# the new history will be loose, as if it had been pushed
 | |
| 		# up incrementally and exploded via unpack-objects
 | |
| 		git repack -Ad &&
 | |
| 
 | |
| 		# and now restore our original tip, as if the pushes
 | |
| 		# had happened
 | |
| 		git update-ref HEAD $orig_tip
 | |
| 	'
 | |
| 
 | |
| 	test_partial_bitmap
 | |
| }
 |