blob: 59d8fc9d63d44d32176cb7a09ff34f418bbe38e9 [file] [log] [blame]
Akron0e1ed242018-10-11 13:22:00 +02001use Mojo::Base -strict;
2use Test::Mojo;
3use Test::More;
Akron32396632018-10-11 17:08:37 +02004use Mojo::File qw/path/;
5
6
7#####################
8# Start Fake server #
9#####################
10my $mount_point = '/api/';
11$ENV{KALAMAR_API} = $mount_point;
Akron0e1ed242018-10-11 13:22:00 +020012
13my $t = Test::Mojo->new('Kalamar');
14
Akron32396632018-10-11 17:08:37 +020015# Mount fake backend
16# Get the fixture path
Akron73f36082018-10-25 15:34:59 +020017my $fixtures_path = path(Mojo::File->new(__FILE__)->dirname, 'server');
Akron32396632018-10-11 17:08:37 +020018my $fake_backend = $t->app->plugin(
19 Mount => {
20 $mount_point =>
Akron73f36082018-10-25 15:34:59 +020021 $fixtures_path->child('mock.pl')
Akron32396632018-10-11 17:08:37 +020022 }
23);
24# Configure fake backend
25$fake_backend->pattern->defaults->{app}->log($t->app->log);
26
Akron0e1ed242018-10-11 13:22:00 +020027# Query passed
Akron8ea84292018-10-24 13:41:52 +020028$t->get_ok('/?q=baum')
Akron0e1ed242018-10-11 13:22:00 +020029 ->status_is(200)
30 ->text_is('#error','')
Akron8ea84292018-10-24 13:41:52 +020031
Akron32396632018-10-11 17:08:37 +020032 ->text_is('title', 'KorAP: Find »baum« with Poliqarp')
33 ->element_exists('meta[name="DC.title"][content="KorAP: Find »baum« with Poliqarp"]')
Akron0e1ed242018-10-11 13:22:00 +020034 ->element_exists('body[itemscope][itemtype="http://schema.org/SearchResultsPage"]')
Akrondffa9392018-10-12 16:26:09 +020035
36 # Total results
Akron32396632018-10-11 17:08:37 +020037 ->text_is('#total-results', 51)
Akrondffa9392018-10-12 16:26:09 +020038
39 # Total pages
40 ->element_count_is('#pagination a', 5)
41
42 # api_response
43 ->content_like(qr/\"authorized\":null/)
44 ->content_like(qr/\"pubDate\",\"subTitle\",\"author\"/)
45
Akron8ea84292018-10-24 13:41:52 +020046 # No cutOff
47 ->content_unlike(qr!\"cutOff":true!)
48
Akrondffa9392018-10-12 16:26:09 +020049 ->element_exists('li[data-text-sigle=GOE/AGI/00000]')
50 ->element_exists('li:nth-of-type(1) div.flop')
51 ->element_exists('li[data-text-sigle=GOE/AGI/00001]')
52 ->element_exists('li:nth-of-type(2) div.flip')
53
54 # Match1
55 ->element_exists('li:nth-of-type(1)' .
56 '[data-match-id="p2030-2031"]' .
57 '[data-text-sigle="GOE/AGI/00000"]' .
58 '[id="GOE/AGI/00000#p2030-2031"]' .
59 '[data-available-info^="base/s=spans"]' .
60 '[data-info^="{"]')
61 ->text_is('li:nth-of-type(1) div.meta', 'GOE/AGI/00000')
62 ->element_exists('li:nth-of-type(1) div.match-main div.match-wrap div.snippet')
63 ->element_exists('li:nth-of-type(1) div.snippet.startMore.endMore')
64 ->text_like('li:nth-of-type(1) div.snippet span.context-left',qr!sie etwas bedeuten!)
65 ->text_like('li:nth-of-type(1) div.snippet span.context-left',qr!sie etwas bedeuten!)
66 ->text_is('li:nth-of-type(1) div.snippet span.match mark','Baum')
67 ->text_like('li:nth-of-type(1) div.snippet span.context-right',qr!es war!)
68 ->text_is('li:nth-of-type(1) p.ref strong', 'Italienische Reise')
69 ->text_like('li:nth-of-type(1) p.ref', qr!by Goethe, Johann Wolfgang!)
70 ->text_is('li:nth-of-type(1) p.ref time[datetime=1982]', 1982)
71 ->text_is('li:nth-of-type(1) p.ref span.sigle', '[GOE/AGI/00000]')
Akron8ea84292018-10-24 13:41:52 +020072 ->header_isnt('X-Kalamar-Cache', 'true')
Akron0e1ed242018-10-11 13:22:00 +020073 ;
74
Akron7093b812018-10-19 17:28:21 +020075
Akron8ea84292018-10-24 13:41:52 +020076$t->get_ok('/?q=[orth=das')
Akron7093b812018-10-19 17:28:21 +020077 ->status_is(400)
78 ->text_is('div.notify-error:nth-of-type(1)', '302: Parantheses/brackets unbalanced.')
79 ->text_like('div.notify-error:nth-of-type(2)', qr!302: Could not parse query .+? \[orth=das.+?!)
80 ;
81
Akron73f36082018-10-25 15:34:59 +020082# Check for query error with ql (from remote.t)
83$t->get_ok('/?q=[orth=das&ql=poliqarp')
84 ->element_exists('.notify-error')
85 ->text_is('.notify-error', '302: Parantheses/brackets unbalanced.')
86 ->content_like(qr!KorAP\.koralQuery =!)
87 ->text_is('.no-results:nth-of-type(1)', 'Unable to perform the search.')
88 ;
89
90
Akron8ea84292018-10-24 13:41:52 +020091# Query with partial cache (for total results)
92$t->get_ok('/?q=baum')
93 ->status_is(200)
94 ->text_is('#error','')
95 ->text_is('title', 'KorAP: Find »baum« with Poliqarp')
96 ->element_exists('meta[name="DC.title"][content="KorAP: Find »baum« with Poliqarp"]')
97 ->element_exists('body[itemscope][itemtype="http://schema.org/SearchResultsPage"]')
98 ->header_isnt('X-Kalamar-Cache', 'true')
99 ->content_like(qr!\"cutOff":true!)
100 ->text_is('#total-results', 51)
101 ;
102
103# Query with full cache
104$t->get_ok('/?q=baum')
105 ->status_is(200)
106 ->text_is('#error','')
107 ->text_is('title', 'KorAP: Find »baum« with Poliqarp')
108 ->element_exists('meta[name="DC.title"][content="KorAP: Find »baum« with Poliqarp"]')
109 ->element_exists('body[itemscope][itemtype="http://schema.org/SearchResultsPage"]')
110 ->header_is('X-Kalamar-Cache', 'true')
111 ->content_like(qr!\"cutOff":true!)
112 ->text_is('#total-results', 51)
113 ;
114
115
116# Query with page information
117$t->get_ok('/?q=der&p=1&count=2')
118 ->status_is(200)
119 ->text_is('#error','')
120 ->text_is('title', 'KorAP: Find »der« with Poliqarp')
121
122 # Total results
123 ->text_is('#total-results', '14,581')
124
125 # Total pages
126 ->element_count_is('#pagination a', 7)
127 ->text_is('#pagination a:nth-of-type(6) span', 7291)
128 ->content_like(qr!\"count":2!)
129 ->content_like(qr!\"startIndex":0!)
130 ->content_like(qr!\"itemsPerPage":2!)
131
132 # No caching
133 ->header_isnt('X-Kalamar-Cache', 'true')
134
135 # Not searched for "der" before
136 ->content_unlike(qr!\"cutOff":true!)
137 ;
138
139# Query with page information - next page
140$t->get_ok('/?q=der&p=2&count=2')
141 ->status_is(200)
142 ->text_is('#error','')
143 ->text_is('title', 'KorAP: Find »der« with Poliqarp')
144
145 # Total results
146 ->text_is('#total-results', '14,581')
147
148 # Total pages
149 ->element_count_is('#pagination a', 7)
150 ->text_is('#pagination a:nth-of-type(6) span', 7291)
151 ->content_like(qr!\"count":2!)
152 ->content_like(qr!\"itemsPerPage":2!)
153 ->content_like(qr!\"startIndex":2!)
154
155 # No caching
156 ->header_isnt('X-Kalamar-Cache', 'true')
157 ->content_like(qr!\"cutOff":true!)
158 ;
159
Akronc4be8192018-10-25 16:07:53 +0200160# Query with failing parameters
161$t->get_ok('/?q=fantastisch&ql=Fabelsprache')
162 ->status_is(400)
163 ->text_is('noscript div.notify-error', 'Parameter "ql" invalid')
164 ->element_count_is('noscript div.notify-error', 1)
165 ;
166$t->get_ok('/?q=fantastisch&cutoff=no')
167 ->status_is(400)
168 ->text_is('noscript div.notify-error', 'Parameter "cutoff" invalid')
169 ->element_count_is('noscript div.notify-error', 1)
170 ;
171$t->get_ok('/?q=fantastisch&p=hui&o=hui&count=-8')
172 ->status_is(400)
173 ->text_like('noscript div.notify-error', qr!Parameter ".+?" invalid!)
174 ->element_count_is('noscript div.notify-error', 3)
175 ;
Akron8ea84292018-10-24 13:41:52 +0200176
177
Akron0e1ed242018-10-11 13:22:00 +0200178done_testing;
Akron8ea84292018-10-24 13:41:52 +0200179__END__