blob: 1dfa55f63828b037e37772b7bd23c3363b21a42c [file] [log] [blame]
Akronb80341d2018-10-15 19:46:23 +02001use Mojo::Base -strict;
2use Test::Mojo;
3use Test::More;
4use Mojo::File qw/path/;
5
6
7#####################
8# Start Fake server #
9#####################
Akron63d963b2019-07-05 15:35:51 +020010my $mount_point = '/realapi/';
Akronb80341d2018-10-15 19:46:23 +020011$ENV{KALAMAR_API} = $mount_point;
12
13my $t = Test::Mojo->new('Kalamar');
14
15# Mount fake backend
16# Get the fixture path
Akron73f36082018-10-25 15:34:59 +020017my $fixtures_path = path(Mojo::File->new(__FILE__)->dirname, 'server');
Akronb80341d2018-10-15 19:46:23 +020018my $fake_backend = $t->app->plugin(
19 Mount => {
20 $mount_point =>
Akron73f36082018-10-25 15:34:59 +020021 $fixtures_path->child('mock.pl')
Akronb80341d2018-10-15 19:46:23 +020022 }
23);
24# Configure fake backend
25$fake_backend->pattern->defaults->{app}->log($t->app->log);
26
27# Query passed
Akron3b3a4342021-05-31 11:14:48 +020028$t->get_ok('/corpus/WPD15/232/39681/p2133-2134?spans=false&foundry=*&_format=json')
Akronb80341d2018-10-15 19:46:23 +020029 ->status_is(200)
Akron69481a42021-03-22 10:31:16 +010030 ->content_type_is('application/json;charset=UTF-8')
Akronb80341d2018-10-15 19:46:23 +020031 ->json_is('/textSigle', 'WPD15/232/39681')
Akronb8d0b402018-10-18 23:51:52 +020032 ->json_like('/snippet', qr!<span class=\"context-left\">!)
Akron8ea84292018-10-24 13:41:52 +020033 ->header_isnt('X-Kalamar-Cache', 'true')
Akronb80341d2018-10-15 19:46:23 +020034 ;
35
Akron3b3a4342021-05-31 11:14:48 +020036$t->get_ok('/corpus/GOE/AGF/02286/p75682-75683?_format=json')
Akronb8d0b402018-10-18 23:51:52 +020037 ->status_is(200)
38 ->json_is('/textSigle', 'GOE/AGF/02286')
39 ->json_is('/title','Materialien zur Geschichte der Farbenlehre')
40 ;
41
42# TODO:
43# It's surprising, that it doesn't return a 404!
Akron3b3a4342021-05-31 11:14:48 +020044$t->get_ok('/corpus/notfound/X/X/p0-1?_format=json')
Akronb8d0b402018-10-18 23:51:52 +020045 ->status_is(200)
46 ->json_is('/textSigle', 'NOTFOUND/X/X')
47 ->json_is('/corpusID', undef)
48 ;
49
Akron3b3a4342021-05-31 11:14:48 +020050$t->get_ok('/corpus/fail/x/x/p0-0?_format=json')
Akron3c390c42020-03-30 09:06:21 +020051 ->status_is(400)
Akronb8d0b402018-10-18 23:51:52 +020052 ->json_is('/notifications/0/0', 'error')
Akron2e2098e2018-10-24 20:16:24 +020053 ->json_like('/notifications/0/1', qr!Unable to load query response from .+?response_matchinfo_fail_x_x_p0-0\.json!)
Akronb8d0b402018-10-18 23:51:52 +020054 ;
55
56# TODO:
57# Should probably return a 4xx!
Akron3b3a4342021-05-31 11:14:48 +020058$t->get_ok('/corpus/GOE/AGF/02286/p-2-0?_format=json')
Akron3c390c42020-03-30 09:06:21 +020059 ->status_is(400)
Akronb8d0b402018-10-18 23:51:52 +020060 ->json_is('/notifications/0/0', 'error')
61 ->json_is('/notifications/0/1', '730: Invalid match identifier')
62 ;
63
Akron3b3a4342021-05-31 11:14:48 +020064$t->get_ok('/corpus/notfound2/X/X/p0-1?_format=json')
Akron7093b812018-10-19 17:28:21 +020065 ->status_is(404)
Akronb8d0b402018-10-18 23:51:52 +020066 ->json_is('/notifications/0/0', 'error')
67 ->json_is('/notifications/0/1', '404: Not Found')
68 ;
69
Akron3b3a4342021-05-31 11:14:48 +020070$t->get_ok('/corpus/brokenerr/X/X/p0-1?_format=json')
Akrond0ec3082018-10-19 18:53:09 +020071 ->status_is(409)
72 ->json_is('/notifications/0/0', 'error')
73 ->json_is('/notifications/0/1', 'Message structure failed')
74 ;
75
Akron3b3a4342021-05-31 11:14:48 +020076$t->get_ok('/corpus/brokenwarn/X/X/p0-1?_format=json')
Akrond0ec3082018-10-19 18:53:09 +020077 ->status_is(200)
Akrona3c353c2019-02-14 23:50:00 +010078 ->json_is('/notifications/0/0', 'warn')
Akrond0ec3082018-10-19 18:53:09 +020079 ->json_is('/notifications/0/1', '1: Warning 1')
80 ->json_is('/notifications/1/0', 'error')
81 ->json_is('/notifications/1/1', 'Message structure failed')
82 ;
83
Akron3b3a4342021-05-31 11:14:48 +020084$t->get_ok('/corpus/brokenerr2/X/X/p0-1?_format=json')
Akrond0ec3082018-10-19 18:53:09 +020085 ->status_is(417)
86 ->json_is('/notifications/0/0', 'error')
87 ->json_is('/notifications/0/1', 'Message structure failed')
88 ;
89
Akronf21eb492018-10-22 15:17:56 +020090# Get from cache
Akron3b3a4342021-05-31 11:14:48 +020091$t->get_ok('/corpus/WPD15/232/39681/p2133-2134?spans=false&foundry=*&_format=json')
Akronf21eb492018-10-22 15:17:56 +020092 ->status_is(200)
93 ->json_is('/textSigle', 'WPD15/232/39681')
94 ->json_like('/snippet', qr!<span class=\"context-left\">!)
Akron8ea84292018-10-24 13:41:52 +020095 ->header_is('X-Kalamar-Cache', 'true')
Akronf21eb492018-10-22 15:17:56 +020096 ;
97
Akronc4be8192018-10-25 16:07:53 +020098# Check for validation error
Akron3b3a4342021-05-31 11:14:48 +020099$t->get_ok('/corpus/WPD15/232/39681/p2133-2134?spans=no&_format=json')
Akronc4be8192018-10-25 16:07:53 +0200100 ->status_is(400)
101 ->json_is('/notifications/0/1', 'Parameter "spans" invalid')
102 ;
Akronb8d0b402018-10-18 23:51:52 +0200103
Akron3b3a4342021-05-31 11:14:48 +0200104$t->get_ok('/corpus/WPD15/232/39681/p2133-2134?spans=no&_format=html')
Akron69481a42021-03-22 10:31:16 +0100105 ->content_type_is('text/html;charset=UTF-8')
106 ->status_is(400)
107 ->text_is('p.no-results', 'Unable to perform the action.')
108 ->text_is('div.notify', 'Parameter "spans" invalid')
109 ;
110
111$t->get_ok('/corpus/WPD15/232/39681/p2133-2134?spans=no')
112 ->content_type_is('text/html;charset=UTF-8')
Akron3c390c42020-03-30 09:06:21 +0200113 ->status_is(400)
114 ->text_is('p.no-results', 'Unable to perform the action.')
115 ->text_is('div.notify', 'Parameter "spans" invalid')
116 ;
117
118
Akronb80341d2018-10-15 19:46:23 +0200119done_testing;
Akron7093b812018-10-19 17:28:21 +0200120__END__