mirror of
				https://github.com/mnauw/git-remote-hg.git
				synced 2025-10-26 06:06:06 +01:00 
			
		
		
		
	t: rename directory
This commit is contained in:
		
							
								
								
									
										3
									
								
								t/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								t/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| test-results/ | ||||
| trash directory.*/ | ||||
| .prove | ||||
							
								
								
									
										19
									
								
								t/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								t/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| RM ?= rm -f | ||||
|  | ||||
| T = $(wildcard *.t) | ||||
| SHARNESS_TEST_DIRECTORY := $(CURDIR) | ||||
|  | ||||
| export SHARNESS_TEST_DIRECTORY | ||||
|  | ||||
| all: test | ||||
|  | ||||
| test: $(T) | ||||
| 	$(MAKE) clean | ||||
|  | ||||
| $(T): | ||||
| 	./$@ $(TEST_OPTS) | ||||
|  | ||||
| clean: | ||||
| 	$(RM) -r 'trash directory'.* test-results | ||||
|  | ||||
| .PHONY: all test $(T) clean | ||||
							
								
								
									
										268
									
								
								t/bidi.t
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										268
									
								
								t/bidi.t
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,268 @@ | ||||
| #!/bin/bash | ||||
| # | ||||
| # Copyright (c) 2012 Felipe Contreras | ||||
| # | ||||
| # Base commands from hg-git tests: | ||||
| # https://bitbucket.org/durin42/hg-git/src | ||||
| # | ||||
|  | ||||
| test_description='Test bidirectionality of remote-hg' | ||||
|  | ||||
| . ./test-lib.sh | ||||
|  | ||||
| # clone to a git repo | ||||
| git_clone () { | ||||
| 	git clone -q "hg::$1" $2 | ||||
| } | ||||
|  | ||||
| # clone to an hg repo | ||||
| hg_clone () { | ||||
| 	( | ||||
| 	hg init $2 && | ||||
| 	cd $1 && | ||||
| 	git push -q "hg::../$2" 'refs/tags/*:refs/tags/*' 'refs/heads/*:refs/heads/*' | ||||
| 	) && | ||||
|  | ||||
| 	(cd $2 && hg -q update) | ||||
| } | ||||
|  | ||||
| # push an hg repo | ||||
| hg_push () { | ||||
| 	( | ||||
| 	cd $2 | ||||
| 	git checkout -q -b tmp && | ||||
| 	git fetch -q "hg::../$1" 'refs/tags/*:refs/tags/*' 'refs/heads/*:refs/heads/*' && | ||||
| 	git checkout -q @{-1} && | ||||
| 	git branch -q -D tmp 2> /dev/null || true | ||||
| 	) | ||||
| } | ||||
|  | ||||
| hg_log () { | ||||
| 	hg -R $1 log --graph --debug | ||||
| } | ||||
|  | ||||
| setup () { | ||||
| 	cat > "$HOME"/.hgrc <<-EOF && | ||||
| 	[ui] | ||||
| 	username = A U Thor <author@example.com> | ||||
| 	[defaults] | ||||
| 	backout = -d "0 0" | ||||
| 	commit = -d "0 0" | ||||
| 	debugrawcommit = -d "0 0" | ||||
| 	tag = -d "0 0" | ||||
| 	[extensions]" | ||||
| 	graphlog = | ||||
| 	EOF | ||||
| 	git config --global remote-hg.hg-git-compat true | ||||
| 	git config --global remote-hg.track-branches true | ||||
|  | ||||
| 	HGEDITOR=/usr/bin/true | ||||
| 	GIT_AUTHOR_DATE="2007-01-01 00:00:00 +0230" | ||||
| 	GIT_COMMITTER_DATE="$GIT_AUTHOR_DATE" | ||||
| 	export HGEDITOR GIT_AUTHOR_DATE GIT_COMMITTER_DATE | ||||
| } | ||||
|  | ||||
| setup | ||||
|  | ||||
| test_expect_success 'encoding' ' | ||||
| 	test_when_finished "rm -rf gitrepo* hgrepo*" && | ||||
|  | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
|  | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add älphà" && | ||||
|  | ||||
| 	GIT_AUTHOR_NAME="tést èncödîng" && | ||||
| 	export GIT_AUTHOR_NAME && | ||||
| 	echo beta > beta && | ||||
| 	git add beta && | ||||
| 	git commit -m "add beta" && | ||||
|  | ||||
| 	echo gamma > gamma && | ||||
| 	git add gamma && | ||||
| 	git commit -m "add gämmâ" && | ||||
|  | ||||
| 	: TODO git config i18n.commitencoding latin-1 && | ||||
| 	echo delta > delta && | ||||
| 	git add delta && | ||||
| 	git commit -m "add déltà" | ||||
| 	) && | ||||
|  | ||||
| 	hg_clone gitrepo hgrepo && | ||||
| 	git_clone hgrepo gitrepo2 && | ||||
| 	hg_clone gitrepo2 hgrepo2 && | ||||
|  | ||||
| 	HGENCODING=utf-8 hg_log hgrepo > expected && | ||||
| 	HGENCODING=utf-8 hg_log hgrepo2 > actual && | ||||
|  | ||||
| 	test_cmp expected actual | ||||
| ' | ||||
|  | ||||
| test_expect_success 'file removal' ' | ||||
| 	test_when_finished "rm -rf gitrepo* hgrepo*" && | ||||
|  | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add alpha" && | ||||
| 	echo beta > beta && | ||||
| 	git add beta && | ||||
| 	git commit -m "add beta" | ||||
| 	mkdir foo && | ||||
| 	echo blah > foo/bar && | ||||
| 	git add foo && | ||||
| 	git commit -m "add foo" && | ||||
| 	git rm alpha && | ||||
| 	git commit -m "remove alpha" && | ||||
| 	git rm foo/bar && | ||||
| 	git commit -m "remove foo/bar" | ||||
| 	) && | ||||
|  | ||||
| 	hg_clone gitrepo hgrepo && | ||||
| 	git_clone hgrepo gitrepo2 && | ||||
| 	hg_clone gitrepo2 hgrepo2 && | ||||
|  | ||||
| 	hg_log hgrepo > expected && | ||||
| 	hg_log hgrepo2 > actual && | ||||
|  | ||||
| 	test_cmp expected actual | ||||
| ' | ||||
|  | ||||
| test_expect_success 'git tags' ' | ||||
| 	test_when_finished "rm -rf gitrepo* hgrepo*" && | ||||
|  | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
| 	git config receive.denyCurrentBranch ignore && | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add alpha" && | ||||
| 	git tag alpha && | ||||
|  | ||||
| 	echo beta > beta && | ||||
| 	git add beta && | ||||
| 	git commit -m "add beta" && | ||||
| 	git tag -a -m "added tag beta" beta | ||||
| 	) && | ||||
|  | ||||
| 	hg_clone gitrepo hgrepo && | ||||
| 	git_clone hgrepo gitrepo2 && | ||||
| 	hg_clone gitrepo2 hgrepo2 && | ||||
|  | ||||
| 	hg_log hgrepo > expected && | ||||
| 	hg_log hgrepo2 > actual && | ||||
|  | ||||
| 	test_cmp expected actual | ||||
| ' | ||||
|  | ||||
| test_expect_success 'hg branch' ' | ||||
| 	test_when_finished "rm -rf gitrepo* hgrepo*" && | ||||
|  | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
|  | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -q -m "add alpha" && | ||||
| 	git checkout -q -b not-master | ||||
| 	) && | ||||
|  | ||||
| 	( | ||||
| 	hg_clone gitrepo hgrepo && | ||||
|  | ||||
| 	cd hgrepo && | ||||
| 	hg -q co default && | ||||
| 	hg mv alpha beta && | ||||
| 	hg -q commit -m "rename alpha to beta" && | ||||
| 	hg branch gamma | grep -v "permanent and global" && | ||||
| 	hg -q commit -m "started branch gamma" | ||||
| 	) && | ||||
|  | ||||
| 	hg_push hgrepo gitrepo && | ||||
| 	hg_clone gitrepo hgrepo2 && | ||||
|  | ||||
| 	: Back to the common revision && | ||||
| 	(cd hgrepo && hg checkout default) && | ||||
|  | ||||
| 	hg_log hgrepo > expected && | ||||
| 	hg_log hgrepo2 > actual && | ||||
|  | ||||
| 	test_cmp expected actual | ||||
| ' | ||||
|  | ||||
| test_expect_success 'hg tags' ' | ||||
| 	test_when_finished "rm -rf gitrepo* hgrepo*" && | ||||
|  | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
|  | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add alpha" && | ||||
| 	git checkout -q -b not-master | ||||
| 	) && | ||||
|  | ||||
| 	( | ||||
| 	hg_clone gitrepo hgrepo && | ||||
|  | ||||
| 	cd hgrepo && | ||||
| 	hg co default && | ||||
| 	hg tag alpha | ||||
| 	) && | ||||
|  | ||||
| 	hg_push hgrepo gitrepo && | ||||
| 	hg_clone gitrepo hgrepo2 && | ||||
|  | ||||
| 	hg_log hgrepo > expected && | ||||
| 	hg_log hgrepo2 > actual && | ||||
|  | ||||
| 	test_cmp expected actual | ||||
| ' | ||||
|  | ||||
| test_expect_success 'test timezones' ' | ||||
| 	test_when_finished "rm -rf gitrepo* hgrepo*" && | ||||
|  | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
|  | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add alpha" --date="2007-01-01 00:00:00 +0000" && | ||||
|  | ||||
| 	echo beta > beta && | ||||
| 	git add beta && | ||||
| 	git commit -m "add beta" --date="2007-01-01 00:00:00 +0100" && | ||||
|  | ||||
| 	echo gamma > gamma && | ||||
| 	git add gamma && | ||||
| 	git commit -m "add gamma" --date="2007-01-01 00:00:00 -0100" && | ||||
|  | ||||
| 	echo delta > delta && | ||||
| 	git add delta && | ||||
| 	git commit -m "add delta" --date="2007-01-01 00:00:00 +0130" && | ||||
|  | ||||
| 	echo epsilon > epsilon && | ||||
| 	git add epsilon && | ||||
| 	git commit -m "add epsilon" --date="2007-01-01 00:00:00 -0130" | ||||
| 	) && | ||||
|  | ||||
| 	hg_clone gitrepo hgrepo && | ||||
| 	git_clone hgrepo gitrepo2 && | ||||
| 	hg_clone gitrepo2 hgrepo2 && | ||||
|  | ||||
| 	hg_log hgrepo > expected && | ||||
| 	hg_log hgrepo2 > actual && | ||||
|  | ||||
| 	test_cmp expected actual | ||||
| ' | ||||
|  | ||||
| test_done | ||||
							
								
								
									
										60
									
								
								t/expected/converged merge/git-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								t/expected/converged merge/git-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | ||||
| blob | ||||
| mark :1 | ||||
| data 2 | ||||
| A | ||||
|  | ||||
| reset refs/heads/master | ||||
| commit refs/heads/master | ||||
| mark :2 | ||||
| author A U Thor <author@example.com> 0 +0000 | ||||
| committer A U Thor <author@example.com> 0 +0000 | ||||
| data 7 | ||||
| origin | ||||
| M 100644 :1 afile | ||||
|  | ||||
| blob | ||||
| mark :3 | ||||
| data 2 | ||||
| C | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :4 | ||||
| author A U Thor <author@example.com> 3 +0000 | ||||
| committer A U Thor <author@example.com> 3 +0000 | ||||
| data 5 | ||||
| A->C | ||||
| from :2 | ||||
| M 100644 :3 afile | ||||
|  | ||||
| blob | ||||
| mark :5 | ||||
| data 2 | ||||
| B | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :6 | ||||
| author A U Thor <author@example.com> 1 +0000 | ||||
| committer A U Thor <author@example.com> 1 +0000 | ||||
| data 5 | ||||
| A->B | ||||
| from :2 | ||||
| M 100644 :5 afile | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :7 | ||||
| author A U Thor <author@example.com> 2 +0000 | ||||
| committer A U Thor <author@example.com> 2 +0000 | ||||
| data 5 | ||||
| B->C | ||||
| from :6 | ||||
| M 100644 :3 afile | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :8 | ||||
| author A U Thor <author@example.com> 4 +0000 | ||||
| committer A U Thor <author@example.com> 4 +0000 | ||||
| data 6 | ||||
| merge | ||||
| from :4 | ||||
| merge :7 | ||||
|  | ||||
							
								
								
									
										67
									
								
								t/expected/converged merge/hg-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								t/expected/converged merge/hg-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | ||||
