]>
Commit | Line | Data |
---|---|---|
8d32c68b | 1 | #!/usr/bin/perl -w |
2 | use v5.14; | |
3 | use strict; | |
4 | use warnings; | |
5 | ||
6 | use Gruntmaster::Daemon qw/process/; | |
7 | ||
8 | use Cwd qw/getcwd/; | |
9 | use File::Slurp qw/read_file/; | |
10 | use File::Temp qw/tempdir/; | |
11 | use HTTP::Tiny; | |
12 | use Hash::Merge qw/merge/; | |
13 | use JSON qw/encode_json decode_json/; | |
14 | use Log::Log4perl; | |
15 | use Test::HTTP::LocalServer; | |
16 | use Test::More; | |
17 | use YAML::Tiny qw/LoadFile/; | |
18 | ||
19 | my $server = Test::HTTP::LocalServer->spawn; | |
20 | my $response = HTTP::Tiny->new->get( $server->url ); | |
21 | $ENV{REMOTE_ADDRESS} = $server->url; | |
22 | ||
23 | my $loglevel = $ENV{TEST_LOG_LEVEL} // ($ENV{TEST_VERBOSE} ? 'TRACE' : 'OFF'); | |
24 | my $log_conf = <<CONF; | |
25 | log4perl.category.Gruntmaster.Daemon = $loglevel, stderr | |
26 | ||
27 | log4perl.appender.stderr = Log::Log4perl::Appender::Screen | |
28 | log4perl.appender.stderr.layout = Log::Log4perl::Layout::PatternLayout | |
29 | log4perl.appender.stderr.layout.ConversionPattern = [\%d] [\%F{1}:\%M{1}:\%L] [\%p] \%m\%n | |
30 | CONF | |
31 | Log::Log4perl->init(\$log_conf); | |
32 | ||
33 | my $tempdir = tempdir "gruntmasterd-testingXXXX", TMPDIR => 1, CLEANUP => 1; | |
34 | chmod 0777, $tempdir; | |
35 | ||
36 | sub process_meta() { | |
37 | my $pbmeta = LoadFile "t/problems/aplusb/meta.yml"; | |
38 | for (1 .. $pbmeta->{testcnt}) { | |
39 | $pbmeta->{infile}[$_ - 1] = read_file "t/problems/aplusb/$_.in" | |
40 | if $pbmeta->{generator} eq 'File'; | |
41 | $pbmeta->{okfile}[$_ - 1] = read_file "t/problems/aplusb/$_.ok" | |
42 | if $pbmeta->{runner} && $pbmeta->{runner} eq 'File'; | |
43 | } | |
44 | my $source = <t/problems/aplusb/tests/40>; | |
45 | my $meta = LoadFile "$source/meta.yml"; | |
46 | $meta->{files}{prog}{content} = read_file "$source/$meta->{files}{prog}{name}"; | |
47 | $meta = merge $meta, $pbmeta; | |
48 | my $savedcwd = getcwd; | |
49 | chdir $tempdir; | |
50 | $meta->{job_id} = 1; | |
51 | Gruntmaster::Daemon::process($meta); | |
52 | chdir $savedcwd; | |
53 | } | |
54 | ||
55 | sub send_request() { | |
56 | process_meta(); | |
57 | ||
58 | my $requests = $server->get_log; | |
59 | is $requests =~ qr/"result_text":"40 points"/, 1; | |
60 | is $requests =~ qr/"result":10/, 1; | |
61 | is $requests =~ qr/"gm_id":1/, 1; | |
62 | } | |
63 | ||
64 | send_request(); | |
65 | ||
66 | $server->stop; | |
67 | ||
68 | done_testing(); |