blob: edd84b442bf9a1cb905481680b1629608d8e0b9d [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
Akron910828a2025-06-27 15:38:48 +020036$t->get_ok('/corpus/GOE/AGF/02286/p75682-75683?_format=json&response-pipe=glemm')
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')
Akron910828a2025-06-27 15:38:48 +020040 ->json_is('/meta/responsePipes','glemm')
Akronb8d0b402018-10-18 23:51:52 +020041 ;
42
43# TODO:
44# It's surprising, that it doesn't return a 404!
Akron3b3a4342021-05-31 11:14:48 +020045$t->get_ok('/corpus/notfound/X/X/p0-1?_format=json')
Akronb8d0b402018-10-18 23:51:52 +020046 ->status_is(200)
47 ->json_is('/textSigle', 'NOTFOUND/X/X')
48 ->json_is('/corpusID', undef)
49 ;
50
Akron3b3a4342021-05-31 11:14:48 +020051$t->get_ok('/corpus/fail/x/x/p0-0?_format=json')
Akron3c390c42020-03-30 09:06:21 +020052 ->status_is(400)
Akronb8d0b402018-10-18 23:51:52 +020053 ->json_is('/notifications/0/0', 'error')
Akron2e2098e2018-10-24 20:16:24 +020054 ->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 +020055 ;
56
57# TODO:
58# Should probably return a 4xx!
Akron3b3a4342021-05-31 11:14:48 +020059$t->get_ok('/corpus/GOE/AGF/02286/p-2-0?_format=json')
Akron3c390c42020-03-30 09:06:21 +020060 ->status_is(400)
Akronb8d0b402018-10-18 23:51:52 +020061 ->json_is('/notifications/0/0', 'error')
62 ->json_is('/notifications/0/1', '730: Invalid match identifier')
63 ;
64
Akron3b3a4342021-05-31 11:14:48 +020065$t->get_ok('/corpus/notfound2/X/X/p0-1?_format=json')
Akron7093b812018-10-19 17:28:21 +020066 ->status_is(404)
Akronb8d0b402018-10-18 23:51:52 +020067 ->json_is('/notifications/0/0', 'error')
68 ->json_is('/notifications/0/1', '404: Not Found')
69 ;
70
Akron3b3a4342021-05-31 11:14:48 +020071$t->get_ok('/corpus/brokenerr/X/X/p0-1?_format=json')
Akrond0ec3082018-10-19 18:53:09 +020072 ->status_is(409)
73 ->json_is('/notifications/0/0', 'error')
74 ->json_is('/notifications/0/1', 'Message structure failed')
75 ;
76
Akron3b3a4342021-05-31 11:14:48 +020077$t->get_ok('/corpus/brokenwarn/X/X/p0-1?_format=json')
Akrond0ec3082018-10-19 18:53:09 +020078 ->status_is(200)
Akrona3c353c2019-02-14 23:50:00 +010079 ->json_is('/notifications/0/0', 'warn')
Akrond0ec3082018-10-19 18:53:09 +020080 ->json_is('/notifications/0/1', '1: Warning 1')
81 ->json_is('/notifications/1/0', 'error')
82 ->json_is('/notifications/1/1', 'Message structure failed')
83 ;
84
Akron3b3a4342021-05-31 11:14:48 +020085$t->get_ok('/corpus/brokenerr2/X/X/p0-1?_format=json')
Akrond0ec3082018-10-19 18:53:09 +020086 ->status_is(417)
87 ->json_is('/notifications/0/0', 'error')
88 ->json_is('/notifications/0/1', 'Message structure failed')
89 ;
90
Akronf21eb492018-10-22 15:17:56 +020091# Get from cache
Akron3b3a4342021-05-31 11:14:48 +020092$t->get_ok('/corpus/WPD15/232/39681/p2133-2134?spans=false&foundry=*&_format=json')
Akronf21eb492018-10-22 15:17:56 +020093 ->status_is(200)
94 ->json_is('/textSigle', 'WPD15/232/39681')
95 ->json_like('/snippet', qr!<span class=\"context-left\">!)
Akron8ea84292018-10-24 13:41:52 +020096 ->header_is('X-Kalamar-Cache', 'true')
Akronf21eb492018-10-22 15:17:56 +020097 ;
98
Akronc4be8192018-10-25 16:07:53 +020099# Check for validation error
Akron3b3a4342021-05-31 11:14:48 +0200100$t->get_ok('/corpus/WPD15/232/39681/p2133-2134?spans=no&_format=json')
Akronc4be8192018-10-25 16:07:53 +0200101 ->status_is(400)
102 ->json_is('/notifications/0/1', 'Parameter "spans" invalid')
103 ;
Akronb8d0b402018-10-18 23:51:52 +0200104
Akron3b3a4342021-05-31 11:14:48 +0200105$t->get_ok('/corpus/WPD15/232/39681/p2133-2134?spans=no&_format=html')
Akron69481a42021-03-22 10:31:16 +0100106 ->content_type_is('text/html;charset=UTF-8')
107 ->status_is(400)
108 ->text_is('p.no-results', 'Unable to perform the action.')
109 ->text_is('div.notify', 'Parameter "spans" invalid')
110 ;
111
112$t->get_ok('/corpus/WPD15/232/39681/p2133-2134?spans=no')
113 ->content_type_is('text/html;charset=UTF-8')
Akron3c390c42020-03-30 09:06:21 +0200114 ->status_is(400)
115 ->text_is('p.no-results', 'Unable to perform the action.')
116 ->text_is('div.notify', 'Parameter "spans" invalid')
117 ;
118
Akron910828a2025-06-27 15:38:48 +0200119$t->get_ok('/corpus/WPD15/232/39681/p2133-2134?spans=no')
120 ->content_type_is('text/html;charset=UTF-8')
121 ->status_is(400)
122 ->text_is('p.no-results', 'Unable to perform the action.')
123 ->text_is('div.notify', 'Parameter "spans" invalid')
124 ;
125
Akron3c390c42020-03-30 09:06:21 +0200126
Akronb80341d2018-10-15 19:46:23 +0200127done_testing;
Akron7093b812018-10-19 17:28:21 +0200128__END__