This is an automated email from the git hooks/post-receive script.

jamessan pushed a commit to branch master
in repository devscripts.

commit f4f35850aaaf42bfe00a90244653dcfb7c499150
Author: James McCoy <[email protected]>
Date:   Sat Jul 8 14:13:37 2017 -0400

    dch: Elide command-line message if it is empty
    
    Many dch options (e.g., --bpo) automatically add their own entry to the
    changelog as well as adding a bullet for a subsequent entry.  If the
    user provides an empty message on the command-line, do not add the
    second bullet.
    
    Signed-off-by: James McCoy <[email protected]>
---
 debian/changelog     |  4 ++++
 scripts/debchange.pl |  2 +-
 test/test_debchange  | 27 ++++++++++++++++++++++++++-
 3 files changed, 31 insertions(+), 2 deletions(-)

diff --git a/debian/changelog b/debian/changelog
index 795bbba..aeb80e1 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -45,6 +45,10 @@ devscripts (2.17.7) UNRELEASED; urgency=medium
   * bts:
     + Create the cache directory if it doesn't already exist.  Thanks to
       Joonas Kylmälä for the patch.  (Closes: #866117)
+  * debchange:
+    + When an empty message is provided on the command-line, do not add an
+      empty entry to the changelog.  Thanks to Adam Barratt for the patch.
+      (Closes: #830968)
 
   [ Ben Finney ]
   * debdiff:
diff --git a/scripts/debchange.pl b/scripts/debchange.pl
index 0c59d0e..b44b963 100755
--- a/scripts/debchange.pl
+++ b/scripts/debchange.pl
@@ -1253,7 +1253,7 @@ if (($opt_i || $opt_n || $opt_bn || $opt_qa || $opt_R || 
$opt_s || $opt_team ||
            print O "  * Rebuild for $bpo_dist.\n";
            $line = 1;
        }
-       if (@closes_text or $TEXT) {
+       if (@closes_text or $TEXT or $EMPTY_TEXT) {
            foreach (@closes_text) { format_line($_, 1); }
            if (length $TEXT) { format_line($TEXT, 1); }
        } elsif ($opt_news) {
diff --git a/test/test_debchange b/test/test_debchange
index 04b96a6..8cd609f 100755
--- a/test/test_debchange
+++ b/test/test_debchange
@@ -164,8 +164,33 @@ testEncoding() {
     success "-s \"Security upload\""
     verifyMaintainer "dch -s"
 
-    success "--bpo \"Backporrts upload\""
+    success "--bpo \"Backports upload\""
     verifyMaintainer "dch --bpo"
 }
 
+verifyEntryLines() {
+    success "$1"
+    local changes="$(dpkg-parsechangelog -l"$CHANGELOG" -SChanges | fgrep '*')"
+    assertEquals "\"$changes\"" 1 "$(echo "$changes" | wc -l)"
+}
+
+# Any options which automatically add their own entry to the changelog should
+# elide an empty entry if the user passes an empty string as the entry.
+testEmptyMessage() {
+    rm -f "$CHANGELOG"
+    success "--create -D unstable --package test-package -v 1.0-1 'First 
upload'"
+
+    verifyEntryLines "--nmu ''"
+
+    verifyEntryLines "--bin-nmu ''"
+
+    verifyEntryLines "--qa ''"
+
+    verifyEntryLines "--security ''"
+
+    verifyEntryLines "--bpo ''"
+
+    verifyEntryLines "--team ''"
+}
+
 . shunit2

-- 
Alioth's /usr/local/bin/git-commit-notice on 
/srv/git.debian.org/git/collab-maint/devscripts.git

_______________________________________________
devscripts-devel mailing list
[email protected]
http://lists.alioth.debian.org/cgi-bin/mailman/listinfo/devscripts-devel

Reply via email to