Merge pull request #1068 from DeterminateSystems/fix-some-warnings

Fix some warnings
This commit is contained in:
Graham Christensen 2021-12-03 15:38:46 -05:00 committed by GitHub
commit 7227395a72
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 86 additions and 9 deletions

View file

@ -429,7 +429,6 @@
CatalystAuthenticationStoreDBIxClass CatalystAuthenticationStoreDBIxClass
CatalystAuthenticationStoreLDAP CatalystAuthenticationStoreLDAP
CatalystDevel CatalystDevel
CatalystDispatchTypeRegex
CatalystPluginAccessLog CatalystPluginAccessLog
CatalystPluginAuthorizationRoles CatalystPluginAuthorizationRoles
CatalystPluginCaptcha CatalystPluginCaptcha

View file

@ -8,7 +8,6 @@ use Hydra::Plugin;
use Hydra::Model::DB; use Hydra::Model::DB;
use Catalyst::Runtime '5.70'; use Catalyst::Runtime '5.70';
use Catalyst qw/ConfigLoader use Catalyst qw/ConfigLoader
Unicode::Encoding
Static::Simple Static::Simple
StackTrace StackTrace
Authentication Authentication

View file

@ -15,6 +15,9 @@ use JSON;
use List::Util qw[min max]; use List::Util qw[min max];
use List::MoreUtils qw{any}; use List::MoreUtils qw{any};
use Net::Prometheus; use Net::Prometheus;
use Types::Standard qw/StrMatch/;
use constant NARINFO_REGEX => qr{^([a-z0-9]{32})\.narinfo$};
# Put this controller at top-level. # Put this controller at top-level.
__PACKAGE__->config->{namespace} = ''; __PACKAGE__->config->{namespace} = '';
@ -349,17 +352,17 @@ sub nix_cache_info :Path('nix-cache-info') :Args(0) {
} }
sub narinfo :LocalRegex('^([a-z0-9]+).narinfo$') :Args(0) { sub narinfo :Path :Args(StrMatch[NARINFO_REGEX]) {
my ($self, $c) = @_; my ($self, $c, $narinfo) = @_;
if (!isLocalStore) { if (!isLocalStore) {
notFound($c, "There is no binary cache here."); notFound($c, "There is no binary cache here.");
} }
else { else {
my $hash = $c->req->captures->[0]; my ($hash) = $narinfo =~ NARINFO_REGEX;
die if length($hash) != 32; die("Hash length was not 32") if length($hash) != 32;
my $path = queryPathFromHashPart($hash); my $path = queryPathFromHashPart($hash);
if (!$path) { if (!$path) {

View file

@ -17,7 +17,7 @@ sub parse_payload :prototype($$) {
my ($channel_name, $payload) = @_; my ($channel_name, $payload) = @_;
my @payload = split /\t/, $payload; my @payload = split /\t/, $payload;
my $parser = %channels_to_events{$channel_name}; my $parser = $channels_to_events{$channel_name};
unless (defined $parser) { unless (defined $parser) {
die "Invalid channel name: '$channel_name'"; die "Invalid channel name: '$channel_name'";
} }

View file

@ -279,7 +279,7 @@ sub requirePost {
sub trim { sub trim {
my $s = shift; my $s = shift // "";
$s =~ s/^\s+|\s+$//g; $s =~ s/^\s+|\s+$//g;
return $s; return $s;
} }

View file

@ -644,7 +644,7 @@ sub checkJobsetWrapped {
# Hash the arguments to hydra-eval-jobs and check the # Hash the arguments to hydra-eval-jobs and check the
# JobsetInputHashes to see if the previous evaluation had the same # JobsetInputHashes to see if the previous evaluation had the same
# inputs. If so, bail out. # inputs. If so, bail out.
my @args = ($jobset->nixexprinput, $jobset->nixexprpath, inputsToArgs($inputInfo)); my @args = ($jobset->nixexprinput // "", $jobset->nixexprpath // "", inputsToArgs($inputInfo));
my $argsHash = sha256_hex("@args"); my $argsHash = sha256_hex("@args");
my $prevEval = getPrevJobsetEval($db, $jobset, 0); my $prevEval = getPrevJobsetEval($db, $jobset, 0);
if (defined $prevEval && $prevEval->hash eq $argsHash && !$dryRun && !$jobset->forceeval && $prevEval->flake eq $flakeRef) { if (defined $prevEval && $prevEval->hash eq $argsHash && !$dryRun && !$jobset->forceeval && $prevEval->flake eq $flakeRef) {

View file

@ -0,0 +1,48 @@
use strict;
use warnings;
use Setup;
use Data::Dumper;
use JSON qw(decode_json);
my %ctx = test_init(
# Without this, the test will fail because a `file:` store is not treated as a
# local store by `isLocalStore` in src/lib/Hydra/Helper/Nix.pm, and any
# requests to /HASH.narinfo will fail.
use_external_destination_store => 0
);
require Hydra::Schema;
require Hydra::Model::DB;
require Hydra::Helper::Nix;
use Test2::V0;
require Catalyst::Test;
use HTTP::Request::Common;
Catalyst::Test->import('Hydra');
my $db = Hydra::Model::DB->new;
hydra_setup($db);
my $project = $db->resultset('Projects')->create({name => "tests", displayname => "", owner => "root"});
my $jobset = createBaseJobset("basic", "basic.nix", $ctx{jobsdir});
ok(evalSucceeds($jobset), "Evaluating jobs/basic.nix should exit with return code 0");
for my $build (queuedBuildsForJobset($jobset)) {
ok(runBuild($build), "Build '".$build->job."' from jobs/basic.nix should exit with return code 0");
}
subtest "/HASH.narinfo" => sub {
my $build_redirect = request(GET '/job/tests/basic/empty_dir/latest-finished');
my $url = URI->new($build_redirect->header('location'))->path;
my $json = request(GET $url, Accept => 'application/json');
my $data = decode_json($json->content);
my $outpath = $data->{buildoutputs}{out}{path};
my ($hash) = $outpath =~ qr{/nix/store/([a-z0-9]{32}).*};
my $narinfo_response = request(GET "/$hash.narinfo");
ok($narinfo_response->is_success, "Getting the narinfo of a build");
my ($storepath) = $narinfo_response->content =~ qr{StorePath: (.*)};
is($storepath, $outpath, "The returned store path is the same as the out path")
};
done_testing;

28
t/Helper/CatalystUtils.t Normal file
View file

@ -0,0 +1,28 @@
use strict;
use warnings;
use Setup;
use Test2::V0;
use Hydra::Helper::CatalystUtils;
subtest "trim" => sub {
my %values = (
"" => "",
"🌮" => '🌮',
" 🌮" => '🌮',
"🌮 " => '🌮',
" 🌮 " => '🌮',
"\n🌮 " => '🌮',
"\n\t🌮\n\n\t" => '🌮',
);
for my $input (keys %values) {
my $value = $values{$input};
is(trim($input), $value, "Trim the value: " . $input);
}
my $uninitialized;
is(trim($uninitialized), '', "Trimming an uninitialized value");
};
done_testing;