use strict;
use warnings;
use utf8;
use autodie qw(:all);
use Test::More;
use Test::Exception;
BEGIN {
eval { require LWP::UserAgent; 1 }
or plan skip_all => "LWP::UserAgent is required for testing webhooks";
}
use lib 't';
use TestBot;
use App::KGB::Change;
use File::Temp qw(tempdir);
use File::Spec;
use JSON qw(to_json);
use Test::Differences;
unified_diff();
use utf8;
my $builder = Test::More->builder;
binmode $builder->output, ":utf8";
binmode $builder->failure_output, ":utf8";
binmode $builder->todo_output, ":utf8";
my $tmp_cleanup = not $ENV{TEST_KEEP_TMP};
my $dir = tempdir( 'kgb-XXXXXXX', CLEANUP => $tmp_cleanup, DIR => File::Spec->tmpdir );
diag "Temp directory $dir will pe kept" unless $tmp_cleanup;
my $test_bot = TestBot->start;
use Cwd;
my $R = getcwd;
my $ua = LWP::UserAgent->new();
my $webhook_url = sprintf( 'http://%s:%d/webhook/?%s',
$test_bot->addr, $test_bot->port,
join( '&', 'channel=test', 'network=local', 'shorten_urls=0' ) );
sub webhook_post {
return $ua->post(
$webhook_url,
'Content-Type' => 'text/json',
Content => to_json( shift, { utf8 => 1 } ),
);
}
my $resp = webhook_post(
{ object_kind => 'issue',
user => { name => 'Test User' },
project => { name => 'test-repo', },
object_attributes => {
id => 4242,
iid => 42,
title => "Issue title goes here",
url => 'http://git/issues/42',
action => 'open',
},
}
);
is( $resp->code, 202, 'response status is 202' ) or diag $resp->as_string;
TestBot->expect(
join( ' ',
'#test 03Test User',
'05issues 06test-repo',
'#42',
'03Issue title goes here',
'* 14http://git/issues/42',
)
);
diag `cat t/bot/kgb-bot.log`;
$test_bot->stop; # make sure all output is there
my $output = $test_bot->get_output;
eq_or_diff( $output, TestBot->expected_output );
done_testing();