]> git.donarmstrong.com Git - debbugs.git/commitdiff
Extend bugreport test cases to check the output of some control messages
authorFrank Lichtenheld <frank@lichtenheld.de>
Sun, 27 Mar 2016 13:24:15 +0000 (15:24 +0200)
committerDon Armstrong <don@donarmstrong.com>
Tue, 29 Mar 2016 00:05:56 +0000 (17:05 -0700)
This exposes #767327 (wrong package links in "reassigned" message)
as a test failure.

Signed-off-by: Don Armstrong <don@donarmstrong.com>
t/07_bugreport.t

index 3600e1ca7a35684e6b4120399bb4895d508b225d..80dfc9220f85150007388a7340ce0b575d043eee 100644 (file)
@@ -1,7 +1,7 @@
 # -*- mode: cperl;-*-
 
 
-use Test::More tests => 8;
+use Test::More tests => 14;
 
 use warnings;
 use strict;
@@ -90,7 +90,44 @@ print STDERR $mech->content();
 ok($mech->content() !~ qr/[\x01\x02\x03\x05\x06\x07]/i,
    'No unescaped states');
 
-
+# now test the output of some control commands
+my @control_commands =
+     (
+      reassign_foo => {command => 'reassign',
+                      value   => 'bar',
+                      regex => qr{<strong>bug reassigned from package &#39;<a href="pkgreport\.cgi\?package=foo">foo</a>&#39; to &#39;<a href="pkgreport\.cgi\?package=bar">bar</a>},
+                     },
+      forwarded_foo      => {command => 'forwarded',
+                            value   => 'https://foo.invalid/bugs?id=1',
+                            regex   => qr{<strong>Set bug forwarded-to-address to &#39;<a href="https://foo\.invalid/bugs\?id=1">https://foo\.invalid/bugs\?id=1</a>&#39;\.},
+                           },
+      clone        => {command => 'clone',
+                      value   => '-1',
+                      regex   => qr{<strong>Bug <a href="bugreport.cgi\?bug=1">1</a> cloned as bug <a href="bugreport.cgi\?bug=2">2</a>},
+                     },
+     );
+
+while (my ($command,$control_command) = splice(@control_commands,0,2)) {
+  # just check to see that control doesn't explode
+  $control_command->{value} = " $control_command->{value}" if length $control_command->{value}
+    and $control_command->{value} !~ /^\s/;
+  send_message(to => 'control@bugs.something',
+              headers => [To   => 'control@bugs.something',
+                          From => 'foo@bugs.something',
+                          Subject => "Munging a bug with $command",
+                         ],
+              body => <<EOF) or fail 'message to control@bugs.something failed';
+debug 10
+$control_command->{command} 1$control_command->{value}
+thanks
+EOF
+                                 ;
+  # Now test that the output has changed accordingly
+  $mech->get_ok('http://localhost:'.$port.'/?bug=1',
+               'Page received ok');
+  like($mech->content(), $control_command->{regex},
+       'Page matches regex');
+}
 
 # Other tests for bugs in the page should be added here eventually