| changeset:   9a6668f453c3003b71e11bb8d7572af57a7ce891 | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    331ac2e605f2e6092ccb3802244a65b71f3be726 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| origin | ||||
|  | ||||
|  | ||||
| changeset:   ead35d346ecb18ce9d9d54604ff62b41caa196ce | ||||
| phase:       draft | ||||
| parent:      9a6668f453c3003b71e11bb8d7572af57a7ce891 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    894f8ad9a84f743d52747963d0b9f4e9cf37d489 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:01 1970 +0000 | ||||
| files:       afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| A->B | ||||
|  | ||||
|  | ||||
| changeset:   541c7bc8b2d01c8bf71b2298d17edcda120e49bf | ||||
| phase:       draft | ||||
| parent:      ead35d346ecb18ce9d9d54604ff62b41caa196ce | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    04dae4001cb1fb2384111589720617c4b742044c | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:02 1970 +0000 | ||||
| files:       afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| B->C | ||||
|  | ||||
|  | ||||
| changeset:   5694aadcd7171ecb9768b13e29d027e22a360d44 | ||||
| phase:       draft | ||||
| parent:      9a6668f453c3003b71e11bb8d7572af57a7ce891 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    6efc6bb8e097947aa212887bdb01fb89dfa3de13 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:03 1970 +0000 | ||||
| files:       afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| A->C | ||||
|  | ||||
|  | ||||
| changeset:   9ee75b4362cc15f9110d6538b2f1c9f0cf14825a | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      5694aadcd7171ecb9768b13e29d027e22a360d44 | ||||
| parent:      541c7bc8b2d01c8bf71b2298d17edcda120e49bf | ||||
| manifest:    eb9f4687448653e876d787cd6f2e59140680ff09 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:04 1970 +0000 | ||||
| files:       afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| merge | ||||
|  | ||||
|  | ||||
							
								
								
									
										56
									
								
								t/expected/encoding/git-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								t/expected/encoding/git-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | ||||
| blob | ||||
| mark :1 | ||||
| data 6 | ||||
| alpha | ||||
|  | ||||
| reset refs/heads/master | ||||
| commit refs/heads/master | ||||
| mark :2 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 12 | ||||
| add älphà | ||||
| M 100644 :1 alpha | ||||
|  | ||||
| blob | ||||
| mark :3 | ||||
| data 5 | ||||
| beta | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :4 | ||||
| author tést èncödîng <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 9 | ||||
| add beta | ||||
| from :2 | ||||
| M 100644 :3 beta | ||||
|  | ||||
| blob | ||||
| mark :5 | ||||
| data 6 | ||||
| gamma | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :6 | ||||
| author tést èncödîng <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 12 | ||||
| add gämmâ | ||||
| from :4 | ||||
| M 100644 :5 gamma | ||||
|  | ||||
| blob | ||||
| mark :7 | ||||
| data 6 | ||||
| delta | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :8 | ||||
| author tést èncödîng <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 12 | ||||
| add déltà | ||||
| from :6 | ||||
| M 100644 :7 delta | ||||
|  | ||||
							
								
								
									
										58
									
								
								t/expected/encoding/hg-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								t/expected/encoding/hg-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| changeset:   6674f1c866b5c428db4acde16404c14077889646 | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      7e9fd3fd2f75d7de4bf3d77c47f192a51927ac28 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    ea49f93388380ead5601c8fcbfa187516e7c2ed8 | ||||
| user:        tést èncödîng <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      delta | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add déltà | ||||
|  | ||||
|  | ||||
| changeset:   7e9fd3fd2f75d7de4bf3d77c47f192a51927ac28 | ||||
| phase:       draft | ||||
| parent:      99c5adad03b9a9935e181f4be91ff7693a790110 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    f580e7da3673c137370da2b931a1dee83590d7b4 | ||||
| user:        tést èncödîng <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      gamma | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add gämmâ | ||||
|  | ||||
|  | ||||
| changeset:   99c5adad03b9a9935e181f4be91ff7693a790110 | ||||
| phase:       draft | ||||
| parent:      1e3e49d2cc8feaad4942d100108f20f207742d3a | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    f0bd6fbafbaebe4bb59c35108428f6fce152431d | ||||
| user:        tést èncödîng <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      beta | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add beta | ||||
|  | ||||
|  | ||||
| changeset:   1e3e49d2cc8feaad4942d100108f20f207742d3a | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    8b8a0e87dfd7a0706c0524afa8ba67e20544cbf0 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add älphà | ||||
|  | ||||
|  | ||||
							
								
								
									
										32
									
								
								t/expected/executable bit/log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								t/expected/executable bit/log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| blob | ||||
| mark :1 | ||||
| data 6 | ||||
| alpha | ||||
|  | ||||
| reset refs/heads/master | ||||
| commit refs/heads/master | ||||
| mark :2 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 10 | ||||
| add alpha | ||||
| M 100644 :1 alpha | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :3 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 19 | ||||
| set executable bit | ||||
| from :2 | ||||
| M 100755 :1 alpha | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :4 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 21 | ||||
| clear executable bit | ||||
| from :3 | ||||
| M 100644 :1 alpha | ||||
|  | ||||
							
								
								
									
										46
									
								
								t/expected/executable bit/output
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								t/expected/executable bit/output
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | ||||
| changeset:   1efb93106a36bf71352ab04e769a3422522cf946 | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      d7cae8b1fdab97568ba5eca44ca2bf5a44d7c394 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    51e6255d794f794a8c4e0f03edf264444e3c5ce7 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files:       alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| clear executable bit | ||||
|  | ||||
|  | ||||
| changeset:   d7cae8b1fdab97568ba5eca44ca2bf5a44d7c394 | ||||
| phase:       draft | ||||
| parent:      362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    e4bf4ef5e9aea7a6a57573e533a5519bd062f144 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files:       alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| set executable bit | ||||
|  | ||||
|  | ||||
| changeset:   362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    8b8a0e87dfd7a0706c0524afa8ba67e20544cbf0 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add alpha | ||||
|  | ||||
|  | ||||
| 644   alpha | ||||
| 644   alpha | ||||
							
								
								
									
										60
									
								
								t/expected/file removal/log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								t/expected/file removal/log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | ||||
| blob | ||||
| mark :1 | ||||
| data 6 | ||||
| alpha | ||||
|  | ||||
| reset refs/heads/master | ||||
| commit refs/heads/master | ||||
| mark :2 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 10 | ||||
| add alpha | ||||
| M 100644 :1 alpha | ||||
|  | ||||
| blob | ||||
| mark :3 | ||||
| data 5 | ||||
| beta | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :4 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 9 | ||||
| add beta | ||||
| from :2 | ||||
| M 100644 :3 beta | ||||
|  | ||||
| blob | ||||
| mark :5 | ||||
| data 5 | ||||
| blah | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :6 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 8 | ||||
| add foo | ||||
| from :4 | ||||
| M 100644 :5 foo/bar | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :7 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 13 | ||||
| remove alpha | ||||
| from :6 | ||||
| D alpha | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :8 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 15 | ||||
| remove foo/bar | ||||
| from :7 | ||||
| D foo/bar | ||||
|  | ||||
							
								
								
									
										75
									
								
								t/expected/file removal/output
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								t/expected/file removal/output
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | ||||
| changeset:   54f595cbdf1f516dc3b2b25faa6f051aae712f5d | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      7fe32a9185c6d37db430ee5248cdb2ae66582478 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    3f83f42fa00fb0cac14a83aa48baac2f287a9329 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files-:      foo/bar | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| remove foo/bar | ||||
|  | ||||
|  | ||||
| changeset:   7fe32a9185c6d37db430ee5248cdb2ae66582478 | ||||
| phase:       draft | ||||
| parent:      a21fd0b26a555427c2ea72f8ed37190f6216f705 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    cd10925837609b99d345c44c85bd1f73d742cbbc | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files-:      alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| remove alpha | ||||
|  | ||||
|  | ||||
| changeset:   a21fd0b26a555427c2ea72f8ed37190f6216f705 | ||||
| phase:       draft | ||||
| parent:      7cd99375c843931bd8959b766a94e050f428512b | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    a6ee442a94bfc6fb0b7d717183bb8b4534ca4ccd | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      foo/bar | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add foo | ||||
|  | ||||
|  | ||||
| changeset:   7cd99375c843931bd8959b766a94e050f428512b | ||||
| phase:       draft | ||||
| parent:      362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    f0bd6fbafbaebe4bb59c35108428f6fce152431d | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      beta | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add beta | ||||
|  | ||||
|  | ||||
| changeset:   362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    8b8a0e87dfd7a0706c0524afa8ba67e20544cbf0 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add alpha | ||||
|  | ||||
|  | ||||
| beta | ||||
| foo/bar | ||||
| beta | ||||
							
								
								
									
										32
									
								
								t/expected/git tags/log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								t/expected/git tags/log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| changeset:   7cd99375c843931bd8959b766a94e050f428512b | ||||
| bookmark:    master | ||||
| tag:         beta | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    f0bd6fbafbaebe4bb59c35108428f6fce152431d | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      beta | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add beta | ||||
|  | ||||
|  | ||||
| changeset:   362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| tag:         alpha | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    8b8a0e87dfd7a0706c0524afa8ba67e20544cbf0 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add alpha | ||||
|  | ||||
|  | ||||
							
								
								
									
										141
									
								
								t/expected/hg author/git-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								t/expected/hg author/git-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,141 @@ | ||||
| blob | ||||
| mark :1 | ||||
| data 6 | ||||
| alpha | ||||
|  | ||||
| reset refs/heads/not-master | ||||
| commit refs/heads/not-master | ||||
| mark :2 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 10 | ||||
| add alpha | ||||
| M 100644 :1 alpha | ||||
|  | ||||
| blob | ||||
| mark :3 | ||||
| data 5 | ||||
| beta | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :4 | ||||
| author test <none@none> 0 +0000 | ||||
| committer test <none@none> 0 +0000 | ||||
| data 9 | ||||
| add beta | ||||
| from :2 | ||||
| M 100644 :3 beta | ||||
|  | ||||
| blob | ||||
| mark :5 | ||||
| data 11 | ||||
| beta | ||||
| gamma | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :6 | ||||
| author test ext:(%20%28comment%29) <test@example.com> 0 +0000 | ||||
| committer test ext:(%20%28comment%29) <test@example.com> 0 +0000 | ||||
| data 12 | ||||
| modify beta | ||||
| from :4 | ||||
| M 100644 :5 beta | ||||
|  | ||||
| blob | ||||
| mark :7 | ||||
| data 6 | ||||
| gamma | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :8 | ||||
| author  <test@example.com> 0 +0000 | ||||
| committer  <test@example.com> 0 +0000 | ||||
| data 10 | ||||
| add gamma | ||||
| from :6 | ||||
| M 100644 :7 gamma | ||||
|  | ||||
| blob | ||||
| mark :9 | ||||
| data 6 | ||||
| delta | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :10 | ||||
| author name <test@example.com> 0 +0000 | ||||
| committer name <test@example.com> 0 +0000 | ||||
| data 10 | ||||
| add delta | ||||
| from :8 | ||||
| M 100644 :9 delta | ||||
|  | ||||
| blob | ||||
| mark :11 | ||||
| data 8 | ||||
| epsilon | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :12 | ||||
| author name <test@example.com> 0 +0000 | ||||
| committer name <test@example.com> 0 +0000 | ||||
| data 12 | ||||
| add epsilon | ||||
| from :10 | ||||
| M 100644 :11 epsilon | ||||
|  | ||||
| blob | ||||
| mark :13 | ||||
| data 5 | ||||
| zeta | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :14 | ||||
| author test <none@none> 0 +0000 | ||||
| committer test <none@none> 0 +0000 | ||||
| data 9 | ||||
| add zeta | ||||
| from :12 | ||||
| M 100644 :13 zeta | ||||
|  | ||||
| blob | ||||
| mark :15 | ||||
| data 4 | ||||
| eta | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :16 | ||||
| author test <test@example.com> 0 +0000 | ||||
| committer test <test@example.com> 0 +0000 | ||||
| data 8 | ||||
| add eta | ||||
| from :14 | ||||
| M 100644 :15 eta | ||||
|  | ||||
| blob | ||||
| mark :17 | ||||
| data 6 | ||||
| theta | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :18 | ||||
| author test ?test@example.com <test ?test@example.com> 0 +0000 | ||||
| committer test ?test@example.com <test ?test@example.com> 0 +0000 | ||||
| data 10 | ||||
| add theta | ||||
| from :16 | ||||
| M 100644 :17 theta | ||||
|  | ||||
| blob | ||||
| mark :19 | ||||
| data 5 | ||||
| iota | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :20 | ||||
| author test ext:(%20example%20%3Cdot%3E%20com%3E) <test ?at> 0 +0000 | ||||
| committer test ext:(%20example%20%3Cdot%3E%20com%3E) <test ?at> 0 +0000 | ||||
| data 9 | ||||
| add iota | ||||
| from :18 | ||||
| M 100644 :19 iota | ||||
|  | ||||
							
								
								
									
										134
									
								
								t/expected/hg author/hg-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										134
									
								
								t/expected/hg author/hg-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,134 @@ | ||||
