From: Jeff Sipek <jeffpc@josefsipek.net>
To: Per Cederqvist <cederp@opera.com>
Cc: git@vger.kernel.org
Subject: Re: [GUILT 07/28] Added test cases for "guilt fold".
Date: Tue, 6 May 2014 15:40:26 -0400 [thread overview]
Message-ID: <20140506194026.GK1655@meili.valhalla.31bits.net> (raw)
In-Reply-To: <1395387126-13681-8-git-send-email-cederp@opera.com>
On Fri, Mar 21, 2014 at 08:31:45AM +0100, Per Cederqvist wrote:
> Test that we can combine any combination of patches with empty and
> non-empty messages, both with and without guilt.diffstat. (All
> patches are empty.)
I feel like we should have *some* content there - most of the time, I care
more about the diffs getting folded than the commit message :)
> Signed-off-by: Per Cederqvist <cederp@opera.com>
> ---
> regression/t-035.out | 659 +++++++++++++++++++++++++++++++++++++++++++++++++++
> regression/t-035.sh | 88 +++++++
> 2 files changed, 747 insertions(+)
> create mode 100644 regression/t-035.out
> create mode 100755 regression/t-035.sh
>
> diff --git a/regression/t-035.out b/regression/t-035.out
> new file mode 100644
> index 0000000..04af146
> --- /dev/null
> +++ b/regression/t-035.out
> @@ -0,0 +1,659 @@
> +% setup_repo
> +% git config guilt.diffstat true
> +%% empty + empty (diffstat=true)
> +% guilt new empty-1
> +% guilt pop
> +All patches popped.
> +% guilt push
> +Applying patch..empty-1
> +Patch applied.
> +% guilt new empty-2
> +% guilt pop
> +Now at empty-1.
> +% guilt push
> +Applying patch..empty-2
> +Patch applied.
> +% guilt pop
> +Now at empty-1.
> +% guilt fold empty-2
> +% guilt pop
> +All patches popped.
> +% guilt push
> +Applying patch..empty-1
> +Patch applied.
> +% list_files
> +d .git/patches
> +d .git/patches/master
> +d .git/refs/patches
> +d .git/refs/patches/master
> +f 22930c6d1f1938f298a4fca51c57e4b47171db21 .git/patches/master/mode
> +f 413390f3906f16f30b054a4fb86c1e014b964504 .git/patches/master/remove
> +f 4ea806e306f0228a8ef41f186035e7b04097f1f2 .git/patches/master/status
> +f 7d261b8caad0f161c21daf5de65eeb521ff8c067 .git/patches/master/empty-1
> +f 9c18cc7abe6b87f18503714a80a677b4094eb457 .git/patches/master/add
> +f bc9ab2e0f5db99d483961e956e814d963f0309f8 .git/patches/master/modify
> +f d28d87b88c1e24d637e390dc3603cfa7c1715711 .git/patches/master/series
> +f da39a3ee5e6b4b0d3255bfef95601890afd80709 .git/patches/master/empty-1~
> +f da39a3ee5e6b4b0d3255bfef95601890afd80709 .git/patches/master/empty-2~
> +r bde3d337af70f36836ad606c800d194006f883b3 .git/refs/patches/master/empty-1
> +% git log -p
Strictly speaking, git log isn't necessary since list_files prints the
hashes of each of the files as well as the refs for all the applied patches.
If anything mismatches, the hashes will catch it. I'm ok with keeping the
git log here as long as people can't mess up the formatting with git
config/etc.
...
> diff --git a/regression/t-035.sh b/regression/t-035.sh
> new file mode 100755
> index 0000000..aed3ef2
> --- /dev/null
> +++ b/regression/t-035.sh
> @@ -0,0 +1,88 @@
> +#!/bin/bash
> +#
> +# Test the fold code
> +#
> +
> +source "$REG_DIR/scaffold"
> +
> +cmd setup_repo
> +
> +function fixup_time_info
> +{
> + cmd guilt pop
> + touch -a -m -t "$TOUCH_DATE" ".git/patches/master/$1"
> + cmd guilt push
> +}
> +
> +function test_fold
> +{
> + using_diffstat=$1
> +
> + cmd git config guilt.diffstat $using_diffstat
> +
> + # Empty message + empty message = empty message.
> + echo "%% empty + empty (diffstat=$using_diffstat)"
> + cmd guilt new empty-1
> + fixup_time_info empty-1
> + cmd guilt new empty-2
> + fixup_time_info empty-2
> + cmd guilt pop
> + cmd guilt fold empty-2
> + fixup_time_info empty-1
> + cmd list_files
> + cmd git log -p
> + cmd guilt pop
> + cmd guilt delete -f empty-1
> + cmd list_files
> +
> + # Empty message + non-empty message
> + echo "%% empty + non-empty (diffstat=$using_diffstat)"
> + cmd guilt new empty
> + fixup_time_info empty
> + cmd echo test > a
I see these redirected echos... what are they for?
> + cmd guilt new -f -s -m "A commit message." non-empty
> + fixup_time_info non-empty
> + cmd guilt pop
> + cmd guilt fold non-empty
> + fixup_time_info empty
> + cmd list_files
> + cmd git log -p
> + cmd guilt pop
> + cmd guilt delete -f empty
> + cmd list_files
Maybe make two helper functions.. one to make a patch with an empty message
and one to make a patch with a non-empty message. Then each of these blocks
would look a bit cleaner.
echo "%% empty + non-empty (diffstat=$using_diffstat)"
empty_patch empty
nonempty_patch non-empty
cmd guilt pop non-empty
cmd guilt fold non-empty
fixup_time_info empty
cmd list_files
cleanup empty
cmd list_files
cleanup()
{
guilt pop $1
guilt delete -f $1
}
Eh, it's not as clean as I thought it would be, but I think it's still a
bit better. Ok, how about:
for using_diffstat in true false ; do
for patcha in empty nonempty ; do
for patchb in empty nonempty ; do
echo "%% $patcha + $patchb (diffstat=$using_diffstat)"
${patcha}_patch $patcha
${patchb}_patch $patchb
cmd guilt pop $patchb
cmd guilt fold $patchb
fixup_time_info $patcha
cmd list_files
cleanup $patcha
cmd list_files
done
done
done
Aha! That's better, IMO.
Adding the non-empty diff is a matter of another loop, but I'm ok with just
testing the headers (for now) :)
Jeff.
--
I abhor a system designed for the "user", if that word is a coded pejorative
meaning "stupid and unsophisticated."
- Ken Thompson
next prev parent reply other threads:[~2014-05-06 19:40 UTC|newest]
Thread overview: 61+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-03-21 7:31 [GUILT 00/28] Teach guilt import-commit how create legal patch names, and more Per Cederqvist
2014-03-21 7:31 ` [GUILT 01/28] The tests should not fail if guilt.diffstat is set Per Cederqvist
2014-03-21 7:31 ` [GUILT 02/28] Allow "guilt delete -f" to run from a dir which contains spaces Per Cederqvist
2014-03-21 7:31 ` [GUILT 03/28] Added test case for "guilt delete -f" Per Cederqvist
2014-03-21 7:31 ` [GUILT 04/28] Allow "guilt import-commit" to run from a dir which contains spaces Per Cederqvist
2014-03-23 17:04 ` Jeff Sipek
2014-03-23 19:57 ` Per Cederqvist
2014-03-23 20:07 ` Jeff Sipek
2014-03-23 21:13 ` Per Cederqvist
2014-05-06 18:27 ` Jeff Sipek
2014-03-21 7:31 ` [GUILT 05/28] "guilt new": Accept more than 4 arguments Per Cederqvist
2014-03-21 7:31 ` [GUILT 06/28] Fix and simplify the do_get_patch function Per Cederqvist
2014-03-23 17:09 ` Jeff Sipek
2014-03-23 21:03 ` Per Cederqvist
2014-05-06 19:08 ` Jeff Sipek
2014-05-07 20:44 ` Per Cederqvist
2014-03-21 7:31 ` [GUILT 07/28] Added test cases for "guilt fold" Per Cederqvist
2014-05-06 19:40 ` Jeff Sipek [this message]
2014-05-07 20:59 ` Per Cederqvist
2014-05-07 21:06 ` Jeff Sipek
2014-05-08 19:41 ` Per Cederqvist
2014-05-08 19:59 ` Jeff Sipek
2014-03-21 7:31 ` [GUILT 08/28] Added more test cases for "guilt new": empty patches Per Cederqvist
2014-03-21 7:31 ` [GUILT 09/28] Test suite: properly check the exit status of commands Per Cederqvist
2014-03-21 7:31 ` [GUILT 10/28] Run test_failed if the exit status of a test script is bad Per Cederqvist
2014-05-06 19:56 ` Jeff Sipek
2014-03-21 7:31 ` [GUILT 11/28] test suite: remove pointless redirection Per Cederqvist
2014-05-06 19:57 ` Jeff Sipek
2014-03-21 7:31 ` [GUILT 12/28] "guilt header": more robust header selection Per Cederqvist
2014-03-21 7:31 ` [GUILT 13/28] Check that "guilt header '.*'" fails Per Cederqvist
2014-03-21 7:31 ` [GUILT 14/28] Use "git check-ref-format" to validate patch names Per Cederqvist
2014-03-21 7:31 ` [GUILT 15/28] Produce legal patch names in guilt-import-commit Per Cederqvist
2014-03-21 7:31 ` [GUILT 16/28] Fix backslash handling when creating names of imported patches Per Cederqvist
2014-03-21 7:31 ` [GUILT 17/28] "guilt graph" no longer loops when no patches are applied Per Cederqvist
2014-05-06 20:10 ` Jeff Sipek
2014-03-21 7:31 ` [GUILT 18/28] guilt-graph: Handle commas in branch names Per Cederqvist
2014-05-06 20:13 ` Jeff Sipek
2014-03-21 7:31 ` [GUILT 19/28] Check that "guilt graph" works when working on a branch with a comma Per Cederqvist
2014-05-06 20:15 ` Jeff Sipek
2014-05-13 21:33 ` Jeff Sipek
2014-05-13 21:35 ` Jeff Sipek
2014-03-21 7:31 ` [GUILT 20/28] "guilt graph": Handle patch names containing quotes Per Cederqvist
2014-03-21 7:57 ` Eric Sunshine
2014-05-06 20:24 ` Jeff Sipek
2014-05-08 20:18 ` Per Cederqvist
2014-03-21 7:31 ` [GUILT 21/28] The log.decorate setting should not influence import-commit Per Cederqvist
2014-05-06 20:41 ` Jeff Sipek
2014-03-21 7:32 ` [GUILT 22/28] The log.decorate setting should not influence patchbomb Per Cederqvist
2014-05-06 20:41 ` Jeff Sipek
2014-03-21 7:32 ` [GUILT 23/28] The log.decorate setting should not influence guilt rebase Per Cederqvist
2014-05-06 20:41 ` Jeff Sipek
2014-03-21 7:32 ` [GUILT 24/28] disp no longer processes backslashes Per Cederqvist
2014-05-07 21:15 ` Jeff Sipek
2014-03-21 7:32 ` [GUILT 25/28] "guilt push" now fails when there are no more patches to push Per Cederqvist
2014-05-07 22:04 ` Jeff Sipek
2014-05-08 21:37 ` Per Cederqvist
2014-03-21 7:32 ` [GUILT 26/28] "guilt pop" now fails when there are no more patches to pop Per Cederqvist
2014-03-21 7:32 ` [GUILT 27/28] Minor testsuite fix Per Cederqvist
2014-05-07 21:09 ` Jeff Sipek
2014-03-21 7:32 ` [GUILT 28/28] Added guilt.reusebranch configuration option Per Cederqvist
2014-03-21 20:39 ` [GUILT 00/28] Teach guilt import-commit how create legal patch names, and more Jeff Sipek
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20140506194026.GK1655@meili.valhalla.31bits.net \
--to=jeffpc@josefsipek.net \
--cc=cederp@opera.com \
--cc=git@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).