about summary refs log tree commit diff
path: root/lib/jitterbug/Emailer.pm
blob: d21028f6cd654044deb83e7ad1c2585a19827952 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
package jitterbug::Emailer;

use strict;
use warnings;
use Email::Stuff;
use JSON;

sub new {
    my $self = bless {} => shift;
    my ($conf,$task,$tap_output) = @_;
    # smelly
    $self->{'conf'} = $conf;
    $self->{'task'} = $task;
    $self->{'tap_output'} = $tap_output;

    return $self;
}

sub _make_body {
    my ($header, $message, $tap, $footer) = @_;

    no warnings 'uninitialized';
    return <<BODY;
$header
Commit Message:
$message

TAP Output:
$tap
$footer
BODY

}
sub run {
    my $self       = shift;
    my $task       = $self->{'task'};
    my $buildconf  = $self->{'conf'}->{'jitterbug'}{'build_process'};
    my $project    = $task->project->name;
    my $tap        = $self->{'tap_output'};
    my $sha1       = $task->commit->sha256;
    my $shortsha1  = substr($sha1, 0, 8);
    my $desc       = JSON::decode_json( $task->commit->content );
    my $email      = $desc->{'author'}{'email'};
    my $message    = $desc->{'message'};
    my $header     = $buildconf->{'on_failure_header'};
    my $footer     = $buildconf->{'on_failure_footer'};
    my $body       = _make_body($header,$message, $tap, $footer);
    my $summary    = '';

    if ( $tap =~ m/^(Test Summary Report.*)/ms ) {
        $summary = $1;
    }

    # Expand placeholders in our failure email
    $body =~ s/%%PROJECT%%/$project/g;
    $body =~ s/%%SHA1%%/$sha1/g;
    $body =~ s/%%SUMMARY%%/$summary/g;


    my $stuff = Email::Stuff->from($buildconf->{'on_failure_from_email'})
                # bug in Email::Stuff brakes chaining if $email is empty
                ->to($email || " ")
                ->cc($buildconf->{'on_failure_cc_email'})
                ->text_body($body)
                ->subject(
                    $buildconf->{'on_failure_subject_prefix'} . "$project @ $shortsha1 $message"
                  );
                # Should we attach a build log for convenience?
                # ->attach(io('dead_bunbun_faked.gif')->all,
                #    filename => 'dead_bunbun_proof.gif')
    $self->{'last_email_sent'} = $stuff;

    $stuff->send;

    return $self;
}

1;