 1f90a64891
			
		
	
	1f90a64891
	
	
	
		
			
			When fetching changes from a depot using a full client spec, there is no need to perform as many queries as there are top-level paths in the client spec. Instead we query all changes in chronological order, also getting rid of the need to sort the results and remove duplicates. Signed-off-by: Sam Hocevar <sam@hocevar.net> Signed-off-by: Luke Diamand <luke@diamand.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			146 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='git p4 fetching changes in multiple blocks'
 | |
| 
 | |
| . ./lib-git-p4.sh
 | |
| 
 | |
| test_expect_success 'start p4d' '
 | |
| 	start_p4d
 | |
| '
 | |
| 
 | |
| create_restricted_group() {
 | |
| 	p4 group -i <<-EOF
 | |
| 	Group: restricted
 | |
| 	MaxResults: 7
 | |
| 	MaxScanRows: 40
 | |
| 	Users: author
 | |
| 	EOF
 | |
| }
 | |
| 
 | |
| test_expect_success 'Create group with limited maxrows' '
 | |
| 	create_restricted_group
 | |
| '
 | |
| 
 | |
| test_expect_success 'Create a repo with many changes' '
 | |
| 	(
 | |
| 		client_view "//depot/included/... //client/included/..." \
 | |
| 			    "//depot/excluded/... //client/excluded/..." &&
 | |
| 		mkdir -p "$cli/included" "$cli/excluded" &&
 | |
| 		cd "$cli/included" &&
 | |
| 		>file.txt &&
 | |
| 		p4 add file.txt &&
 | |
| 		p4 submit -d "Add file.txt" &&
 | |
| 		for i in $(test_seq 0 5)
 | |
| 		do
 | |
| 			>outer$i.txt &&
 | |
| 			p4 add outer$i.txt &&
 | |
| 			p4 submit -d "Adding outer$i.txt" &&
 | |
| 			for j in $(test_seq 0 5)
 | |
| 			do
 | |
| 				p4 edit file.txt &&
 | |
| 				echo $i$j >file.txt &&
 | |
| 				p4 submit -d "Commit $i$j" || exit
 | |
| 			done || exit
 | |
| 		done
 | |
| 	)
 | |
| '
 | |
| 
 | |
| test_expect_success 'Default user cannot fetch changes' '
 | |
| 	! p4 changes -m 1 //depot/...
 | |
| '
 | |
| 
 | |
| test_expect_success 'Clone the repo' '
 | |
| 	git p4 clone --dest="$git" --changes-block-size=7 --verbose //depot/included@all
 | |
| '
 | |
| 
 | |
| test_expect_success 'All files are present' '
 | |
| 	echo file.txt >expected &&
 | |
| 	test_write_lines outer0.txt outer1.txt outer2.txt outer3.txt outer4.txt >>expected &&
 | |
| 	test_write_lines outer5.txt >>expected &&
 | |
| 	ls "$git" >current &&
 | |
| 	test_cmp expected current
 | |
| '
 | |
| 
 | |
| test_expect_success 'file.txt is correct' '
 | |
| 	echo 55 >expected &&
 | |
| 	test_cmp expected "$git/file.txt"
 | |
| '
 | |
| 
 | |
| test_expect_success 'Correct number of commits' '
 | |
| 	(cd "$git" && git log --oneline) >log &&
 | |
| 	wc -l log &&
 | |
| 	test_line_count = 43 log
 | |
| '
 | |
| 
 | |
| test_expect_success 'Previous version of file.txt is correct' '
 | |
| 	(cd "$git" && git checkout HEAD^^) &&
 | |
| 	echo 53 >expected &&
 | |
| 	test_cmp expected "$git/file.txt"
 | |
| '
 | |
| 
 | |
| # Test git-p4 sync, with some files outside the client specification.
 | |
| 
 | |
| p4_add_file() {
 | |
| 	(cd "$cli" &&
 | |
| 		>$1 &&
 | |
| 		p4 add $1 &&
 | |
| 		p4 submit -d "Added file $1" $1
 | |
| 	)
 | |
| }
 | |
| 
 | |
| test_expect_success 'Add some more files' '
 | |
| 	for i in $(test_seq 0 10)
 | |
| 	do
 | |
| 		p4_add_file "included/x$i" &&
 | |
| 		p4_add_file "excluded/x$i"
 | |
| 	done &&
 | |
| 	for i in $(test_seq 0 10)
 | |
| 	do
 | |
| 		p4_add_file "excluded/y$i"
 | |
| 	done
 | |
| '
 | |
| 
 | |
| # This should pick up the 10 new files in "included", but not be confused
 | |
| # by the additional files in "excluded"
 | |
| test_expect_success 'Syncing files' '
 | |
| 	(
 | |
| 		cd "$git" &&
 | |
| 		git p4 sync --changes-block-size=7 &&
 | |
| 		git checkout p4/master &&
 | |
| 		ls -l x* > log &&
 | |
| 		test_line_count = 11 log
 | |
| 	)
 | |
| '
 | |
| 
 | |
| # Handling of multiple depot paths:
 | |
| #    git p4 clone //depot/pathA //depot/pathB
 | |
| #
 | |
| test_expect_success 'Create a repo with multiple depot paths' '
 | |
| 	client_view "//depot/pathA/... //client/pathA/..." \
 | |
| 		    "//depot/pathB/... //client/pathB/..." &&
 | |
| 	mkdir -p "$cli/pathA" "$cli/pathB" &&
 | |
| 	for p in pathA pathB
 | |
| 	do
 | |
| 		for i in $(test_seq 1 10)
 | |
| 		do
 | |
| 			p4_add_file "$p/file$p$i"
 | |
| 		done
 | |
| 	done
 | |
| '
 | |
| 
 | |
| test_expect_success 'Clone repo with multiple depot paths' '
 | |
| 	(
 | |
| 		cd "$git" &&
 | |
| 		git p4 clone --changes-block-size=4 //depot/pathA@all //depot/pathB@all \
 | |
| 			--destination=dest &&
 | |
| 		ls -1 dest >log &&
 | |
| 		test_line_count = 20 log
 | |
| 	)
 | |
| '
 | |
| 
 | |
| test_expect_success 'kill p4d' '
 | |
| 	kill_p4d
 | |
| '
 | |
| 
 | |
| test_done
 |