Add test for SendResults
[gruntmaster-daemon.git] / t / 02-send-results-request.t
CommitLineData
8d32c68b 1#!/usr/bin/perl -w
2use v5.14;
3use strict;
4use warnings;
5
6use Gruntmaster::Daemon qw/process/;
7
8use Cwd qw/getcwd/;
9use File::Slurp qw/read_file/;
10use File::Temp qw/tempdir/;
11use HTTP::Tiny;
12use Hash::Merge qw/merge/;
13use JSON qw/encode_json decode_json/;
14use Log::Log4perl;
15use Test::HTTP::LocalServer;
16use Test::More;
17use YAML::Tiny qw/LoadFile/;
18
19my $server = Test::HTTP::LocalServer->spawn;
20my $response = HTTP::Tiny->new->get( $server->url );
21$ENV{REMOTE_ADDRESS} = $server->url;
22
23my $loglevel = $ENV{TEST_LOG_LEVEL} // ($ENV{TEST_VERBOSE} ? 'TRACE' : 'OFF');
24my $log_conf = <<CONF;
25log4perl.category.Gruntmaster.Daemon = $loglevel, stderr
26
27log4perl.appender.stderr = Log::Log4perl::Appender::Screen
28log4perl.appender.stderr.layout = Log::Log4perl::Layout::PatternLayout
29log4perl.appender.stderr.layout.ConversionPattern = [\%d] [\%F{1}:\%M{1}:\%L] [\%p] \%m\%n
30CONF
31Log::Log4perl->init(\$log_conf);
32
33my $tempdir = tempdir "gruntmasterd-testingXXXX", TMPDIR => 1, CLEANUP => 1;
34chmod 0777, $tempdir;
35
36sub 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
55sub 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
64send_request();
65
66$server->stop;
67
68done_testing();
This page took 0.013075 seconds and 4 git commands to generate.