From b0dfbed363d50007959707f9f3fd058e8f67ac2e Mon Sep 17 00:00:00 2001 Message-Id: From: Mark Wooding Date: Thu, 9 Aug 2007 22:46:10 +0200 Subject: [PATCH] Test the new powers of "stg assimilate" MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit Organization: Straylight/Edgeware From: Karl Hasselström Signed-off-by: Karl Hasselström --- t/t1302-assimilate-interop.sh | 59 +++++++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100755 t/t1302-assimilate-interop.sh diff --git a/t/t1302-assimilate-interop.sh b/t/t1302-assimilate-interop.sh new file mode 100755 index 0000000..31f8b78 --- /dev/null +++ b/t/t1302-assimilate-interop.sh @@ -0,0 +1,59 @@ +#!/bin/sh +test_description='Test git/StGit interoperability with "stg assimilate"' +. ./test-lib.sh + +test_expect_success 'Create some git-only history' ' + echo foo > foo.txt && + git add foo.txt && + git commit -a -m foo && + git tag foo-tag && + for i in 0 1 2 3 4; do + echo foo$i >> foo.txt && + git commit -a -m foo$i; + done +' + +test_expect_success 'Initialize the StGit repository' ' + stg init +' + +test_expect_success 'Create five patches' ' + for i in 0 1 2 3 4; do + stg new p$i -m p$i; + done && + [ "$(echo $(stg applied))" = "p0 p1 p2 p3 p4" ] && + [ "$(echo $(stg unapplied))" = "" ] +' + +test_expect_success 'Pop two patches with git-reset' ' + git reset --hard HEAD~2 && + ! stg refresh && + stg assimilate && + stg refresh && + [ "$(echo $(stg applied))" = "p0 p1 p2" ] && + [ "$(echo $(stg unapplied))" = "p3 p4" ] +' + +test_expect_success 'Create a new patch' ' + stg new q0 -m q0 && + [ "$(echo $(stg applied))" = "p0 p1 p2 q0" ] && + [ "$(echo $(stg unapplied))" = "p3 p4" ] +' + +test_expect_success 'Go to an unapplied patch with with git-reset' ' + git reset --hard $(stg id p3) && + ! stg refresh && + stg assimilate && + stg refresh && + [ "$(echo $(stg applied))" = "p0 p1 p2 p3" ] && + [ "$(echo $(stg unapplied))" = "q0 p4" ] +' + +test_expect_success 'Go back to below the stack base with git-reset' ' + git reset --hard foo-tag && + stg assimilate && + [ "$(echo $(stg applied))" = "" ] && + [ "$(echo $(stg unapplied))" = "p0 p1 p2 p3 q0 p4" ] +' + +test_done -- [mdw]