* [NEW REPLACEMENT PATCH] git-checkout: Add a test case for relative paths use.
@ 2007-11-08 13:13 David Symonds
2007-11-08 14:32 ` Johannes Schindelin
0 siblings, 1 reply; 4+ messages in thread
From: David Symonds @ 2007-11-08 13:13 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git, Johannes Schindelin, Andreas Ericsson, David Symonds
Signed-off-by: David Symonds <dsymonds@gmail.com>
---
t/t2008-checkout-subdir.sh | 47 ++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 47 insertions(+), 0 deletions(-)
create mode 100755 t/t2008-checkout-subdir.sh
diff --git a/t/t2008-checkout-subdir.sh b/t/t2008-checkout-subdir.sh
new file mode 100755
index 0000000..45b9e13
--- /dev/null
+++ b/t/t2008-checkout-subdir.sh
@@ -0,0 +1,47 @@
+#!/bin/sh
+#
+# Copyright (c) 2007 David Symonds
+
+test_description='git checkout from subdirectories'
+
+. ./test-lib.sh
+
+test_expect_success setup '
+
+ echo base > file0 &&
+ git add file0 &&
+ mkdir dir1 &&
+ echo hello > dir1/file1 &&
+ git add dir1/file1 &&
+ test_tick &&
+ mkdir dir2 &&
+ echo bonjour > dir2/file2 &&
+ git add dir2/file2 &&
+ git commit -m "populate tree"
+
+'
+
+test_expect_success 'remove and restore with relative path' '
+
+ cd dir1 &&
+ rm ../file0 &&
+ git checkout HEAD -- ../file0 && test -f ../file0 &&
+ rm ../dir2/file2 &&
+ git checkout HEAD -- ../dir2/file2 && test -f ../dir2/file2 &&
+ rm ../file0 ./file1 &&
+ git checkout HEAD -- .. && test -f ../file0 && test -f ./file1 &&
+ rm file1 &&
+ git checkout HEAD -- ../dir1/../dir1/file1 && test -f ./file1
+
+'
+
+test_expect_failure 'checkout with relative path outside tree should fail (1)' \
+ 'git checkout HEAD -- ../file0'
+
+test_expect_failure 'checkout with relative path outside tree should fail (2)' \
+ 'cd dir1 && git checkout HEAD -- ./file0'
+
+test_expect_failure 'checkout with relative path outside tree should fail (2)' \
+ 'cd dir1 && git checkout HEAD -- ../../file0'
+
+test_done
--
1.5.3.1
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [NEW REPLACEMENT PATCH] git-checkout: Add a test case for relative paths use.
2007-11-08 13:13 [NEW REPLACEMENT PATCH] git-checkout: Add a test case for relative paths use David Symonds
@ 2007-11-08 14:32 ` Johannes Schindelin
2007-11-08 20:48 ` Junio C Hamano
0 siblings, 1 reply; 4+ messages in thread
From: Johannes Schindelin @ 2007-11-08 14:32 UTC (permalink / raw)
To: David Symonds; +Cc: Junio C Hamano, git, Andreas Ericsson
Hi,
just a few nitpicks:
On Fri, 9 Nov 2007, David Symonds wrote:
> +test_expect_success setup '
> +
> + echo base > file0 &&
> + git add file0 &&
> + mkdir dir1 &&
> + echo hello > dir1/file1 &&
> + git add dir1/file1 &&
> + test_tick &&
please move the test_tick directly in front of the commit. Readers might
assume that it has an effect on mkdir otherwise.
> + mkdir dir2 &&
> + echo bonjour > dir2/file2 &&
> + git add dir2/file2 &&
> + git commit -m "populate tree"
> +
> +'
Please lose the empty line before the closing quote. (This applies to all
tests.)
> +test_expect_success 'remove and restore with relative path' '
> +
> + cd dir1 &&
> + rm ../file0 &&
> + git checkout HEAD -- ../file0 && test -f ../file0 &&
> + rm ../dir2/file2 &&
> + git checkout HEAD -- ../dir2/file2 && test -f ../dir2/file2 &&
> + rm ../file0 ./file1 &&
> + git checkout HEAD -- .. && test -f ../file0 && test -f ./file1 &&
> + rm file1 &&
> + git checkout HEAD -- ../dir1/../dir1/file1 && test -f ./file1
> +
> +'
> +
> +test_expect_failure 'checkout with relative path outside tree should fail (1)' \
> + 'git checkout HEAD -- ../file0'
Maybe do that with an existing file? Since the test script lives in t/,
and the test is run in t/trash/, we can test for "../Makefile".
Also, I would shorten the message to "relative path outside tree should
fail".
> +test_expect_failure 'checkout with relative path outside tree should fail (2)' \
> + 'cd dir1 && git checkout HEAD -- ./file0'
I am not convinced that this should fail.
> +test_expect_failure 'checkout with relative path outside tree should fail (2)' \
> + 'cd dir1 && git checkout HEAD -- ../../file0'
Please add some other test like
test_expect_success 'checkout with empty prefix' '
rm file0 &&
git checkout HEAD -- file0 &&
test base = "$(cat file0)"
'
Thanks,
Dscho
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [NEW REPLACEMENT PATCH] git-checkout: Add a test case for relative paths use.
2007-11-08 14:32 ` Johannes Schindelin
@ 2007-11-08 20:48 ` Junio C Hamano
2007-11-08 23:04 ` Johannes Schindelin
0 siblings, 1 reply; 4+ messages in thread
From: Junio C Hamano @ 2007-11-08 20:48 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: David Symonds, git, Andreas Ericsson
Johannes Schindelin <Johannes.Schindelin@gmx.de> writes:
>> + mkdir dir2 &&
>> + echo bonjour > dir2/file2 &&
>> + git add dir2/file2 &&
>> + git commit -m "populate tree"
>> +
>> +'
>
> Please lose the empty line before the closing quote. (This applies to all
> tests.)
I personaly find the extra blank lines before and after the
indented test body easier to read. That is..
test_expect_sucess 'test description comes here' '
test command 1 &&
test command 2 &&
...
test command N
'
I agree with all other suggestions from your message.
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [NEW REPLACEMENT PATCH] git-checkout: Add a test case for relative paths use.
2007-11-08 20:48 ` Junio C Hamano
@ 2007-11-08 23:04 ` Johannes Schindelin
0 siblings, 0 replies; 4+ messages in thread
From: Johannes Schindelin @ 2007-11-08 23:04 UTC (permalink / raw)
To: Junio C Hamano; +Cc: David Symonds, git, Andreas Ericsson
Hi,
On Thu, 8 Nov 2007, Junio C Hamano wrote:
> Johannes Schindelin <Johannes.Schindelin@gmx.de> writes:
>
> >> + mkdir dir2 &&
> >> + echo bonjour > dir2/file2 &&
> >> + git add dir2/file2 &&
> >> + git commit -m "populate tree"
> >> +
> >> +'
> >
> > Please lose the empty line before the closing quote. (This applies to all
> > tests.)
>
> I personaly find the extra blank lines before and after the
> indented test body easier to read.
Personally, I don't. But you are the maintainer.
Ciao,
Dscho
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2007-11-08 23:33 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-11-08 13:13 [NEW REPLACEMENT PATCH] git-checkout: Add a test case for relative paths use David Symonds
2007-11-08 14:32 ` Johannes Schindelin
2007-11-08 20:48 ` Junio C Hamano
2007-11-08 23:04 ` Johannes Schindelin
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).