 fba95dad6a
			
		
	
	fba95dad6a
	
	
	
		
			
			There are a bunch of tests which do not have any leaks: - t0411: Introduced via5c5a4a1c05(t0411: add tests for cloning from partial repo, 2024-01-28), passes since its inception. - t0610: Introduced via57db2a094d(refs: introduce reftable backend, 2024-02-07), passes since its inception. - t2405: Passes since6741e917de(repository: avoid leaking `fsmonitor` data, 2024-04-12). - t7423: Introduced viab20c10fd9b(t7423: add tests for symlinked submodule directories, 2024-01-28), passes sincee8d0608944(submodule: require the submodule path to contain directories only, 2024-03-26). The fix is not obviously related, but probably works because we now die early in many code paths. - t9xxx: All of these are exercising CVS-related tooling and pass since at least Git v2.40. It's likely that these pass for a long time already, but nobody ever noticed because Git developers do not tend to have CVS on their machines. Mark all of these tests as passing. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			169 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			169 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| test_description='git cvsimport basic tests'
 | |
| GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
 | |
| export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
 | |
| 
 | |
| TEST_PASSES_SANITIZE_LEAK=true
 | |
| . ./lib-cvs.sh
 | |
| 
 | |
| if ! test_have_prereq NOT_ROOT; then
 | |
| 	skip_all='When cvs is compiled with CVS_BADROOT commits as root fail'
 | |
| 	test_done
 | |
| fi
 | |
| 
 | |
| test_expect_success PERL 'setup cvsroot environment' '
 | |
| 	CVSROOT=$(pwd)/cvsroot &&
 | |
| 	export CVSROOT
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'setup cvsroot' '$CVS init'
 | |
| 
 | |
| test_expect_success PERL 'setup a cvs module' '
 | |
| 
 | |
| 	mkdir "$CVSROOT/module" &&
 | |
| 	$CVS co -d module-cvs module &&
 | |
| 	(cd module-cvs &&
 | |
| 	cat <<EOF >o_fortuna &&
 | |
| O Fortuna
 | |
| velut luna
 | |
| statu variabilis,
 | |
| 
 | |
| semper crescis
 | |
| aut decrescis;
 | |
| vita detestabilis
 | |
| 
 | |
| nunc obdurat
 | |
| et tunc curat
 | |
| ludo mentis aciem,
 | |
| 
 | |
| egestatem,
 | |
| potestatem
 | |
| dissolvit ut glaciem.
 | |
| EOF
 | |
| 	$CVS add o_fortuna &&
 | |
| 	cat <<EOF >message &&
 | |
| add "O Fortuna" lyrics
 | |
| 
 | |
| These public domain lyrics make an excellent sample text.
 | |
| EOF
 | |
| 	$CVS commit -F message
 | |
| 	)
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'import a trivial module' '
 | |
| 
 | |
| 	git cvsimport -a -R -z 0 -C module-git module &&
 | |
| 	test_cmp module-cvs/o_fortuna module-git/o_fortuna
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'pack refs' '(cd module-git && git gc)'
 | |
| 
 | |
| test_expect_success PERL 'initial import has correct .git/cvs-revisions' '
 | |
| 
 | |
| 	(cd module-git &&
 | |
| 	 git log --format="o_fortuna 1.1 %H" -1) > expected &&
 | |
| 	test_cmp expected module-git/.git/cvs-revisions
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'update cvs module' '
 | |
| 	(cd module-cvs &&
 | |
| 	cat <<EOF >o_fortuna &&
 | |
| O Fortune,
 | |
| like the moon
 | |
| you are changeable,
 | |
| 
 | |
| ever waxing
 | |
| and waning;
 | |
| hateful life
 | |
| 
 | |
| first oppresses
 | |
| and then soothes
 | |
| as fancy takes it;
 | |
| 
 | |
| poverty
 | |
| and power
 | |
| it melts them like ice.
 | |
| EOF
 | |
| 	cat <<EOF >message &&
 | |
| translate to English
 | |
| 
 | |
| My Latin is terrible.
 | |
| EOF
 | |
| 	$CVS commit -F message
 | |
| 	)
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'update git module' '
 | |
| 
 | |
| 	(cd module-git &&
 | |
| 	git config cvsimport.trackRevisions true &&
 | |
| 	git cvsimport -a -z 0 module &&
 | |
| 	git merge origin
 | |
| 	) &&
 | |
| 	test_cmp module-cvs/o_fortuna module-git/o_fortuna
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'update has correct .git/cvs-revisions' '
 | |
| 
 | |
| 	(cd module-git &&
 | |
| 	 git log --format="o_fortuna 1.1 %H" -1 HEAD^ &&
 | |
| 	 git log --format="o_fortuna 1.2 %H" -1 HEAD) > expected &&
 | |
| 	test_cmp expected module-git/.git/cvs-revisions
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'update cvs module' '
 | |
| 
 | |
| 	(cd module-cvs &&
 | |
| 		echo 1 >tick &&
 | |
| 		$CVS add tick &&
 | |
| 		$CVS commit -m 1
 | |
| 	)
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'cvsimport.module config works' '
 | |
| 
 | |
| 	(cd module-git &&
 | |
| 		git config cvsimport.module module &&
 | |
| 		git config cvsimport.trackRevisions true &&
 | |
| 		git cvsimport -a -z0 &&
 | |
| 		git merge origin
 | |
| 	) &&
 | |
| 	test_cmp module-cvs/tick module-git/tick
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'second update has correct .git/cvs-revisions' '
 | |
| 
 | |
| 	(cd module-git &&
 | |
| 	 git log --format="o_fortuna 1.1 %H" -1 HEAD^^ &&
 | |
| 	 git log --format="o_fortuna 1.2 %H" -1 HEAD^ &&
 | |
| 	 git log --format="tick 1.1 %H" -1 HEAD) > expected &&
 | |
| 	test_cmp expected module-git/.git/cvs-revisions
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'import from a CVS working tree' '
 | |
| 
 | |
| 	$CVS co -d import-from-wt module &&
 | |
| 	(cd import-from-wt &&
 | |
| 		git config cvsimport.trackRevisions false &&
 | |
| 		git cvsimport -a -z0 &&
 | |
| 		echo 1 >expect &&
 | |
| 		git log -1 --pretty=format:%s%n >actual &&
 | |
| 		test_cmp expect actual
 | |
| 	)
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'no .git/cvs-revisions created by default' '
 | |
| 
 | |
| 	! test -e import-from-wt/.git/cvs-revisions
 | |
| 
 | |
| '
 | |
| 
 | |
| test_expect_success PERL 'test entire HEAD' 'test_cmp_branch_tree main'
 | |
| 
 | |
| test_done
 |