| changeset:   307c03466a07cccafaafc991f36d695d6ad595f3 | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      5832614d351449a2f8d6f7ccbef4877c2b18cbe0 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    e8f1b3ae088bdd25e3570a4953ccb6b948524473 | ||||
| user:        test <test ?at> example <dot> com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      iota | ||||
| extra:       branch=default | ||||
| description: | ||||
| add iota | ||||
|  | ||||
|  | ||||
| changeset:   5832614d351449a2f8d6f7ccbef4877c2b18cbe0 | ||||
| phase:       draft | ||||
| parent:      e52ded4aca5d210ed58c63158d64fb911876f345 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    7e4875db7e2970c529f462520121d333e514bf4d | ||||
| user:        test ?test@example.com <test ?test@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      theta | ||||
| extra:       branch=default | ||||
| description: | ||||
| add theta | ||||
|  | ||||
|  | ||||
| changeset:   e52ded4aca5d210ed58c63158d64fb911876f345 | ||||
| phase:       draft | ||||
| parent:      9a34ba7d552e8b73ad306baf1d1eb83de0f74c12 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    ef03e54a9916ac3158c9686503dd4f609c26b3ec | ||||
| user:        test <test@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      eta | ||||
| extra:       branch=default | ||||
| description: | ||||
| add eta | ||||
|  | ||||
|  | ||||
| changeset:   9a34ba7d552e8b73ad306baf1d1eb83de0f74c12 | ||||
| phase:       draft | ||||
| parent:      6281edc25b9fe9538407726f044a9a61ac7ba5bc | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    616201b85baf7ed02d41f6a7deb04c52009d8483 | ||||
| user:        test | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      zeta | ||||
| extra:       branch=default | ||||
| description: | ||||
| add zeta | ||||
|  | ||||
|  | ||||
| changeset:   6281edc25b9fe9538407726f044a9a61ac7ba5bc | ||||
| phase:       draft | ||||
| parent:      4c7841053c633cb51f8375555d08b6bea54fc4cb | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    c703b3d7be8a0638047142f57ff83d4e94b5d1fa | ||||
| user:        name <test@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      epsilon | ||||
| extra:       branch=default | ||||
| description: | ||||
| add epsilon | ||||
|  | ||||
|  | ||||
| changeset:   4c7841053c633cb51f8375555d08b6bea54fc4cb | ||||
| phase:       draft | ||||
| parent:      fa8f26586397dd4797842e9300c8db221fe5514d | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    300b54001cbfa5d027b4bccdb594ccb463adb55d | ||||
| user:        name <test@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      delta | ||||
| extra:       branch=default | ||||
| description: | ||||
| add delta | ||||
|  | ||||
|  | ||||
| changeset:   fa8f26586397dd4797842e9300c8db221fe5514d | ||||
| phase:       draft | ||||
| parent:      2708ff417fb7e2c0a4f9596286c0a398553fa793 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    45b0c483a79307d14f7e234feb78776478f828ec | ||||
| user:        <test@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      gamma | ||||
| extra:       branch=default | ||||
| description: | ||||
| add gamma | ||||
|  | ||||
|  | ||||
| changeset:   2708ff417fb7e2c0a4f9596286c0a398553fa793 | ||||
| phase:       draft | ||||
| parent:      8c51e5fe974fe1cc63a56bbfad343f9ede6bed30 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    c305998040b12e956b998318982c9eb92d2d7b28 | ||||
| user:        test <test@example.com> (comment) | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files:       beta | ||||
| extra:       branch=default | ||||
| description: | ||||
| modify beta | ||||
|  | ||||
|  | ||||
| changeset:   8c51e5fe974fe1cc63a56bbfad343f9ede6bed30 | ||||
| phase:       draft | ||||
| parent:      362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    f0bd6fbafbaebe4bb59c35108428f6fce152431d | ||||
| user:        test | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      beta | ||||
| extra:       branch=default | ||||
| description: | ||||
| add beta | ||||
|  | ||||
|  | ||||
| changeset:   362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| bookmark:    not-master | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    8b8a0e87dfd7a0706c0524afa8ba67e20544cbf0 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add alpha | ||||
|  | ||||
|  | ||||
							
								
								
									
										38
									
								
								t/expected/hg branch/git-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								t/expected/hg branch/git-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | ||||
| blob | ||||
| mark :1 | ||||
| data 6 | ||||
| alpha | ||||
|  | ||||
| reset refs/heads/not-master | ||||
| commit refs/heads/not-master | ||||
| mark :2 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 10 | ||||
| add alpha | ||||
| M 100644 :1 alpha | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :3 | ||||
| author A U Thor <author@example.com> 0 +0000 | ||||
| committer A U Thor <author@example.com> 0 +0000 | ||||
| data 52 | ||||
| rename alpha to beta | ||||
|  | ||||
| --HG-- | ||||
| rename : alpha => beta | ||||
| from :2 | ||||
| D alpha | ||||
| M 100644 :1 beta | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :4 | ||||
| author A U Thor <author@example.com> 0 +0000 | ||||
| committer A U Thor <author@example.com> 0 +0000 | ||||
| data 44 | ||||
| started branch gamma | ||||
|  | ||||
| --HG-- | ||||
| branch : gamma | ||||
| from :3 | ||||
|  | ||||
							
								
								
									
										44
									
								
								t/expected/hg branch/hg-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								t/expected/hg branch/hg-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| changeset:   3320583a8de0b31511f499a4ab3426bee1a7f478 | ||||
| branch:      gamma | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      5889597089fea2d144989baa9427d1a080293fdb | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    e353b4d5282d044ad738398fd32d0b684d04a14b | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| extra:       branch=gamma | ||||
| description: | ||||
| started branch gamma | ||||
|  | ||||
|  | ||||
| changeset:   5889597089fea2d144989baa9427d1a080293fdb | ||||
| phase:       draft | ||||
| parent:      362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    e353b4d5282d044ad738398fd32d0b684d04a14b | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      beta | ||||
| files-:      alpha | ||||
| extra:       branch=default | ||||
| description: | ||||
| rename alpha to beta | ||||
|  | ||||
|  | ||||
| changeset:   362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| bookmark:    not-master | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    8b8a0e87dfd7a0706c0524afa8ba67e20544cbf0 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add alpha | ||||
|  | ||||
|  | ||||
							
								
								
									
										33
									
								
								t/expected/hg tags/output
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								t/expected/hg tags/output
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| alpha | ||||
| changeset:   16869bbe54be9f8082a8aec346de09f6c05cf1de | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    26f8145fb5b20cc6f70dd131b646f95ab79738c0 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      .hgtags | ||||
| extra:       branch=default | ||||
| description: | ||||
| Added tag alpha for changeset 362b656574c3 | ||||
|  | ||||
|  | ||||
| changeset:   362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| bookmark:    not-master | ||||
| tag:         alpha | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    8b8a0e87dfd7a0706c0524afa8ba67e20544cbf0 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add alpha | ||||
|  | ||||
|  | ||||
| 362b656574c3c9e89fa7f2d7a943091dc93bce4d alpha | ||||
							
								
								
									
										51
									
								
								t/expected/merge conflict 1/git-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								t/expected/merge conflict 1/git-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
| blob | ||||
| mark :1 | ||||
| data 2 | ||||
| A | ||||
|  | ||||
| reset refs/heads/master | ||||
| commit refs/heads/master | ||||
| mark :2 | ||||
| author A U Thor <author@example.com> 0 +0000 | ||||
| committer A U Thor <author@example.com> 0 +0000 | ||||
| data 7 | ||||
| origin | ||||
| M 100644 :1 afile | ||||
|  | ||||
| blob | ||||
| mark :3 | ||||
| data 2 | ||||
| C | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :4 | ||||
| author A U Thor <author@example.com> 2 +0000 | ||||
| committer A U Thor <author@example.com> 2 +0000 | ||||
| data 5 | ||||
| A->C | ||||
| from :2 | ||||
| M 100644 :3 afile | ||||
|  | ||||
| blob | ||||
| mark :5 | ||||
| data 2 | ||||
| B | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :6 | ||||
| author A U Thor <author@example.com> 1 +0000 | ||||
| committer A U Thor <author@example.com> 1 +0000 | ||||
| data 5 | ||||
| A->B | ||||
| from :2 | ||||
| M 100644 :5 afile | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :7 | ||||
| author A U Thor <author@example.com> 3 +0000 | ||||
| committer A U Thor <author@example.com> 3 +0000 | ||||
| data 11 | ||||
| merge to C | ||||
| from :4 | ||||
| merge :6 | ||||
|  | ||||
							
								
								
									
										54
									
								
								t/expected/merge conflict 1/hg-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								t/expected/merge conflict 1/hg-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | ||||
| changeset:   9a6668f453c3003b71e11bb8d7572af57a7ce891 | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    331ac2e605f2e6092ccb3802244a65b71f3be726 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| origin | ||||
|  | ||||
|  | ||||
| changeset:   ead35d346ecb18ce9d9d54604ff62b41caa196ce | ||||
| phase:       draft | ||||
| parent:      9a6668f453c3003b71e11bb8d7572af57a7ce891 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    894f8ad9a84f743d52747963d0b9f4e9cf37d489 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:01 1970 +0000 | ||||
| files:       afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| A->B | ||||
|  | ||||
|  | ||||
| changeset:   d585ac55494928500f510b965b878d47f9ee60f6 | ||||
| phase:       draft | ||||
| parent:      9a6668f453c3003b71e11bb8d7572af57a7ce891 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    6efc6bb8e097947aa212887bdb01fb89dfa3de13 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:02 1970 +0000 | ||||
| files:       afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| A->C | ||||
|  | ||||
|  | ||||
| changeset:   c6ab734e24c39948e5a25713b48f4972c960ff8b | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      d585ac55494928500f510b965b878d47f9ee60f6 | ||||
| parent:      ead35d346ecb18ce9d9d54604ff62b41caa196ce | ||||
| manifest:    96bedb13781f1b9d729a2210a530f0c5c68f42e6 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:03 1970 +0000 | ||||
| files:       afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| merge to C | ||||
|  | ||||
|  | ||||
							
								
								
									
										52
									
								
								t/expected/merge conflict 2/git-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								t/expected/merge conflict 2/git-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | ||||
| blob | ||||
| mark :1 | ||||
| data 2 | ||||
| A | ||||
|  | ||||
| reset refs/heads/master | ||||
| commit refs/heads/master | ||||
| mark :2 | ||||
| author A U Thor <author@example.com> 0 +0000 | ||||
| committer A U Thor <author@example.com> 0 +0000 | ||||
| data 7 | ||||
| origin | ||||
| M 100644 :1 afile | ||||
|  | ||||
| blob | ||||
| mark :3 | ||||
| data 2 | ||||
| C | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :4 | ||||
| author A U Thor <author@example.com> 2 +0000 | ||||
| committer A U Thor <author@example.com> 2 +0000 | ||||
| data 5 | ||||
| A->C | ||||
| from :2 | ||||
| M 100644 :3 afile | ||||
|  | ||||
| blob | ||||
| mark :5 | ||||
| data 2 | ||||
| B | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :6 | ||||
| author A U Thor <author@example.com> 1 +0000 | ||||
| committer A U Thor <author@example.com> 1 +0000 | ||||
| data 5 | ||||
| A->B | ||||
| from :2 | ||||
| M 100644 :5 afile | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :7 | ||||
| author A U Thor <author@example.com> 3 +0000 | ||||
| committer A U Thor <author@example.com> 3 +0000 | ||||
| data 11 | ||||
| merge to B | ||||
| from :4 | ||||
| merge :6 | ||||
| M 100644 :5 afile | ||||
|  | ||||
							
								
								
									
										54
									
								
								t/expected/merge conflict 2/hg-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								t/expected/merge conflict 2/hg-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | ||||
| changeset:   9a6668f453c3003b71e11bb8d7572af57a7ce891 | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    331ac2e605f2e6092ccb3802244a65b71f3be726 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| origin | ||||
|  | ||||
|  | ||||
| changeset:   ead35d346ecb18ce9d9d54604ff62b41caa196ce | ||||
| phase:       draft | ||||
| parent:      9a6668f453c3003b71e11bb8d7572af57a7ce891 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    894f8ad9a84f743d52747963d0b9f4e9cf37d489 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:01 1970 +0000 | ||||
| files:       afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| A->B | ||||
|  | ||||
|  | ||||
| changeset:   d585ac55494928500f510b965b878d47f9ee60f6 | ||||
| phase:       draft | ||||
| parent:      9a6668f453c3003b71e11bb8d7572af57a7ce891 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    6efc6bb8e097947aa212887bdb01fb89dfa3de13 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:02 1970 +0000 | ||||
| files:       afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| A->C | ||||
|  | ||||
|  | ||||
| changeset:   542b187b70e70dc759631d1065794f3c2c5a3e7b | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      d585ac55494928500f510b965b878d47f9ee60f6 | ||||
| parent:      ead35d346ecb18ce9d9d54604ff62b41caa196ce | ||||
| manifest:    0907d7dbc98790102fa6cb91b68b271ef0bc5b64 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:03 1970 +0000 | ||||
| files:       afile | ||||
| extra:       branch=default | ||||
| description: | ||||
| merge to B | ||||
|  | ||||
|  | ||||
							
								
								
									
										27
									
								
								t/expected/rename/git-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								t/expected/rename/git-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| blob | ||||
