Also, make the messages much shorter by not including build details.
LDICTHWYJ2SP6IU3PK2K2PW5FN54HP7W4KTL324YYTTNPVJ4HSLQC , jobset => $build->jobset->name, job => $build->job->name, system => $build->system, finished => 1, id => { '<', $build->id }, -not => { buildstatus => { -in => [4, 3]} }
, jobset => $build->jobset->name, job => $build->job->name, system => $build->system, finished => 1, id => { '<', $build->id }, -not => { buildstatus => { -in => [4, 3]} }
sub showJobName {my ($build) = @_;return $build->project->name . ":" . $build->jobset->name . ":" . $build->job->name;}
my $template = <<EOF;Hi,The status of Hydra job [% showJobName(build) %] (on [% build.system %]) [% IF prevBuild && build.buildstatus != prevBuild.buildstatus %]has changed from "[% showStatus(prevBuild) %]" to "[% showStatus(build) %]"[% ELSE %]is "[% showStatus(build) %]"[% END %]. For details, see[% baseurl %]/build/[% build.id %][% IF dependents.size > 0 -%]The following dependent jobs also failed:[% FOREACH b IN dependents -%]* [% showJobName(b) %] ([% baseurl %]/build/[% b.id %])[% END -%][% END -%][% IF build.buildstatus == 0 -%]Yay![% ELSE -%]Go forth and fix [% IF dependents.size == 0 -%]it[% ELSE %]them[% END %].[% END -%]Regards,The Hydra build daemon.EOF
my $status = statusDescription($build->buildstatus);
my $vars ={ build => $build, prevBuild => getPrevBuild($self, $build), dependents => [grep { $_->id != $build->id } @builds], baseurl => $self->{config}->{'base_uri'} || "http://localhost:3000", showJobName => \&showJobName, showStatus => \&showStatus};
my $infoTable = Text::Table->new({ align => "left" }, \ " | ", { align => "left" });my @lines = ([ "Build ID:", $build->id ],[ "Nix name:", $build->nixname ],[ "Short description:", $build->description || '(not given)' ],[ "Maintainer(s):", $build->maintainers ],[ "System:", $build->system ],[ "Derivation store path:", $build->drvpath ],[ "Output store path:", join(", ", map { $_->path } $build->buildoutputs) ],[ "Time added:", showTime $build->timestamp ],);push @lines, ([ "Build started:", showTime $build->starttime ],[ "Build finished:", showTime $build->stoptime ],[ "Duration:", $build->stoptime - $build->starttime . "s" ],) if $build->starttime;$infoTable->load(@lines);
my $sender = $self->{config}->{'notification_sender'} ||(($ENV{'USER'} || "hydra") . "@" . hostname_long);
my $inputsTable = Text::Table->new({ title => "Name", align => "left" }, \ " | ",{ title => "Type", align => "left" }, \ " | ",{ title => "Value", align => "left" });@lines = ();foreach my $input ($build->inputs) {my $type = $input->type;push @lines,[ $input->name, $input->type, ( $input->type eq "build" || $input->type eq "sysbuild")? $input->dependency->id: ($input->type eq "string" || $input->type eq "boolean")? $input->value : ($input->uri . ':' . $input->revision)];}$inputsTable->load(@lines);
#my $loglines = 50;#my $logtext = logContents($build->drvpath, $loglines);#$logtext = removeAsciiEscapes($logtext);
my $loglines = 50;my $logtext = logContents($build->drvpath, $loglines);$logtext = removeAsciiEscapes($logtext);my $prevBuild = getPrevBuild($self, $build);my $foo = "\nIn addition, the following jobs failed:\n";foreach my $b (@builds) {$foo .= " " . showJobName($b) . " ($selfURI/build/" . $b->id . ")\n";}my $body = "Hi,\n". "\n". "This is to let you know that Hydra build " . $build->id. " of job " . $jobName . " " . (defined $prevBuild ? "has changed from '" . statusDescription($prevBuild->buildstatus) . "' to '$status'" : "is '$status'" ) .".\n". $foo. "\n". "Complete build information can be found on this page: ". "$selfURI/build/" . $build->id . "\n". ($build->buildstatus != 0 ? "\nThe last $loglines lines of the build log are shown at the bottom of this email.\n" : ""). "\n". "A summary of the build information follows:\n". "\n". $infoTable->body. "\n". "The build inputs were:\n". "\n". $inputsTable->title. $inputsTable->rule('-', '+'). $inputsTable->body. "\n". "Regards,\n\nThe Hydra build daemon.\n". ($build->buildstatus != 0 ? "\n---\n$logtext" : "");# stripping trailing spaces from lines$body =~ s/[\ ]+$//gm;
Subject => "$status: Hydra job $jobName on " . $build->system . ", build " . $build->id,'X-Hydra-Instance' => $baseurl,
Subject => showStatus($build) . ": Hydra job " . showJobName($build) . " on " . $build->system,'X-Hydra-Instance' => $vars->{baseurl},