Re: [PATCH] tests: fix autostash
On Fri, Jun 7, 2013 at 10:29 PM, Ramkumar Ramachandra artag...@gmail.com wrote: Felipe Contreras wrote: diff --git a/t/t3420-rebase-autostash.sh b/t/t3420-rebase-autostash.sh index a5e69f3..ff370a3 100755 --- a/t/t3420-rebase-autostash.sh +++ b/t/t3420-rebase-autostash.sh @@ -71,8 +71,7 @@ testrebase() { test_must_fail git rebase$type related-onto-branch test_path_is_file $dotest/autostash ! grep dirty file3 - rm -rf $dotest - git reset --hard + git rebase --abort git checkout feature-branch ' Incorrect. I don't assume that --abort works yet, in this test. Yes you do. The rest of the tests expect that the previous rebase has been aborted. In fact, all the tests depend on the previous test finishing correctly, which is not the way tests should be written. --- a/t/t3420-rebase-autostash.sh +++ b/t/t3420-rebase-autostash.sh @@ -70,7 +70,7 @@ testrebase() { echo dirty file3 test_must_fail git rebase$type related-onto-branch test_path_is_file $dotest/autostash - ! grep dirty file3 + false ! grep dirty file3 rm -rf $dotest git reset --hard git checkout feature-branch # failed 19 among 22 test(s) Doing 'rm -rf $dotest' is even worst than 'git rebase --abort', because it relies on the implementation of 'git rebase', which might need to remove more files than $dotest. This wouldn't be a problem if the tests were implemented correctly, but they are not, so 'git rebase --abort' is the only sane option. -- Felipe Contreras -- To unsubscribe from this list: send the line unsubscribe git in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Re: [PATCH] tests: fix autostash
Felipe Contreras wrote: Yes you do. The rest of the tests expect that the previous rebase has been aborted. In fact, all the tests depend on the previous test finishing correctly, which is not the way tests should be written. How else am I supposed to write them? If there is a stale state from the previous test, there isn't too much I can do. Or should I be cleaning up state at the beginning of each test, instead of at the end? Doing 'rm -rf $dotest' is even worst than 'git rebase --abort', because it relies on the implementation of 'git rebase', which might need to remove more files than $dotest. Huh? Tests aren't allowed to rely on how a command is implemented? $ git grep test_path t Ofcourse they're implementation details. Even in this very test, I check $dotest/autostash plenty of times. Have you read rr/rebase-autostash? The whole idea is to inject $dotest/autostash and teach various scripts about how their assumptions about $dotest have changed. This wouldn't be a problem if the tests were implemented correctly, but they are not, so 'git rebase --abort' is the only sane option. Then show me how to do it correctly. -- To unsubscribe from this list: send the line unsubscribe git in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Re: [PATCH] tests: fix autostash
On Sat, Jun 8, 2013 at 8:19 AM, Ramkumar Ramachandra artag...@gmail.com wrote: Felipe Contreras wrote: Doing 'rm -rf $dotest' is even worst than 'git rebase --abort', because it relies on the implementation of 'git rebase', which might need to remove more files than $dotest. Huh? Tests aren't allowed to rely on how a command is implemented? $ git grep test_path t Ofcourse they're implementation details. Even in this very test, I check $dotest/autostash plenty of times. The more the test relies on implementation details, the worst. Have you read rr/rebase-autostash? The whole idea is to inject $dotest/autostash and teach various scripts about how their assumptions about $dotest have changed. This wouldn't be a problem if the tests were implemented correctly, but they are not, so 'git rebase --abort' is the only sane option. Then show me how to do it correctly. Something like this. diff --git a/t/t3420-rebase-autostash.sh b/t/t3420-rebase-autostash.sh index 6ba449b..b96a56a 100755 --- a/t/t3420-rebase-autostash.sh +++ b/t/t3420-rebase-autostash.sh @@ -33,54 +33,56 @@ test_expect_success setup ' git commit -m related commit ' +setup_tmp () { + git clone . tmp + cd tmp + git fetch -u origin refs/heads/*:refs/heads/* + test_config rebase.autostash true + git checkout -b rebased-feature-branch feature-branch +} + testrebase() { type=$1 dotest=$2 test_expect_success rebase$type: dirty worktree, non-conflicting rebase ' - test_config rebase.autostash true - git reset --hard - git checkout -b rebased-feature-branch feature-branch - test_when_finished git branch -D rebased-feature-branch + test_when_finished rm -rf tmp + ( + setup_tmp echo dirty file3 git rebase$type unrelated-onto-branch grep unrelated file4 - grep dirty file3 - git checkout feature-branch + grep dirty file3 + ) ' test_expect_success rebase$type: dirty index, non-conflicting rebase ' - test_config rebase.autostash true - git reset --hard - git checkout -b rebased-feature-branch feature-branch - test_when_finished git branch -D rebased-feature-branch + test_when_finished rm -rf tmp + ( + setup_tmp echo dirty file3 git add file3 git rebase$type unrelated-onto-branch grep unrelated file4 - grep dirty file3 - git checkout feature-branch + grep dirty file3 + ) ' test_expect_success rebase$type: conflicting rebase ' - test_config rebase.autostash true - git reset --hard - git checkout -b rebased-feature-branch feature-branch - test_when_finished git branch -D rebased-feature-branch + test_when_finished rm -rf tmp + ( + setup_tmp echo dirty file3 test_must_fail git rebase$type related-onto-branch test_path_is_file $dotest/autostash - false ! grep dirty file3 - rm -rf $dotest - git reset --hard - git checkout feature-branch + ! grep dirty file3 + ) ' test_expect_success rebase$type: --continue ' - test_config rebase.autostash true - git reset --hard - git checkout -b rebased-feature-branch feature-branch - test_when_finished git branch -D rebased-feature-branch + test_when_finished rm -rf tmp + ( + setup_tmp echo dirty file3 test_must_fail git rebase$type related-onto-branch test_path_is_file $dotest/autostash @@ -89,45 +91,43 @@ testrebase() { git add file2 git rebase --continue test_path_is_missing $dotest/autostash - grep dirty file3 - git checkout feature-branch + grep dirty file3 + ) ' test_expect_success rebase$type: --skip ' - test_config rebase.autostash true + test_when_finished rm -rf tmp + ( + setup_tmp git reset --hard - git checkout -b rebased-feature-branch feature-branch - test_when_finished git branch -D rebased-feature-branch echo dirty file3 test_must_fail git rebase$type related-onto-branch test_path_is_file $dotest/autostash ! grep dirty file3 git rebase
Re: [PATCH] tests: fix autostash
Felipe Contreras wrote: Ofcourse they're implementation details. Even in this very test, I check $dotest/autostash plenty of times. The more the test relies on implementation details, the worst. I'm not convinced about this. Then show me how to do it correctly. Something like this. Yeah, this is definitely better. Can you submit this patch? -- To unsubscribe from this list: send the line unsubscribe git in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Re: [PATCH] tests: fix autostash
On Sat, Jun 8, 2013 at 9:04 AM, Ramkumar Ramachandra artag...@gmail.com wrote: Felipe Contreras wrote: Ofcourse they're implementation details. Even in this very test, I check $dotest/autostash plenty of times. The more the test relies on implementation details, the worst. I'm not convinced about this. There's even a model called test-driven development, where you start developing the tests even before there's any implementation. There's also black-box testing. There's reasons for that. Then show me how to do it correctly. Something like this. Yeah, this is definitely better. Can you submit this patch? Maybe, I don't know when. -- Felipe Contreras -- To unsubscribe from this list: send the line unsubscribe git in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Re: [PATCH] tests: fix autostash
On Sat, Jun 8, 2013 at 4:04 PM, Ramkumar Ramachandra artag...@gmail.com wrote: Felipe Contreras wrote: Ofcourse they're implementation details. Even in this very test, I check $dotest/autostash plenty of times. The more the test relies on implementation details, the worst. I'm not convinced about this. My understanding of these tests is that they make sure new/better implementations don't break the user experience/defined behavior. If the test relies on the implementation, then they lose most of their interest. -- To unsubscribe from this list: send the line unsubscribe git in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Re: [PATCH] tests: fix autostash
Antoine Pelisse wrote: The more the test relies on implementation details, the worst. I'm not convinced about this. My understanding of these tests is that they make sure new/better implementations don't break the user experience/defined behavior. If the test relies on the implementation, then they lose most of their interest. Makes sense, thanks. -- To unsubscribe from this list: send the line unsubscribe git in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Re: [PATCH] tests: fix autostash
Ramkumar Ramachandra wrote: How else am I supposed to write them? If there is a stale state from the previous test, there isn't too much I can do. Or should I be cleaning up state at the beginning of each test, instead of at the end? That's one strategy. test_when_finished to restore the set-up state is another. Making tests skippable unless labelled otherwise is currently an aspirational goal rather than a practical one. Hopefully some day we'll get there and the test harness can start checking it. :) It makes reorganizing test scripts, for example by reordering tests, much easier. Thanks, Jonathan -- To unsubscribe from this list: send the line unsubscribe git in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
[PATCH] tests: fix autostash
We should call 'git rebase --abort', like a normal user would do. Signed-off-by: Felipe Contreras felipe.contre...@gmail.com --- t/t3420-rebase-autostash.sh | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/t/t3420-rebase-autostash.sh b/t/t3420-rebase-autostash.sh index a5e69f3..ff370a3 100755 --- a/t/t3420-rebase-autostash.sh +++ b/t/t3420-rebase-autostash.sh @@ -71,8 +71,7 @@ testrebase() { test_must_fail git rebase$type related-onto-branch test_path_is_file $dotest/autostash ! grep dirty file3 - rm -rf $dotest - git reset --hard + git rebase --abort git checkout feature-branch ' -- 1.8.3.698.g079b096 -- To unsubscribe from this list: send the line unsubscribe git in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Re: [PATCH] tests: fix autostash
Felipe Contreras wrote: diff --git a/t/t3420-rebase-autostash.sh b/t/t3420-rebase-autostash.sh index a5e69f3..ff370a3 100755 --- a/t/t3420-rebase-autostash.sh +++ b/t/t3420-rebase-autostash.sh @@ -71,8 +71,7 @@ testrebase() { test_must_fail git rebase$type related-onto-branch test_path_is_file $dotest/autostash ! grep dirty file3 - rm -rf $dotest - git reset --hard + git rebase --abort git checkout feature-branch ' Incorrect. I don't assume that --abort works yet, in this test. It is non-trivial to get --abort to work with autostash, and this is tested in a separate test: see rebase$type: --abort in the same file. -- To unsubscribe from this list: send the line unsubscribe git in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html