| mark :1 | ||||
| data 6 | ||||
| alpha | ||||
|  | ||||
| reset refs/heads/master | ||||
| commit refs/heads/master | ||||
| mark :2 | ||||
| author A U Thor <author@example.com> 0 +0000 | ||||
| committer A U Thor <author@example.com> 0 +0000 | ||||
| data 10 | ||||
| add alpha | ||||
| M 100644 :1 alpha | ||||
|  | ||||
| commit refs/heads/master | ||||
| mark :3 | ||||
| author A U Thor <author@example.com> 0 +0000 | ||||
| committer A U Thor <author@example.com> 0 +0000 | ||||
| data 52 | ||||
| rename alpha to beta | ||||
|  | ||||
| --HG-- | ||||
| rename : alpha => beta | ||||
| from :2 | ||||
| D alpha | ||||
| M 100644 :1 beta | ||||
|  | ||||
							
								
								
									
										29
									
								
								t/expected/rename/hg-log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								t/expected/rename/hg-log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| changeset:   a985b184598fd779e53576c65c5dd1d274736c73 | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      0558a161e3ca0d59f5f165e3182402d9f1e574a8 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    e353b4d5282d044ad738398fd32d0b684d04a14b | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      beta | ||||
| files-:      alpha | ||||
| extra:       branch=default | ||||
| description: | ||||
| rename alpha to beta | ||||
|  | ||||
|  | ||||
| changeset:   0558a161e3ca0d59f5f165e3182402d9f1e574a8 | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    8b8a0e87dfd7a0706c0524afa8ba67e20544cbf0 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Thu Jan 01 00:00:00 1970 +0000 | ||||
| files+:      alpha | ||||
| extra:       branch=default | ||||
| description: | ||||
| add alpha | ||||
|  | ||||
|  | ||||
							
								
								
									
										27
									
								
								t/expected/symlink/log
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								t/expected/symlink/log
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| blob | ||||
| mark :1 | ||||
| data 6 | ||||
| alpha | ||||
|  | ||||
| reset refs/heads/master | ||||
| commit refs/heads/master | ||||
| mark :2 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 10 | ||||
| add alpha | ||||
| M 100644 :1 alpha | ||||
|  | ||||
| blob | ||||
| mark :3 | ||||
| data 5 | ||||
| alpha | ||||
| commit refs/heads/master | ||||
| mark :4 | ||||
| author A U Thor <author@example.com> 1167600600 +0230 | ||||
| committer C O Mitter <committer@example.com> 1167600600 +0230 | ||||
| data 9 | ||||
| add beta | ||||
| from :2 | ||||
| M 120000 :3 beta | ||||
|  | ||||
							
								
								
									
										32
									
								
								t/expected/symlink/output
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								t/expected/symlink/output
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| changeset:   87cbc97576079d3dfef04c678bfc8ab69999ebdf | ||||
| bookmark:    master | ||||
| tag:         tip | ||||
| phase:       draft | ||||
| parent:      362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    4950f48a7f5b0ce6f31c2f4307e296dbac652026 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      beta | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add beta | ||||
|  | ||||
|  | ||||
| changeset:   362b656574c3c9e89fa7f2d7a943091dc93bce4d | ||||
| phase:       draft | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| parent:      -0000000000000000000000000000000000000000 | ||||
| manifest:    8b8a0e87dfd7a0706c0524afa8ba67e20544cbf0 | ||||
| user:        A U Thor <author@example.com> | ||||
| date:        Mon Jan 01 00:00:00 2007 +0230 | ||||
| files+:      alpha | ||||
| extra:       branch=default | ||||
| extra:       committer=C O Mitter <committer@example.com> 1167600600 -9000 | ||||
| description: | ||||
| add alpha | ||||
|  | ||||
|  | ||||
| 644   alpha | ||||
| 644 @ beta | ||||
							
								
								
									
										444
									
								
								t/hg-git.t
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										444
									
								
								t/hg-git.t
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,444 @@ | ||||
| #!/bin/bash | ||||
| # | ||||
| # Copyright (c) 2012 Felipe Contreras | ||||
| # | ||||
| # Base commands from hg-git tests: | ||||
| # https://bitbucket.org/durin42/hg-git/src | ||||
| # | ||||
|  | ||||
| # shellcheck disable=SC2016,SC2034,SC2086,SC2164,SC1091 | ||||
|  | ||||
| test_description='Test remote-hg output compared to hg-git' | ||||
|  | ||||
| . ./test-lib.sh | ||||
|  | ||||
| export EXPECTED_DIR="$SHARNESS_TEST_DIRECTORY/expected" | ||||
|  | ||||
| git_clone () { | ||||
| 	git clone -q "hg::$1" $2 && | ||||
| 	( | ||||
| 	cd $2 && | ||||
| 	git checkout master && | ||||
| 	{ git branch -D default || true ;} | ||||
| 	) | ||||
| } | ||||
|  | ||||
| hg_clone () { | ||||
| 	( | ||||
| 	hg init $2 && | ||||
| 	hg -R $2 bookmark -i master && | ||||
| 	cd $1 && | ||||
| 	git push -q "hg::../$2" 'refs/tags/*:refs/tags/*' 'refs/heads/*:refs/heads/*' | ||||
| 	) && | ||||
|  | ||||
| 	(cd $2 && hg -q update) | ||||
| } | ||||
|  | ||||
| hg_push () { | ||||
| 	( | ||||
| 	cd $2 | ||||
| 	git checkout -q -b tmp && | ||||
| 	git fetch -q "hg::../$1" 'refs/tags/*:refs/tags/*' 'refs/heads/*:refs/heads/*' && | ||||
| 	git branch -D default && | ||||
| 	git checkout -q '@{-1}' && | ||||
| 	{ git branch -q -D tmp 2> /dev/null || true ;} | ||||
| 	) | ||||
| } | ||||
|  | ||||
| hg_log () { | ||||
| 	hg -R $1 log --debug -r 'sort(tip:0, date)' | | ||||
| 		sed -e '/tag: *default/d' -e 's/[0-9]\+:\([0-9a-f]\{40\}\)/\1/' | ||||
| } | ||||
|  | ||||
| git_log () { | ||||
| 	git -C $1 fast-export --branches | ||||
| } | ||||
|  | ||||
| test_cmp_expected () { | ||||
| 	test_cmp "$EXPECTED_DIR/$test_id/$1" "$1" | ||||
| } | ||||
|  | ||||
| cmp_hg_to_git_log () { | ||||
| 	hg_log hgrepo2 > hg-log && | ||||
| 	git_log gitrepo > git-log && | ||||
|  | ||||
| 	test_cmp_expected hg-log && | ||||
| 	test_cmp_expected git-log | ||||
| } | ||||
|  | ||||
| cmp_hg_to_git_log_hgrepo1 () { | ||||
| 	git_clone hgrepo1 gitrepo && | ||||
| 	hg_clone gitrepo hgrepo2 && | ||||
|  | ||||
| 	cmp_hg_to_git_log | ||||
| } | ||||
|  | ||||
| cmp_hg_to_git_manifest () { | ||||
| 	( | ||||
| 	hg_clone gitrepo hgrepo && | ||||
| 	cd hgrepo && | ||||
| 	hg_log . && | ||||
| 	eval "$1" | ||||
| 	) > output && | ||||
|  | ||||
| 	git_clone hgrepo gitrepo2 && | ||||
| 	git_log gitrepo2 > log && | ||||
|  | ||||
| 	test_cmp_expected output && | ||||
| 	test_cmp_expected log | ||||
| } | ||||
|  | ||||
| setup () { | ||||
| 	cat > "$HOME"/.hgrc <<-EOF | ||||
| 	[ui] | ||||
| 	username = A U Thor <author@example.com> | ||||
| 	[defaults] | ||||
| 	commit = -d "0 0" | ||||
| 	tag = -d "0 0" | ||||
| 	EOF | ||||
|  | ||||
| 	cat > "$HOME"/.gitconfig <<-EOF | ||||
| 	[remote-hg] | ||||
| 		hg-git-compat = true | ||||
| 		track-branches = false | ||||
| 	EOF | ||||
|  | ||||
| 	export HGEDITOR=true | ||||
| 	export HGMERGE=true | ||||
|  | ||||
| 	export GIT_AUTHOR_DATE="2007-01-01 00:00:00 +0230" | ||||
| 	export GIT_COMMITTER_DATE="$GIT_AUTHOR_DATE" | ||||
| } | ||||
|  | ||||
| setup | ||||
|  | ||||
| # save old function | ||||
| eval "old_$(declare -f test_expect_success)" | ||||
|  | ||||
| test_expect_success () { | ||||
| 	local req | ||||
| 	test "$#" = 3 && { req=$1; shift; } || req= | ||||
| 	test_id="$1" | ||||
| 	old_test_expect_success "$req" "$1" " | ||||
| 	test_when_finished \"rm -rf gitrepo* hgrepo*\" && $2" | ||||
| } | ||||
|  | ||||
| test_expect_success 'rename' ' | ||||
| 	( | ||||
| 	hg init hgrepo1 && | ||||
| 	cd hgrepo1 && | ||||
| 	echo alpha > alpha && | ||||
| 	hg add alpha && | ||||
| 	hg commit -m "add alpha" && | ||||
| 	hg mv alpha beta && | ||||
| 	hg commit -m "rename alpha to beta" | ||||
| 	) && | ||||
|  | ||||
| 	cmp_hg_to_git_log_hgrepo1 | ||||
| ' | ||||
|  | ||||
| test_expect_success !WIN 'executable bit' ' | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
| 	echo alpha > alpha && | ||||
| 	chmod 0644 alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add alpha" && | ||||
| 	chmod 0755 alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "set executable bit" && | ||||
| 	chmod 0644 alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "clear executable bit" | ||||
| 	) && | ||||
|  | ||||
| 	cmp_hg_to_git_manifest "hg manifest -v -r -1; hg manifest -v" | ||||
| ' | ||||
|  | ||||
| test_expect_success !WIN 'symlink' ' | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add alpha" && | ||||
| 	ln -s alpha beta && | ||||
| 	git add beta && | ||||
| 	git commit -m "add beta" | ||||
| 	) && | ||||
|  | ||||
| 	cmp_hg_to_git_manifest "hg manifest -v" | ||||
| ' | ||||
|  | ||||
| test_expect_success 'merge conflict 1' ' | ||||
| 	( | ||||
| 	hg init hgrepo1 && | ||||
| 	cd hgrepo1 && | ||||
| 	echo A > afile && | ||||
| 	hg add afile && | ||||
| 	hg ci -m "origin" && | ||||
|  | ||||
| 	echo B > afile && | ||||
| 	hg ci -m "A->B" -d "1 0" && | ||||
|  | ||||
| 	hg up -r0 && | ||||
| 	echo C > afile && | ||||
| 	hg ci -m "A->C" -d "2 0" && | ||||
|  | ||||
| 	hg merge -r1 && | ||||
| 	echo C > afile && | ||||
| 	hg resolve -m afile && | ||||
| 	hg ci -m "merge to C" -d "3 0" | ||||
| 	) && | ||||
|  | ||||
| 	cmp_hg_to_git_log_hgrepo1 | ||||
| ' | ||||
|  | ||||
| test_expect_success 'merge conflict 2' ' | ||||
| 	( | ||||
| 	hg init hgrepo1 && | ||||
| 	cd hgrepo1 && | ||||
| 	echo A > afile && | ||||
| 	hg add afile && | ||||
| 	hg ci -m "origin" && | ||||
|  | ||||
| 	echo B > afile && | ||||
| 	hg ci -m "A->B" -d "1 0" && | ||||
|  | ||||
| 	hg up -r0 && | ||||
| 	echo C > afile && | ||||
| 	hg ci -m "A->C" -d "2 0" && | ||||
|  | ||||
| 	hg merge -r1 || true && | ||||
| 	echo B > afile && | ||||
| 	hg resolve -m afile && | ||||
| 	hg ci -m "merge to B" -d "3 0" | ||||
| 	) && | ||||
|  | ||||
| 	cmp_hg_to_git_log_hgrepo1 | ||||
| ' | ||||
|  | ||||
| test_expect_success 'converged merge' ' | ||||
| 	( | ||||
| 	hg init hgrepo1 && | ||||
| 	cd hgrepo1 && | ||||
| 	echo A > afile && | ||||
| 	hg add afile && | ||||
| 	hg ci -m "origin" && | ||||
|  | ||||
| 	echo B > afile && | ||||
| 	hg ci -m "A->B" -d "1 0" && | ||||
|  | ||||
| 	echo C > afile && | ||||
| 	hg ci -m "B->C" -d "2 0" && | ||||
|  | ||||
| 	hg up -r0 && | ||||
| 	echo C > afile && | ||||
| 	hg ci -m "A->C" -d "3 0" && | ||||
|  | ||||
| 	hg merge -r2 || true && | ||||
| 	hg ci -m "merge" -d "4 0" | ||||
| 	) && | ||||
|  | ||||
| 	cmp_hg_to_git_log_hgrepo1 | ||||
| ' | ||||
|  | ||||
| test_expect_success 'encoding' ' | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
|  | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add älphà" && | ||||
|  | ||||
| 	GIT_AUTHOR_NAME="tést èncödîng" && | ||||
| 	export GIT_AUTHOR_NAME && | ||||
| 	echo beta > beta && | ||||
| 	git add beta && | ||||
| 	git commit -m "add beta" && | ||||
|  | ||||
| 	echo gamma > gamma && | ||||
| 	git add gamma && | ||||
| 	git commit -m "add gämmâ" && | ||||
|  | ||||
| 	: TODO git config i18n.commitencoding latin-1 && | ||||
| 	echo delta > delta && | ||||
| 	git add delta && | ||||
| 	git commit -m "add déltà" | ||||
| 	) && | ||||
|  | ||||
| 	hg_clone gitrepo hgrepo && | ||||
| 	git_clone hgrepo gitrepo2 && | ||||
|  | ||||
| 	HGENCODING=utf-8 hg_log hgrepo > hg-log && | ||||
| 	git_log gitrepo2 > git-log && | ||||
|  | ||||
| 	test_cmp_expected hg-log && | ||||
| 	test_cmp_expected git-log | ||||
| ' | ||||
|  | ||||
| test_expect_success 'file removal' ' | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add alpha" && | ||||
| 	echo beta > beta && | ||||
| 	git add beta && | ||||
| 	git commit -m "add beta" | ||||
| 	mkdir foo && | ||||
| 	echo blah > foo/bar && | ||||
| 	git add foo && | ||||
| 	git commit -m "add foo" && | ||||
| 	git rm alpha && | ||||
| 	git commit -m "remove alpha" && | ||||
| 	git rm foo/bar && | ||||
| 	git commit -m "remove foo/bar" | ||||
| 	) && | ||||
|  | ||||
| 	cmp_hg_to_git_manifest "hg manifest -r 3; hg manifest" | ||||
| ' | ||||
|  | ||||
| test_expect_success 'git tags' ' | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
| 	git config receive.denyCurrentBranch ignore && | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add alpha" && | ||||
| 	git tag alpha && | ||||
|  | ||||
| 	echo beta > beta && | ||||
| 	git add beta && | ||||
| 	git commit -m "add beta" && | ||||
| 	git tag -a -m "added tag beta" beta | ||||
| 	) && | ||||
|  | ||||
| 	hg_clone gitrepo hgrepo && | ||||
| 	hg_log hgrepo > log && | ||||
|  | ||||
| 	test_cmp_expected log | ||||
| ' | ||||
|  | ||||
| test_expect_success 'hg author' ' | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
|  | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add alpha" && | ||||
| 	git checkout -q -b not-master | ||||
| 	) && | ||||
|  | ||||
| 	( | ||||
| 	hg_clone gitrepo hgrepo && | ||||
| 	cd hgrepo && | ||||
|  | ||||
| 	hg co master && | ||||
| 	echo beta > beta && | ||||
| 	hg add beta && | ||||
| 	hg commit -u "test" -m "add beta" && | ||||
|  | ||||
| 	echo gamma >> beta && | ||||
| 	hg commit -u "test <test@example.com> (comment)" -m "modify beta" && | ||||
|  | ||||
| 	echo gamma > gamma && | ||||
| 	hg add gamma && | ||||
| 	hg commit -u "<test@example.com>" -m "add gamma" && | ||||
|  | ||||
| 	echo delta > delta && | ||||
| 	hg add delta && | ||||
| 	hg commit -u "name<test@example.com>" -m "add delta" && | ||||
|  | ||||
| 	echo epsilon > epsilon && | ||||
| 	hg add epsilon && | ||||
| 	hg commit -u "name <test@example.com" -m "add epsilon" && | ||||
|  | ||||
| 	echo zeta > zeta && | ||||
| 	hg add zeta && | ||||
| 	hg commit -u " test " -m "add zeta" && | ||||
|  | ||||
| 	echo eta > eta && | ||||
| 	hg add eta && | ||||
| 	hg commit -u "test < test@example.com >" -m "add eta" && | ||||
|  | ||||
| 	echo theta > theta && | ||||
| 	hg add theta && | ||||
| 	hg commit -u "test >test@example.com>" -m "add theta" && | ||||
|  | ||||
| 	echo iota > iota && | ||||
| 	hg add iota && | ||||
| 	hg commit -u "test <test <at> example <dot> com>" -m "add iota" | ||||
| 	) && | ||||
|  | ||||
| 	hg_push hgrepo gitrepo && | ||||
| 	hg_clone gitrepo hgrepo2 && | ||||
|  | ||||
| 	cmp_hg_to_git_log | ||||
| ' | ||||
|  | ||||
| test_expect_success 'hg branch' ' | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
|  | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -q -m "add alpha" && | ||||
| 	git checkout -q -b not-master | ||||
| 	) && | ||||
|  | ||||
| 	( | ||||
| 	hg_clone gitrepo hgrepo && | ||||
|  | ||||
| 	cd hgrepo && | ||||
| 	hg -q co master && | ||||
| 	hg mv alpha beta && | ||||
| 	hg -q commit -m "rename alpha to beta" && | ||||
| 	hg branch gamma | grep -v "permanent and global" && | ||||
| 	hg -q commit -m "started branch gamma" | ||||
| 	) && | ||||
|  | ||||
| 	hg_push hgrepo gitrepo && | ||||
| 	hg_clone gitrepo hgrepo2 && | ||||
|  | ||||
| 	cmp_hg_to_git_log | ||||
| ' | ||||
|  | ||||
| test_expect_success 'hg tags' ' | ||||
| 	( | ||||
| 	git init -q gitrepo && | ||||
| 	cd gitrepo && | ||||
|  | ||||
| 	echo alpha > alpha && | ||||
| 	git add alpha && | ||||
| 	git commit -m "add alpha" && | ||||
| 	git checkout -q -b not-master | ||||
| 	) && | ||||
|  | ||||
| 	( | ||||
| 	hg_clone gitrepo hgrepo && | ||||
|  | ||||
| 	cd hgrepo && | ||||
| 	hg co master && | ||||
| 	hg tag alpha | ||||
| 	) && | ||||
|  | ||||
| 	hg_push hgrepo gitrepo && | ||||
| 	hg_clone gitrepo hgrepo2 && | ||||
|  | ||||
| 	( | ||||
| 	git -C gitrepo tag -l && | ||||
| 	hg_log hgrepo2 && | ||||
| 	cat hgrepo2/.hgtags | ||||
| 	) > output && | ||||
|  | ||||
| 	test_cmp_expected output | ||||
| ' | ||||
|  | ||||
| test_done | ||||
							
								
								
									
										971
									
								
								t/sharness.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										971
									
								
								t/sharness.sh
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,971 @@ | ||||
| #!/bin/sh | ||||
| # | ||||
| # Copyright (c) 2011-2012 Mathias Lafeldt | ||||
| # Copyright (c) 2005-2012 Git project | ||||
| # Copyright (c) 2005-2012 Junio C Hamano | ||||
| # | ||||
| # This program is free software: you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation, either version 2 of the License, or | ||||
| # (at your option) any later version. | ||||
| # | ||||
| # This program is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with this program.  If not, see http://www.gnu.org/licenses/ . | ||||
|  | ||||
| # Public: Current version of Sharness. | ||||
| SHARNESS_VERSION="1.1.0" | ||||
| export SHARNESS_VERSION | ||||
|  | ||||
| # Public: The file extension for tests.  By default, it is set to "t". | ||||
| : "${SHARNESS_TEST_EXTENSION:=t}" | ||||
| export SHARNESS_TEST_EXTENSION | ||||
|  | ||||
| # Public: Root directory containing tests. Tests can override this variable, | ||||
| # e.g. for testing Sharness itself. | ||||
| if test -z "$SHARNESS_TEST_DIRECTORY" | ||||
| then | ||||
| 	SHARNESS_TEST_DIRECTORY=$(pwd) | ||||
| else | ||||
| 	# ensure that SHARNESS_TEST_DIRECTORY is an absolute path so that it | ||||
| 	# is valid even if the current working directory is changed | ||||
| 	SHARNESS_TEST_DIRECTORY=$(cd "$SHARNESS_TEST_DIRECTORY" && pwd) || exit 1 | ||||
| fi | ||||
| export SHARNESS_TEST_DIRECTORY | ||||
|  | ||||
| if test -z "$SHARNESS_TEST_OUTPUT_DIRECTORY" | ||||
| then | ||||
| 	# Similarly, override this to store the test-results subdir | ||||
| 	# elsewhere | ||||
| 	SHARNESS_TEST_OUTPUT_DIRECTORY=$SHARNESS_TEST_DIRECTORY | ||||
| fi | ||||
|  | ||||
| #  Reset TERM to original terminal if found, otherwise save original TERM | ||||
| [ "x" = "x$SHARNESS_ORIG_TERM" ] && | ||||
| 		SHARNESS_ORIG_TERM="$TERM" || | ||||
| 		TERM="$SHARNESS_ORIG_TERM" | ||||
| # Public: The unsanitized TERM under which sharness is originally run | ||||
| export SHARNESS_ORIG_TERM | ||||
|  | ||||
| # Export SHELL_PATH | ||||
| : "${SHELL_PATH:=$SHELL}" | ||||
| export SHELL_PATH | ||||
|  | ||||
| # if --tee was passed, write the output not only to the terminal, but | ||||
| # additionally to the file test-results/$BASENAME.out, too. | ||||
| case "$SHARNESS_TEST_TEE_STARTED, $* " in | ||||
| done,*) | ||||
| 	# do not redirect again | ||||
| 	;; | ||||
| *' --tee '*|*' --verbose-log '*) | ||||
| 	mkdir -p "$SHARNESS_TEST_OUTPUT_DIRECTORY/test-results" | ||||
| 	BASE="$SHARNESS_TEST_OUTPUT_DIRECTORY/test-results/$(basename "$0" ".$SHARNESS_TEST_EXTENSION")" | ||||
|  | ||||
| 	# Make this filename available to the sub-process in case it is using | ||||
| 	# --verbose-log. | ||||
| 	SHARNESS_TEST_TEE_OUTPUT_FILE="$BASE.out" | ||||
| 	export SHARNESS_TEST_TEE_OUTPUT_FILE | ||||
|  | ||||
| 	# Truncate before calling "tee -a" to get rid of the results | ||||
| 	# from any previous runs. | ||||
| 	: >"$SHARNESS_TEST_TEE_OUTPUT_FILE" | ||||
|  | ||||
| 	(SHARNESS_TEST_TEE_STARTED="done" ${SHELL_PATH} "$0" "$@" 2>&1; | ||||
| 	 echo $? >"$BASE.exit") | tee -a "$SHARNESS_TEST_TEE_OUTPUT_FILE" | ||||
| 	test "$(cat "$BASE.exit")" = 0 | ||||
| 	exit | ||||
| 	;; | ||||
| esac | ||||
|  | ||||
| # For repeatability, reset the environment to a known state. | ||||
| # TERM is sanitized below, after saving color control sequences. | ||||
| LANG=C | ||||
| LC_ALL=C | ||||
| PAGER="cat" | ||||
| TZ=UTC | ||||
| EDITOR=: | ||||
| export LANG LC_ALL PAGER TZ EDITOR | ||||
| unset VISUAL CDPATH GREP_OPTIONS | ||||
|  | ||||
| [ "x$TERM" != "xdumb" ] && ( | ||||
| 		[ -t 1 ] && | ||||
| 		tput bold >/dev/null 2>&1 && | ||||
| 		tput setaf 1 >/dev/null 2>&1 && | ||||
| 		tput sgr0 >/dev/null 2>&1 | ||||
| 	) && | ||||
| 	color=t | ||||
|  | ||||
| while test "$#" -ne 0; do | ||||
| 	case "$1" in | ||||
| 	-d|--d|--de|--deb|--debu|--debug) | ||||
| 		debug=t; shift ;; | ||||
| 	-i|--i|--im|--imm|--imme|--immed|--immedi|--immedia|--immediat|--immediate) | ||||
| 		immediate=t; shift ;; | ||||
| 	-l|--l|--lo|--lon|--long|--long-|--long-t|--long-te|--long-tes|--long-test|--long-tests) | ||||
| 		TEST_LONG=t; export TEST_LONG; shift ;; | ||||
| 	--in|--int|--inte|--inter|--intera|--interac|--interact|--interacti|--interactiv|--interactive|--interactive-|--interactive-t|--interactive-te|--interactive-tes|--interactive-test|--interactive-tests): | ||||
| 		TEST_INTERACTIVE=t; export TEST_INTERACTIVE; verbose=t; shift ;; | ||||
| 	-h|--h|--he|--hel|--help) | ||||
| 		help=t; shift ;; | ||||
| 	-v|--v|--ve|--ver|--verb|--verbo|--verbos|--verbose) | ||||
| 		verbose=t; shift ;; | ||||
| 	-q|--q|--qu|--qui|--quie|--quiet) | ||||
| 		# Ignore --quiet under a TAP::Harness. Saying how many tests | ||||
| 		# passed without the ok/not ok details is always an error. | ||||
| 		test -z "$HARNESS_ACTIVE" && quiet=t; shift ;; | ||||
| 	--chain-lint) | ||||
| 		chain_lint=t; shift ;; | ||||
| 	--no-chain-lint) | ||||
| 		chain_lint=; shift ;; | ||||
| 	--no-color) | ||||
| 		color=; shift ;; | ||||
| 	--tee) | ||||
| 		shift ;; # was handled already | ||||
| 	--root=*) | ||||
| 		root=$(expr "z$1" : 'z[^=]*=\(.*\)') | ||||
| 		shift ;; | ||||
| 	--verbose-log) | ||||
| 		verbose_log=t | ||||
| 		shift ;; | ||||
| 	*) | ||||
| 		echo "error: unknown test option '$1'" >&2; exit 1 ;; | ||||
| 	esac | ||||
| done | ||||
|  | ||||
| if test -n "$color"; then | ||||
| 	# Save the color control sequences now rather than run tput | ||||
| 	# each time say_color() is called.  This is done for two | ||||
| 	# reasons: | ||||
| 	#   * TERM will be changed to dumb | ||||
| 	#   * HOME will be changed to a temporary directory and tput | ||||
| 	#     might need to read ~/.terminfo from the original HOME | ||||
| 	#     directory to get the control sequences | ||||
| 	# Note:  This approach assumes the control sequences don't end | ||||
| 	# in a newline for any terminal of interest (command | ||||
| 	# substitutions strip trailing newlines).  Given that most | ||||
| 	# (all?) terminals in common use are related to ECMA-48, this | ||||
| 	# shouldn't be a problem. | ||||
| 	say_color_error=$(tput bold; tput setaf 1) # bold red | ||||
| 	say_color_skip=$(tput setaf 4) # blue | ||||
| 	say_color_warn=$(tput setaf 3) # brown/yellow | ||||
| 	say_color_pass=$(tput setaf 2) # green | ||||
| 	say_color_info=$(tput setaf 6) # cyan | ||||
| 	say_color_reset=$(tput sgr0) | ||||
| 	say_color_raw="" # no formatting for normal text | ||||
| 	say_color() { | ||||
| 		test -z "$1" && test -n "$quiet" && return | ||||
| 		case "$1" in | ||||
| 			error) say_color_color=$say_color_error ;; | ||||
| 			skip) say_color_color=$say_color_skip ;; | ||||
| 			warn) say_color_color=$say_color_warn ;; | ||||
| 			pass) say_color_color=$say_color_pass ;; | ||||
| 			info) say_color_color=$say_color_info ;; | ||||
| 			*) say_color_color=$say_color_raw ;; | ||||
| 		esac | ||||
| 		shift | ||||
| 		printf '%s%s%s\n' "$say_color_color" "$*" "$say_color_reset" | ||||
| 	} | ||||
| else | ||||
| 	say_color() { | ||||
| 		test -z "$1" && test -n "$quiet" && return | ||||
| 		shift | ||||
| 		printf '%s\n' "$*" | ||||
| 	} | ||||
| fi | ||||
|  | ||||
| TERM=dumb | ||||
| export TERM | ||||
|  | ||||
| error() { | ||||
| 	say_color error "error: $*" | ||||
| 	EXIT_OK=t | ||||
| 	exit 1 | ||||
| } | ||||
|  | ||||
| say() { | ||||
| 	say_color info "$*" | ||||
| } | ||||
|  | ||||
| test -n "${test_description:-}" || error "Test script did not set test_description." | ||||
|  | ||||
| if test "$help" = "t"; then | ||||
| 	echo "$test_description" | ||||
| 	exit 0 | ||||
| fi | ||||
|  | ||||
| exec 5>&1 | ||||
| exec 6<&0 | ||||
| if test "$verbose_log" = "t" | ||||
| then | ||||
| 	exec 3>>"$SHARNESS_TEST_TEE_OUTPUT_FILE" 4>&3 | ||||
| elif test "$verbose" = "t" | ||||
| then | ||||
| 	exec 4>&2 3>&1 | ||||
| else | ||||
| 	exec 4>/dev/null 3>/dev/null | ||||
| fi | ||||
|  | ||||
| test_failure=0 | ||||
| test_count=0 | ||||
| test_fixed=0 | ||||
| test_broken=0 | ||||
| test_success=0 | ||||
|  | ||||
| die() { | ||||
| 	code=$? | ||||
| 	if test -n "$EXIT_OK"; then | ||||
| 		exit $code | ||||
| 	else | ||||
| 		echo >&5 "FATAL: Unexpected exit with code $code" | ||||
| 		exit 1 | ||||
| 	fi | ||||
| } | ||||
|  | ||||
| EXIT_OK= | ||||
| trap 'die' EXIT | ||||
|  | ||||
| # Public: Define that a test prerequisite is available. | ||||
| # | ||||
| # The prerequisite can later be checked explicitly using test_have_prereq or | ||||
| # implicitly by specifying the prerequisite name in calls to test_expect_success | ||||
| # or test_expect_failure. | ||||
| # | ||||
| # $1 - Name of prerequisite (a simple word, in all capital letters by convention) | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   # Set PYTHON prerequisite if interpreter is available. | ||||
| #   command -v python >/dev/null && test_set_prereq PYTHON | ||||
| # | ||||
| #   # Set prerequisite depending on some variable. | ||||
| #   test -z "$NO_GETTEXT" && test_set_prereq GETTEXT | ||||
| # | ||||
| # Returns nothing. | ||||
| test_set_prereq() { | ||||
| 	satisfied_prereq="$satisfied_prereq$1 " | ||||
| } | ||||
| satisfied_prereq=" " | ||||
|  | ||||
| # Public: Check if one or more test prerequisites are defined. | ||||
| # | ||||
| # The prerequisites must have previously been set with test_set_prereq. | ||||
| # The most common use of this is to skip all the tests if some essential | ||||
| # prerequisite is missing. | ||||
| # | ||||
| # $1 - Comma-separated list of test prerequisites. | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   # Skip all remaining tests if prerequisite is not set. | ||||
| #   if ! test_have_prereq PERL; then | ||||
| #       skip_all='skipping perl interface tests, perl not available' | ||||
| #       test_done | ||||
| #   fi | ||||
| # | ||||
| # Returns 0 if all prerequisites are defined or 1 otherwise. | ||||
| test_have_prereq() { | ||||
| 	# prerequisites can be concatenated with ',' | ||||
| 	save_IFS=$IFS | ||||
| 	IFS=, | ||||
| 	set -- $@ | ||||
| 	IFS=$save_IFS | ||||
|  | ||||
| 	total_prereq=0 | ||||
| 	ok_prereq=0 | ||||
| 	missing_prereq= | ||||
|  | ||||
| 	for prerequisite; do | ||||
| 		case "$prerequisite" in | ||||
| 		!*) | ||||
| 			negative_prereq=t | ||||
| 			prerequisite=${prerequisite#!} | ||||
| 			;; | ||||
| 		*) | ||||
| 			negative_prereq= | ||||
| 		esac | ||||
|  | ||||
| 		total_prereq=$((total_prereq + 1)) | ||||
| 		case "$satisfied_prereq" in | ||||
| 		*" $prerequisite "*) | ||||
| 			satisfied_this_prereq=t | ||||
| 			;; | ||||
| 		*) | ||||
| 			satisfied_this_prereq= | ||||
| 		esac | ||||
|  | ||||
| 		case "$satisfied_this_prereq,$negative_prereq" in | ||||
| 		t,|,t) | ||||
| 			ok_prereq=$((ok_prereq + 1)) | ||||
| 			;; | ||||
| 		*) | ||||
| 			# Keep a list of missing prerequisites; restore | ||||
| 			# the negative marker if necessary. | ||||
| 			prerequisite=${negative_prereq:+!}$prerequisite | ||||
| 			if test -z "$missing_prereq"; then | ||||
| 				missing_prereq=$prerequisite | ||||
| 			else | ||||
| 				missing_prereq="$prerequisite,$missing_prereq" | ||||
| 			fi | ||||
| 		esac | ||||
| 	done | ||||
|  | ||||
| 	test $total_prereq = $ok_prereq | ||||
| } | ||||
|  | ||||
| # You are not expected to call test_ok_ and test_failure_ directly, use | ||||
| # the text_expect_* functions instead. | ||||
|  | ||||
| test_ok_() { | ||||
| 	test_success=$((test_success + 1)) | ||||
| 	say_color "" "ok $test_count - $*" | ||||
| } | ||||
|  | ||||
| test_failure_() { | ||||
| 	test_failure=$((test_failure + 1)) | ||||
| 	say_color error "not ok $test_count - $1" | ||||
| 	shift | ||||
| 	echo "$@" | sed -e 's/^/#	/' | ||||
| 	test "$immediate" = "" || { EXIT_OK=t; exit 1; } | ||||
| } | ||||
|  | ||||
| test_known_broken_ok_() { | ||||
| 	test_fixed=$((test_fixed + 1)) | ||||
| 	say_color error "ok $test_count - $* # TODO known breakage vanished" | ||||
| } | ||||
|  | ||||
| test_known_broken_failure_() { | ||||
| 	test_broken=$((test_broken + 1)) | ||||
| 	say_color warn "not ok $test_count - $* # TODO known breakage" | ||||
| } | ||||
|  | ||||
| # Public: Execute commands in debug mode. | ||||
| # | ||||
| # Takes a single argument and evaluates it only when the test script is started | ||||
| # with --debug. This is primarily meant for use during the development of test | ||||
| # scripts. | ||||
| # | ||||
| # $1 - Commands to be executed. | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   test_debug "cat some_log_file" | ||||
| # | ||||
| # Returns the exit code of the last command executed in debug mode or 0 | ||||
| #   otherwise. | ||||
| test_debug() { | ||||
| 	test "$debug" = "" || eval "$1" | ||||
| } | ||||
|  | ||||
| # Public: Stop execution and start a shell. | ||||
| # | ||||
| # This is useful for debugging tests and only makes sense together with "-v". | ||||
| # Be sure to remove all invocations of this command before submitting. | ||||
| test_pause() { | ||||
| 	if test "$verbose" = t; then | ||||
| 		"$SHELL_PATH" <&6 >&3 2>&4 | ||||
| 	else | ||||
| 		error >&5 "test_pause requires --verbose" | ||||
| 	fi | ||||
| } | ||||
|  | ||||
| test_eval_() { | ||||
| 	# This is a separate function because some tests use | ||||
| 	# "return" to end a test_expect_success block early. | ||||
| 	case ",$test_prereq," in | ||||
| 	*,INTERACTIVE,*) | ||||
| 		eval "$*" | ||||
| 		;; | ||||
| 	*) | ||||
| 		eval </dev/null >&3 2>&4 "$*" | ||||
| 		;; | ||||
| 	esac | ||||
| } | ||||
|  | ||||
| test_run_() { | ||||
| 	test_cleanup=: | ||||
| 	expecting_failure=$2 | ||||
| 	test_eval_ "$1" | ||||
| 	eval_ret=$? | ||||
|  | ||||
| 	if test "$chain_lint" = "t"; then | ||||
| 		test_eval_ "(exit 117) && $1" | ||||
| 		if test "$?" != 117; then | ||||
| 			error "bug in the test script: broken &&-chain: $1" | ||||
| 		fi | ||||
| 	fi | ||||
|  | ||||
| 	if test -z "$immediate" || test $eval_ret = 0 || test -n "$expecting_failure"; then | ||||
| 		test_eval_ "$test_cleanup" | ||||
| 	fi | ||||
| 	if test "$verbose" = "t" && test -n "$HARNESS_ACTIVE"; then | ||||
| 		echo "" | ||||
| 	fi | ||||
| 	return "$eval_ret" | ||||
| } | ||||
|  | ||||
| test_skip_() { | ||||
| 	test_count=$((test_count + 1)) | ||||
| 	to_skip= | ||||
| 	for skp in $SKIP_TESTS; do | ||||
| 		case $this_test.$test_count in | ||||
| 		$skp) | ||||
| 			to_skip=t | ||||
| 			break | ||||
| 		esac | ||||
| 	done | ||||
| 	if test -z "$to_skip" && test -n "$test_prereq" && ! test_have_prereq "$test_prereq"; then | ||||
| 		to_skip=t | ||||
| 	fi | ||||
| 	case "$to_skip" in | ||||
| 	t) | ||||
| 		of_prereq= | ||||
| 		if test "$missing_prereq" != "$test_prereq"; then | ||||
| 			of_prereq=" of $test_prereq" | ||||
| 		fi | ||||
|  | ||||
| 		say_color skip >&3 "skipping test: $*" | ||||
| 		say_color skip "ok $test_count # skip $1 (missing $missing_prereq${of_prereq})" | ||||
| 		: true | ||||
| 		;; | ||||
| 	*) | ||||
| 		false | ||||
| 		;; | ||||
| 	esac | ||||
| } | ||||
|  | ||||
| # Public: Run test commands and expect them to succeed. | ||||
| # | ||||
| # When the test passed, an "ok" message is printed and the number of successful | ||||
| # tests is incremented. When it failed, a "not ok" message is printed and the | ||||
| # number of failed tests is incremented. | ||||
| # | ||||
| # With --immediate, exit test immediately upon the first failed test. | ||||
| # | ||||
| # Usually takes two arguments: | ||||
| # $1 - Test description | ||||
| # $2 - Commands to be executed. | ||||
| # | ||||
| # With three arguments, the first will be taken to be a prerequisite: | ||||
| # $1 - Comma-separated list of test prerequisites. The test will be skipped if | ||||
| #      not all of the given prerequisites are set. To negate a prerequisite, | ||||
| #      put a "!" in front of it. | ||||
| # $2 - Test description | ||||
| # $3 - Commands to be executed. | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   test_expect_success \ | ||||
| #       'git-write-tree should be able to write an empty tree.' \ | ||||
| #       'tree=$(git-write-tree)' | ||||
| # | ||||
| #   # Test depending on one prerequisite. | ||||
| #   test_expect_success TTY 'git --paginate rev-list uses a pager' \ | ||||
| #       ' ... ' | ||||
| # | ||||
| #   # Multiple prerequisites are separated by a comma. | ||||
| #   test_expect_success PERL,PYTHON 'yo dawg' \ | ||||
| #       ' test $(perl -E 'print eval "1 +" . qx[python -c "print 2"]') == "4" ' | ||||
| # | ||||
| # Returns nothing. | ||||
| test_expect_success() { | ||||
| 	test "$#" = 3 && { test_prereq=$1; shift; } || test_prereq= | ||||
| 	test "$#" = 2 || error "bug in the test script: not 2 or 3 parameters to test_expect_success" | ||||
| 	export test_prereq | ||||
| 	if ! test_skip_ "$@"; then | ||||
| 		say >&3 "expecting success: $2" | ||||
| 		if test_run_ "$2"; then | ||||
| 			test_ok_ "$1" | ||||
| 		else | ||||
| 			test_failure_ "$@" | ||||
| 		fi | ||||
| 	fi | ||||
| 	echo >&3 "" | ||||
| } | ||||
|  | ||||
| # Public: Run test commands and expect them to fail. Used to demonstrate a known | ||||
| # breakage. | ||||
| # | ||||
| # This is NOT the opposite of test_expect_success, but rather used to mark a | ||||
| # test that demonstrates a known breakage. | ||||
| # | ||||
| # When the test passed, an "ok" message is printed and the number of fixed tests | ||||
| # is incremented. When it failed, a "not ok" message is printed and the number | ||||
| # of tests still broken is incremented. | ||||
| # | ||||
| # Failures from these tests won't cause --immediate to stop. | ||||
| # | ||||
| # Usually takes two arguments: | ||||
| # $1 - Test description | ||||
| # $2 - Commands to be executed. | ||||
| # | ||||
| # With three arguments, the first will be taken to be a prerequisite: | ||||
| # $1 - Comma-separated list of test prerequisites. The test will be skipped if | ||||
| #      not all of the given prerequisites are set. To negate a prerequisite, | ||||
| #      put a "!" in front of it. | ||||
| # $2 - Test description | ||||
| # $3 - Commands to be executed. | ||||
| # | ||||
| # Returns nothing. | ||||
| test_expect_failure() { | ||||
| 	test "$#" = 3 && { test_prereq=$1; shift; } || test_prereq= | ||||
| 	test "$#" = 2 || error "bug in the test script: not 2 or 3 parameters to test_expect_failure" | ||||
| 	export test_prereq | ||||
| 	if ! test_skip_ "$@"; then | ||||
| 		say >&3 "checking known breakage: $2" | ||||
| 		if test_run_ "$2" expecting_failure; then | ||||
| 			test_known_broken_ok_ "$1" | ||||
| 		else | ||||
| 			test_known_broken_failure_ "$1" | ||||
| 		fi | ||||
| 	fi | ||||
| 	echo >&3 "" | ||||
| } | ||||
|  | ||||
| # Public: Run test commands and expect anything from them. Used when a | ||||
| # test is not stable or not finished for some reason. | ||||
| # | ||||
| # When the test passed, an "ok" message is printed, but the number of | ||||
| # fixed tests is not incremented. | ||||
| # | ||||
| # When it failed, a "not ok ... # TODO known breakage" message is | ||||
| # printed, and the number of tests still broken is incremented. | ||||
| # | ||||
| # Failures from these tests won't cause --immediate to stop. | ||||
| # | ||||
| # Usually takes two arguments: | ||||
| # $1 - Test description | ||||
| # $2 - Commands to be executed. | ||||
| # | ||||
| # With three arguments, the first will be taken to be a prerequisite: | ||||
| # $1 - Comma-separated list of test prerequisites. The test will be skipped if | ||||
| #      not all of the given prerequisites are set. To negate a prerequisite, | ||||
| #      put a "!" in front of it. | ||||
| # $2 - Test description | ||||
| # $3 - Commands to be executed. | ||||
| # | ||||
| # Returns nothing. | ||||
| test_expect_unstable() { | ||||
| 	test "$#" = 3 && { test_prereq=$1; shift; } || test_prereq= | ||||
| 	test "$#" = 2 || error "bug in the test script: not 2 or 3 parameters to test_expect_unstable" | ||||
| 	export test_prereq | ||||
| 	if ! test_skip_ "$@"; then | ||||
| 		say >&3 "checking unstable test: $2" | ||||
| 		if test_run_ "$2" unstable; then | ||||
| 			test_ok_ "$1" | ||||
| 		else | ||||
| 			test_known_broken_failure_ "$1" | ||||
| 		fi | ||||
| 	fi | ||||
| 	echo >&3 "" | ||||
| } | ||||
|  | ||||
| # Public: Run command and ensure that it fails in a controlled way. | ||||
| # | ||||
| # Use it instead of "! <command>". For example, when <command> dies due to a | ||||
| # segfault, test_must_fail diagnoses it as an error, while "! <command>" would | ||||
| # mistakenly be treated as just another expected failure. | ||||
| # | ||||
| # This is one of the prefix functions to be used inside test_expect_success or | ||||
| # test_expect_failure. | ||||
| # | ||||
| # $1.. - Command to be executed. | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   test_expect_success 'complain and die' ' | ||||
| #       do something && | ||||
| #       do something else && | ||||
| #       test_must_fail git checkout ../outerspace | ||||
| #   ' | ||||
| # | ||||
| # Returns 1 if the command succeeded (exit code 0). | ||||
| # Returns 1 if the command died by signal (exit codes 130-192) | ||||
| # Returns 1 if the command could not be found (exit code 127). | ||||
| # Returns 0 otherwise. | ||||
| test_must_fail() { | ||||
| 	"$@" | ||||
| 	exit_code=$? | ||||
| 	if test $exit_code = 0; then | ||||
| 		echo >&2 "test_must_fail: command succeeded: $*" | ||||
| 		return 1 | ||||
| 	elif test $exit_code -gt 129 -a $exit_code -le 192; then | ||||
| 		echo >&2 "test_must_fail: died by signal: $*" | ||||
| 		return 1 | ||||
| 	elif test $exit_code = 127; then | ||||
| 		echo >&2 "test_must_fail: command not found: $*" | ||||
| 		return 1 | ||||
| 	fi | ||||
| 	return 0 | ||||
| } | ||||
|  | ||||
| # Public: Run command and ensure that it succeeds or fails in a controlled way. | ||||
| # | ||||
| # Similar to test_must_fail, but tolerates success too. Use it instead of | ||||
| # "<command> || :" to catch failures caused by a segfault, for instance. | ||||
| # | ||||
| # This is one of the prefix functions to be used inside test_expect_success or | ||||
| # test_expect_failure. | ||||
| # | ||||
| # $1.. - Command to be executed. | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   test_expect_success 'some command works without configuration' ' | ||||
| #       test_might_fail git config --unset all.configuration && | ||||
| #       do something | ||||
| #   ' | ||||
| # | ||||
| # Returns 1 if the command died by signal (exit codes 130-192) | ||||
| # Returns 1 if the command could not be found (exit code 127). | ||||
| # Returns 0 otherwise. | ||||
| test_might_fail() { | ||||
| 	"$@" | ||||
| 	exit_code=$? | ||||
| 	if test $exit_code -gt 129 -a $exit_code -le 192; then | ||||
| 		echo >&2 "test_might_fail: died by signal: $*" | ||||
| 		return 1 | ||||
| 	elif test $exit_code = 127; then | ||||
| 		echo >&2 "test_might_fail: command not found: $*" | ||||
| 		return 1 | ||||
| 	fi | ||||
| 	return 0 | ||||
| } | ||||
|  | ||||
| # Public: Run command and ensure it exits with a given exit code. | ||||
| # | ||||
| # This is one of the prefix functions to be used inside test_expect_success or | ||||
| # test_expect_failure. | ||||
| # | ||||
| # $1   - Expected exit code. | ||||
| # $2.. - Command to be executed. | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   test_expect_success 'Merge with d/f conflicts' ' | ||||
| #       test_expect_code 1 git merge "merge msg" B master | ||||
| #   ' | ||||
| # | ||||
| # Returns 0 if the expected exit code is returned or 1 otherwise. | ||||
| test_expect_code() { | ||||
| 	want_code=$1 | ||||
| 	shift | ||||
| 	"$@" | ||||
| 	exit_code=$? | ||||
| 	if test "$exit_code" = "$want_code"; then | ||||
| 		return 0 | ||||
| 	fi | ||||
|  | ||||
| 	echo >&2 "test_expect_code: command exited with $exit_code, we wanted $want_code $*" | ||||
| 	return 1 | ||||
| } | ||||
|  | ||||
| # Public: Compare two files to see if expected output matches actual output. | ||||
| # | ||||
| # The TEST_CMP variable defines the command used for the comparison; it | ||||
| # defaults to "diff -u". Only when the test script was started with --verbose, | ||||
| # will the command's output, the diff, be printed to the standard output. | ||||
| # | ||||
| # This is one of the prefix functions to be used inside test_expect_success or | ||||
| # test_expect_failure. | ||||
| # | ||||
| # $1 - Path to file with expected output. | ||||
| # $2 - Path to file with actual output. | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   test_expect_success 'foo works' ' | ||||
| #       echo expected >expected && | ||||
| #       foo >actual && | ||||
| #       test_cmp expected actual | ||||
| #   ' | ||||
| # | ||||
| # Returns the exit code of the command set by TEST_CMP. | ||||
| test_cmp() { | ||||
| 	${TEST_CMP:-diff -u} "$@" | ||||
| } | ||||
|  | ||||
| # Public: portably print a sequence of numbers. | ||||
| # | ||||
| # seq is not in POSIX and GNU seq might not be available everywhere, | ||||
| # so it is nice to have a seq implementation, even a very simple one. | ||||
| # | ||||
| # $1 - Starting number. | ||||
| # $2 - Ending number. | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   test_expect_success 'foo works 10 times' ' | ||||
| #       for i in $(test_seq 1 10) | ||||
| #       do | ||||
| #           foo || return | ||||
| #       done | ||||
| #   ' | ||||
| # | ||||
| # Returns 0 if all the specified numbers can be displayed. | ||||
| test_seq() { | ||||
| 	i="$1" | ||||
| 	j="$2" | ||||
| 	while test "$i" -le "$j" | ||||
| 	do | ||||
| 		echo "$i" || return | ||||
| 		i=$(("$i" + 1)) | ||||
| 	done | ||||
| } | ||||
|  | ||||
| # Public: Check if the file expected to be empty is indeed empty, and barfs | ||||
| # otherwise. | ||||
| # | ||||
| # $1 - File to check for emptiness. | ||||
| # | ||||
| # Returns 0 if file is empty, 1 otherwise. | ||||
| test_must_be_empty() { | ||||
| 	if test -s "$1" | ||||
| 	then | ||||
| 		echo "'$1' is not empty, it contains:" | ||||
| 		cat "$1" | ||||
| 		return 1 | ||||
| 	fi | ||||
| } | ||||
|  | ||||
| # debugging-friendly alternatives to "test [-f|-d|-e]" | ||||
| # The commands test the existence or non-existence of $1. $2 can be | ||||
| # given to provide a more precise diagnosis. | ||||
| test_path_is_file () { | ||||
| 	if ! test -f "$1" | ||||
| 	then | ||||
| 		echo "File $1 doesn't exist. $2" | ||||
| 		false | ||||
| 	fi | ||||
| } | ||||
|  | ||||
| test_path_is_dir () { | ||||
| 	if ! test -d "$1" | ||||
| 	then | ||||
| 		echo "Directory $1 doesn't exist. $2" | ||||
| 		false | ||||
| 	fi | ||||
| } | ||||
|  | ||||
| # Check if the directory exists and is empty as expected, barf otherwise. | ||||
| test_dir_is_empty () { | ||||
| 	test_path_is_dir "$1" && | ||||
| 	if test -n "$(find "$1" -mindepth 1 -maxdepth 1)" | ||||
| 	then | ||||
| 		echo "Directory '$1' is not empty, it contains:" | ||||
| 		ls -la "$1" | ||||
| 		return 1 | ||||
| 	fi | ||||
| } | ||||
|  | ||||
| # Public: Schedule cleanup commands to be run unconditionally at the end of a | ||||
| # test. | ||||
| # | ||||
| # If some cleanup command fails, the test will not pass. With --immediate, no | ||||
| # cleanup is done to help diagnose what went wrong. | ||||
| # | ||||
| # This is one of the prefix functions to be used inside test_expect_success or | ||||
| # test_expect_failure. | ||||
| # | ||||
| # $1.. - Commands to prepend to the list of cleanup commands. | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   test_expect_success 'test core.capslock' ' | ||||
| #       git config core.capslock true && | ||||
| #       test_when_finished "git config --unset core.capslock" && | ||||
| #       do_something | ||||
| #   ' | ||||
| # | ||||
| # Returns the exit code of the last cleanup command executed. | ||||
| test_when_finished() { | ||||
| 	test_cleanup="{ $* | ||||
| 		} && (exit \"\$eval_ret\"); eval_ret=\$?; $test_cleanup" | ||||
| } | ||||
|  | ||||
| # Public: Schedule cleanup commands to be run unconditionally when all tests | ||||
| # have run. | ||||
| # | ||||
| # This can be used to clean up things like test databases. It is not needed to | ||||
| # clean up temporary files, as test_done already does that. | ||||
| # | ||||
| # Examples: | ||||
| # | ||||
| #   cleanup mysql -e "DROP DATABASE mytest" | ||||
| # | ||||
| # Returns the exit code of the last cleanup command executed. | ||||
| final_cleanup= | ||||
| cleanup() { | ||||
| 	final_cleanup="{ $* | ||||
| 		} && (exit \"\$eval_ret\"); eval_ret=\$?; $final_cleanup" | ||||
| } | ||||
|  | ||||
| # Public: Summarize test results and exit with an appropriate error code. | ||||
| # | ||||
| # Must be called at the end of each test script. | ||||
| # | ||||
| # Can also be used to stop tests early and skip all remaining tests. For this, | ||||
| # set skip_all to a string explaining why the tests were skipped before calling | ||||
| # test_done. | ||||
| # | ||||
| # Examples | ||||
| # | ||||
| #   # Each test script must call test_done at the end. | ||||
| #   test_done | ||||
| # | ||||
| #   # Skip all remaining tests if prerequisite is not set. | ||||
| #   if ! test_have_prereq PERL; then | ||||
| #       skip_all='skipping perl interface tests, perl not available' | ||||
| #       test_done | ||||
| #   fi | ||||
| # | ||||
| # Returns 0 if all tests passed or 1 if there was a failure. | ||||
| test_done() { | ||||
| 	EXIT_OK=t | ||||
|  | ||||
| 	if test -z "$HARNESS_ACTIVE"; then | ||||
| 		test_results_dir="$SHARNESS_TEST_OUTPUT_DIRECTORY/test-results" | ||||
| 		mkdir -p "$test_results_dir" | ||||
| 		test_results_path="$test_results_dir/$this_test.$$.counts" | ||||
|  | ||||
| 		cat >>"$test_results_path" <<-EOF | ||||
| 		total $test_count | ||||
| 		success $test_success | ||||
| 		fixed $test_fixed | ||||
| 		broken $test_broken | ||||
| 		failed $test_failure | ||||
|  | ||||
| 		EOF | ||||
| 	fi | ||||
|  | ||||
| 	if test "$test_fixed" != 0; then | ||||
| 		say_color error "# $test_fixed known breakage(s) vanished; please update test(s)" | ||||
| 	fi | ||||
| 	if test "$test_broken" != 0; then | ||||
| 		say_color warn "# still have $test_broken known breakage(s)" | ||||
| 	fi | ||||
| 	if test "$test_broken" != 0 || test "$test_fixed" != 0; then | ||||
| 		test_remaining=$((test_count - test_broken - test_fixed)) | ||||
| 		msg="remaining $test_remaining test(s)" | ||||
| 	else | ||||
| 		test_remaining=$test_count | ||||
| 		msg="$test_count test(s)" | ||||
| 	fi | ||||
|  | ||||
| 	case "$test_failure" in | ||||
| 	0) | ||||
| 		# Maybe print SKIP message | ||||
| 		if test -n "$skip_all" && test $test_count -gt 0; then | ||||
| 			error "Can't use skip_all after running some tests" | ||||
| 		fi | ||||
| 		[ -z "$skip_all" ] || skip_all=" # SKIP $skip_all" | ||||
|  | ||||
| 		if test $test_remaining -gt 0; then | ||||
| 			say_color pass "# passed all $msg" | ||||
| 		fi | ||||
| 		say "1..$test_count$skip_all" | ||||
|  | ||||
| 		test_eval_ "$final_cleanup" | ||||
|  | ||||
| 		test -d "$remove_trash" && | ||||
| 		cd "$(dirname "$remove_trash")" && | ||||
| 		rm -rf "$(basename "$remove_trash")" | ||||
|  | ||||
| 		exit 0 ;; | ||||
|  | ||||
| 	*) | ||||
| 		say_color error "# failed $test_failure among $msg" | ||||
| 		say "1..$test_count" | ||||
|  | ||||
| 		exit 1 ;; | ||||
|  | ||||
| 	esac | ||||
| } | ||||
|  | ||||
| # Public: Source directory of test code and sharness library. | ||||
| # This directory may be different from the directory in which tests are | ||||
| # being run. | ||||
| : "${SHARNESS_TEST_SRCDIR:=$(cd "$(dirname "$0")" && pwd)}" | ||||
| export SHARNESS_TEST_SRCDIR | ||||
|  | ||||
| # Public: Build directory that will be added to PATH. By default, it is set to | ||||
| # the parent directory of SHARNESS_TEST_DIRECTORY. | ||||
| : "${SHARNESS_BUILD_DIRECTORY:="$SHARNESS_TEST_DIRECTORY/.."}" | ||||
| PATH="$SHARNESS_BUILD_DIRECTORY:$PATH" | ||||
| export PATH SHARNESS_BUILD_DIRECTORY | ||||
|  | ||||
| # Public: Path to test script currently executed. | ||||
| SHARNESS_TEST_FILE="$0" | ||||
| export SHARNESS_TEST_FILE | ||||
|  | ||||
| # Prepare test area. | ||||
| SHARNESS_TRASH_DIRECTORY="trash directory.$(basename "$SHARNESS_TEST_FILE" ".$SHARNESS_TEST_EXTENSION")" | ||||
| test -n "$root" && SHARNESS_TRASH_DIRECTORY="$root/$SHARNESS_TRASH_DIRECTORY" | ||||
| case "$SHARNESS_TRASH_DIRECTORY" in | ||||
| /*) ;; # absolute path is good | ||||
|  *) SHARNESS_TRASH_DIRECTORY="$SHARNESS_TEST_OUTPUT_DIRECTORY/$SHARNESS_TRASH_DIRECTORY" ;; | ||||
| esac | ||||
| test "$debug" = "t" || remove_trash="$SHARNESS_TRASH_DIRECTORY" | ||||
| rm -rf "$SHARNESS_TRASH_DIRECTORY" || { | ||||
| 	EXIT_OK=t | ||||
| 	echo >&5 "FATAL: Cannot prepare test area" | ||||
| 	exit 1 | ||||
| } | ||||
|  | ||||
|  | ||||
| # | ||||
| #  Load any extensions in $srcdir/sharness.d/*.sh | ||||
| # | ||||
| if test -d "${SHARNESS_TEST_SRCDIR}/sharness.d" | ||||
| then | ||||
| 	for file in "${SHARNESS_TEST_SRCDIR}"/sharness.d/*.sh | ||||
| 	do | ||||
| 		# Ensure glob was not an empty match: | ||||
| 		test -e "${file}" || break | ||||
|  | ||||
| 		if test -n "$debug" | ||||
| 		then | ||||
| 			echo >&5 "sharness: loading extensions from ${file}" | ||||
| 		fi | ||||
| 		. "${file}" | ||||
| 		if test $? != 0 | ||||
| 		then | ||||
| 			echo >&5 "sharness: Error loading ${file}. Aborting." | ||||
| 			exit 1 | ||||
| 		fi | ||||
| 	done | ||||
| fi | ||||
|  | ||||
| # Public: Empty trash directory, the test area, provided for each test. The HOME | ||||
| # variable is set to that directory too. | ||||
| export SHARNESS_TRASH_DIRECTORY | ||||
|  | ||||
| HOME="$SHARNESS_TRASH_DIRECTORY" | ||||
| export HOME | ||||
|  | ||||
| mkdir -p "$SHARNESS_TRASH_DIRECTORY" || exit 1 | ||||
| # Use -P to resolve symlinks in our working directory so that the cwd | ||||
| # in subprocesses like git equals our $PWD (for pathname comparisons). | ||||
| cd -P "$SHARNESS_TRASH_DIRECTORY" || exit 1 | ||||
|  | ||||
| this_test=${SHARNESS_TEST_FILE##*/} | ||||
| this_test=${this_test%.$SHARNESS_TEST_EXTENSION} | ||||
| for skp in $SKIP_TESTS; do | ||||
| 	case "$this_test" in | ||||
| 	$skp) | ||||
| 		say_color info >&3 "skipping test $this_test altogether" | ||||
| 		skip_all="skip all tests in $this_test" | ||||
| 		test_done | ||||
| 	esac | ||||
| done | ||||
|  | ||||
| test -n "$TEST_LONG" && test_set_prereq EXPENSIVE | ||||
| test -n "$TEST_INTERACTIVE" && test_set_prereq INTERACTIVE | ||||
|  | ||||
| # Make sure this script ends with code 0 | ||||
| : | ||||
|  | ||||
| # vi: set ts=4 sw=4 noet : | ||||
							
								
								
									
										23
									
								
								t/test-lib.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								t/test-lib.sh
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| #!/bin/bash | ||||
|  | ||||
| : "${SHARNESS_TEST_SRCDIR:=$(cd "$(dirname "${BASH_SOURCE-$0}")" && pwd)}" | ||||
| . "$SHARNESS_TEST_SRCDIR"/sharness.sh | ||||
|  | ||||
| if ! python -c 'import mercurial' > /dev/null 2>&1 | ||||
| then | ||||
| 	error 'mercurial not available' | ||||
| fi | ||||
|  | ||||
| GIT_AUTHOR_EMAIL=author@example.com | ||||
| GIT_AUTHOR_NAME='A U Thor' | ||||
| GIT_COMMITTER_EMAIL=committer@example.com | ||||
| GIT_COMMITTER_NAME='C O Mitter' | ||||
| export GIT_AUTHOR_EMAIL GIT_AUTHOR_NAME | ||||
| export GIT_COMMITTER_EMAIL GIT_COMMITTER_NAME | ||||
|  | ||||
| unset XDG_CONFIG_HOME | ||||
|  | ||||
| if [[ $(uname -s) = MSYS* ]]; then | ||||
| 	test_set_prereq WIN | ||||
| 	export TEST_CMP='diff --strip-trailing-cr -u' | ||||
| fi | ||||
		Reference in New Issue
	
	Block a user