blob: c34248386fe73652ea31a3f1fcbba6ee912eba90 [file] [log] [blame]
hebasta75cfca52019-02-19 13:15:27 +01001/**
hebasta87f1b1f2019-07-30 13:03:23 +02002 * Test suite for guided tour
hebasta75cfca52019-02-19 13:15:27 +01003 *
4 * @author Helge Stallkamp
5 */
6
hebastafa118342021-11-02 19:56:01 +01007define(['tour/tours', 'vc', 'vc/unspecified', 'session', 'match', 'hint', 'hint/foundries/cnx', 'selectMenu', 'loc/dereko'], function(tourClass, vcClass, docClassUnspec, sessionClass, matchClass, hintClass, hintArray, selectMenuClass){
hebasta75cfca52019-02-19 13:15:27 +01008 const loc = KorAP.Locale;
hebastaf95226b2019-09-19 11:37:00 +02009
hebasta0c93d8e2019-05-15 12:06:16 +020010 var introKorAP =
11 "<form autocomplete='off' action='/' id='searchform'>" +
12 "<div id='searchbar' class=''>" +
13 "<input autocapitalize='off' autocomplete='off' autocorrect='off' autofocus='autofocus' id='q-field' name='q' placeholder='Finde ...' spellcheck='false' type='search'>" +
hebasta5df796f2019-05-21 15:27:12 +020014 "<button type='submit' id='qsubmit' title='Los!'><span>Los!</span></button>" +
hebasta0c93d8e2019-05-15 12:06:16 +020015 "</div>" +
Akroncd42a142019-07-12 18:55:37 +020016 "<!-- Search in the following virtual corpus -->"+
hebastafa118342021-11-02 19:56:01 +010017 "<div id='vc-view'>" +
18 "<div class='vc'>"+
19 "<div class='builder'>"+
20 "<div class='doc unspecified'><span>⋯</span></div>" +
21 "</div>" +
22 "<div class='action button-view button-group'><span title='Zuklappen' class='button-icon minimize'><span>Zuklappen</span></span></div>" +
23 "<div>" +
24 "<div class='panel vcinfo'>" +
25 "<div></div>" +
26 "<div class='action button-panel vcinfo button-group'><span title='Korpusstatistik' class='statistic'><span>Korpusstatistik</span></span></div>" +
27 "</div>" +
28 "</div>" +
29 "</div>" +
hebasta0c93d8e2019-05-15 12:06:16 +020030 "in" +
31 "<span id='vc-choose' class='select'><span>allen Korpora</span></span>" +
Akroncd42a142019-07-12 18:55:37 +020032 "<input id='cq' name='cq' type='text' style='display: none;'>" +
hebasta0c93d8e2019-05-15 12:06:16 +020033 "mit" +
34 "<span class='select'>" +
35 "<select id='ql-field' name='ql' style='display: none;'>" +
36 "<option value='poliqarp'>Poliqarp</option>" +
37 "<option value='cosmas2'>Cosmas II</option>" +
38 "<option value='annis'>Annis QL</option>" +
39 "<option value='cql'>CQL v1.2</option>" +
40 "<option value='fcsql'>FCSQL</option>" +
41 "</select>" +
42 "<span style='display: inline;'> Poliqarp</span>" +
43 "<ul style='outline: currentcolor none 0px;' tabindex='0' class='menu roll'>" +
44 "<span class='pref'></span>" +
45 "<div class='lengthField'>" +
46 "<span>Poliqarp--</span>" +
47 "<span>Cosmas II--</span>" +
48 "<span>Annis QL--</span>" +
49 "<span>CQL v1.2--</span>" +
50 "<span>FCSQL--</span>" +
51 "</div><div class='ruler' style='display: none;'><span></span><div></div>" +
52 "</div>" +
53 "</ul>" +
54 "</span>" +
55 "<div class='button right'>" +
56 "<input checked='' class='checkbox' id='q-cutoff-field' name='cutoff' type='checkbox' value='1'>" +
57 "<label for='q-cutoff-field' title='Zeige nur die ersten Treffer in beliebiger Reihenfolge'><span id='glimpse'></span>Glimpse</label>" +
hebasta0c93d8e2019-05-15 12:06:16 +020058 "</div>" +
59 "<div class='clear'></div>"+
60 "</form>" +
61 "<div class='hint mirror' style='height: 0px; left: 238px; top: 36px; width: 1272px; padding-left: 2px; margin-left: 0px; border-left-width: 2px; border-left-style: solid; font-size: 14.6667px; font-family: Noto Sans;'>" +
62 "<span></span>" +
63 "<div id='hint' class=''>" +
64 "<div style='display: none;' class='alert hint'></div>" +
65 "<ul style='outline: currentcolor none 0px;' tabindex='0' class='menu roll hint'>" +
66 "<span class='pref'></span>" +
67 "<div class='lengthField'>" +
68 "<span>Base Annotation--</span>" +
69 "<span class='desc'>Structure--</span>" +
70 "<span>DeReKo--</span><span class='desc'>Structure--</span>"+
71 "</div>"
72 "<div class='ruler' style='display: none;'><span></span><div></div></div>"
73 "</ul>" +
74 "</div>" +
75 "</div>";
hebastad090a512019-07-10 16:36:01 +020076
77
hebasta94e47cb2019-07-24 22:24:27 +020078 var preDefinedStat={
79 "documents":12,
80 "tokens":2323,
81 "sentences":343434,
82 "paragraphs":45454545
83 };
84
85
86 KorAP.API.getCorpStat = function(collQu, cb){
87 return cb(preDefinedStat);
88 };
89
hebasta75cfca52019-02-19 13:15:27 +010090
hebasta87f1b1f2019-07-30 13:03:23 +020091 var resultkorap =
92 "<div id='search'>" +
93 "<ol class='align-left' tabindex='-8'>" +
94 "<li data-corpus-id='WPD' " +
95 "data-doc-id='WWW'" +
96 "data-text-id='03313'" +
97 "data-match-id='p102-103'" +
98 "data-available-info='base/s=spans corenlp/c=spans corenlp/ne=tokens corenlp/p=tokens corenlp/s=spans glemm/l=tokens mate/l=tokens mate/m=tokens mate/p=tokens opennlp/p=tokens opennlp/s=spans tt/l=tokens tt/p=tokens tt/s=spans xip/c=spans malt/d=rels'"+
99 "id='WPD-WWW.03313-p102-103'" +
100 "tabindex='6'>" +
101 "<div class='meta'>WPD/WWW/03313</div>" +
102 "<div class='match-main'>" +
103 "<div class='match-wrap'>" +
104 "<div class='snippet startMore endMore'>" +
105 "<div class='flag'></div>" +
106 "<span class='context-left'>In diesem Beispiel ist zu sehen, dass die beiden Variablen a und b lediglich ihre Werte an" +
107 " die Funktion </span><mark><mark class='class-2 level-1'>Dies </mark><mark class='class-1 level-0'><mark class='class-2 level-1'><mark class='class-3 level-2'>ist</mark>" +
108 " ein</mark> Test</mark></mark><span class='context-right'> übergeben, aber im Gegensatz zu einem Referenzparamter dabei unverändert bleiben.</span></div>" +
109 "</div>"+
110 "<!-- only inject via javascript! -->" +
111 "</div>" +
112 "<p class='ref'><strong>Wertparameter</strong> by Hubi,Zwobot,4; published on 2005-03-28 as WWW.03313 (WPD)</p>" +
113 "<!-- only inject via javascript! -->" +
114 "</li>" +
115 "</div>";
116
117
118
119 var snippet = "<span title=\"cnx/l:meist\">" +
120 " <span title=\"cnx/p:ADV\">" +
121 " <span title=\"cnx/syn:@PREMOD\">" +
122 " <span title=\"mate/l:meist\">" +
123 " <span title=\"mate/l:meist\">" +
124 " <span title=\"mate/p:ADV\">" +
125 " <span title=\"opennlp/p:ADV\">meist</span>" +
126 " </span>" +
127 " </span>" +
128 " </span>" +
129 " </span>" +
130 " </span>" +
131 "</span>" +
132 "<mark>" +
133 "<span title=\"cnx/l:deutlich\">" +
134 " <span title=\"cnx/p:A\">" +
135 " <span title=\"cnx/syn:@PREMOD\">" +
136 " <span title=\"mate/l:deutlich\">" +
137 " <span title=\"mate/m:degree:pos\">" +
138 " <span title=\"mate/p:ADJD\">" +
139 " <span title=\"opennlp/p:ADJD\">deutlich</span>" +
140 " </span>" +
141 " </span>" +
142 " </span>" +
143 " </span>" +
144 " </span>" +
145 "</span>" +
146 "</mark>" +
147 "<span title=\"cnx/l:fähig\">" +
148 " <span title=\"cnx/l:leistung\">" +
149 " <span title=\"cnx/p:A\">" +
150 " <span title=\"cnx/p:ADJA\">" +
151 " <span title=\"cnx/syn:@NH\">" +
152 " <span title=\"mate/l:leistungsfähig\">" +
153 " <span title=\"mate/m:degree:comp\">" +
154 " <span title=\"mate/p:ADJD\">" +
155 " <span title=\"opennlp/p:ADJD\">leistungsfähiger</span>" +
156 " </span>" +
157 " </span>" +
158 " </span>" +
159 " </span>" +
160 " </span>" +
161 " </span>" +
162 " </span>" +
163 "</span>";
164
165 var treeSnippet =
166 "<span class=\"context-left\"></span>" +
167 "<span class=\"match\">" +
168 " <span title=\"xip/c:MC\">" +
169 " <span title=\"xip/c:TOP\">" +
170 " <span title=\"xip/c:PP\">" +
171 " <span title=\"xip/c:PREP\">Mit</span>" +
172 " <span title=\"xip/c:NP\">" +
173 " <span title=\"xip/c:DET\">dieser</span>" +
174 " <span title=\"xip/c:NPA\">" +
175 " <span title=\"xip/c:NOUN\">Methode</span>" +
176 " </span>" +
177 " </span>" +
178 " </span>" +
179 " <span title=\"xip/c:VERB\">ist</span>" +
180 " <mark>" +
181 " <span title=\"xip/c:NP\">" +
182 " <span title=\"xip/c:PRON\">es</span>" +
183 " </span>" +
184 " <span title=\"xip/c:AP\">" +
185 " <span title=\"xip/c:ADV\">nun</span>" +
186 " <span title=\"xip/c:ADJ\">möglich</span>" +
187 " </span>" +
188 " </mark>" +
189 " <span title=\"xip/c:ADV\">z. B.</span>" +
190 " <span title=\"xip/c:NPA\">" +
191 " <span title=\"xip/c:NP\">" +
192 " <span title=\"xip/c:NOUN\">Voice</span>" +
193 " </span>" +
194 " </span>" + "(" +
195 " <span title=\"xip/c:INS\">" +
196 " <span title=\"xip/c:NPA\">" +
197 " <span title=\"xip/c:NP\">" +
198 " <span title=\"xip/c:NOUN\">Sprache</span>" +
199 " </span>" +
200 " </span>" +
201 " </span>" + ")" +
202 " <span title=\"xip/c:VERB\">bevorzugt</span>" +
203 " <span title=\"xip/c:PP\">" +
204 " <span title=\"xip/c:PREP\">in</span>" +
205 " <span title=\"xip/c:NP\">" +
206 " <span title=\"xip/c:PRON\">der</span>" +
207 " </span>" +
208 " <span title=\"xip/c:NPA\">" +
209 " <span title=\"xip/c:NP\">" +
210 " <span title=\"xip/c:NOUN\">Bridge</span>" +
211 " </span>" +
212 " </span>" +
213 " </span>" +
214 " <span title=\"xip/c:INFC\">" +
215 " <span title=\"xip/c:INS\">" +
216 " <span title=\"xip/c:VERB\">weiterzugeben</span>" +
217 " </span>" +
218 " </span>" +
219 " </span>" +
220 " </span>" +
221 "</span>" +
222 "<span class=\"context-right\"></span>";
223
224 KorAP.API.getTextInfo = function (doc, param, cb) {
225 cb(textInfo);
226 };
227
228 // Override getMatchInfo API call
229 KorAP.API.getMatchInfo = function (x, param, cb) {
230 if (param['spans'] === undefined || param['spans'] === false)
231 cb({ "snippet": snippet });
232 else
233 cb({ "snippet": treeSnippet });
234 };
235
236 var textInfo = {
237 "@context":"http:\/\/korap.ids-mannheim.de\/ns\/KoralQuery\/v0.3\/context.jsonld",
238 "document":{
239 "@type":"koral:document",
240 "fields":[
241 {
242 "@type":"koral:field",
243 "key":"editor",
244 "type":"type:store",
245 "value":"wikipedia.org"
246 },
247 {
248 "@type":"koral:field",
249 "key":"textSigle",
250 "type":"type:string",
251 "value":"WPD15\/264\/58336"
252 },
253 {
254 "@type":"koral:field",
255 "key":"author",
256 "type":"type:text",
257 "value":"Sprachpfleger, u.a."
258 },
259 {
260 "@type":"koral:field",
261 "key":"docSigle",
262 "type":"type:string",
263 "value":"WPD15\/264"
264 },
265 {
266 "@type":"koral:field",
267 "key":"textTypeArt",
268 "type":"type:string",
269 "value":"Enzyklopädie-Artikel"
270 },
271 {
272 "@type":"koral:field",
273 "key":"language",
274 "type":"type:string",
275 "value":"de"
276 },
277 {
278 "@type":"koral:field",
279 "key":"docTitle",
280 "type":"type:text",
281 "value":"Wikipedia, Artikel mit Anfangszahl 2, Teil 64"
282 },
283 {
284 "@type":"koral:field",
285 "key":"textType",
286 "type":"type:string",
287 "value":"Enzyklopädie"
288 },
289 {
290 "@type":"koral:field",
291 "key":"availability",
292 "type":"type:string",
293 "value":"CC-BY-SA"
294 },
295 {
296 "@type":"koral:field",
297 "key":"foundries",
298 "type":"type:keywords",
299 "value":[
300 "corenlp",
301 "corenlp\/constituency",
302 "corenlp\/morpho",
303 "corenlp\/sentences",
304 "dereko",
305 "dereko\/structure",
306 "dereko\/structure\/base-sentences-paragraphs-pagebreaks",
307 "opennlp",
308 "opennlp\/morpho",
309 "opennlp\/sentences"
310 ]
311 },
312 {
313 "@type":"koral:field",
314 "key":"creationDate",
315 "type":"type:date",
316 "value":"2015-04-17"
317 },
318 {
319 "@type":"koral:field",
320 "key":"title",
321 "type":"type:text",
322 "value":"22:43 – Das Schicksal hat einen Plan"
323 },
324 {
325 "@type":"koral:field",
326 "key":"pubDate",
327 "type":"type:date",
328 "value":"2015-05-01"
329 },
330 {
331 "@type":"koral:field",
332 "key":"reference",
333 "type":"type:store",
334 "value":"22:43 – Das Schicksal hat einen Plan, In: Wikipedia - URL:http:\/\/de.wikipedia.org\/wiki\/22:43_–_Das_Schicksal_hat_einen_Plan: Wikipedia, 2015"
335 },
336 {
337 "@type":"koral:field",
338 "key":"textClass",
339 "type":"type:keywords",
340 "value":["kultur","film"]
341 },
342 {
343 "@type":"koral:field",
344 "key":"tokenSource",
345 "type":"type:store",
346 "value":"base#tokens"
347 },
348 {
349 "@type":"koral:field",
350 "key":"publisher",
351 "type":"type:store",
352 "value":"Wikipedia"
353 },
354 {
355 "@type":"koral:field",
356 "key":"layerInfos",
357 "type":"type:store",
358 "value":"corenlp\/c=spans corenlp\/p=tokens corenlp\/s=spans dereko\/s=spans opennlp\/p=tokens opennlp\/s=spans"
359 },
360 {
361 "@type":"koral:field",
362 "key":"pubPlace",
363 "type":"type:string",
364 "value":"URL:http:\/\/de.wikipedia.org"
365 },
366 {
367 "@type":"koral:field",
368 "key":"corpusTitle",
369 "type":"type:text",
370 "value":"Wikipedia"
371 },
372 {
373 "@type":"koral:field",
374 "key":"corpusEditor",
375 "type":"type:store",
376 "value":"wikipedia.org"
377 },
378 {
379 "@type":"koral:field",
380 "key":"corpusSigle",
381 "type":"type:string",
382 "value":"WPD15"
383 }
384 ]
385 }
386 };
hebasta75cfca52019-02-19 13:15:27 +0100387 let template = document.createElement('template');
hebasta94e47cb2019-07-24 22:24:27 +0200388 let html = introKorAP.trim(); // Do not return a text node of whitespace as the result
hebasta75cfca52019-02-19 13:15:27 +0100389 template.innerHTML = html;
hebasta94e47cb2019-07-24 22:24:27 +0200390 let intrkorap = template.content;
hebasta75cfca52019-02-19 13:15:27 +0100391
hebasta87f1b1f2019-07-30 13:03:23 +0200392 let resulttemplate = document.createElement('template');
393 let htmlZwei = resultkorap.trim();
394 resulttemplate.innerHTML = resultkorap;
395 var resultkor = resulttemplate.content;
396
397 resultkor.querySelector('#search > ol > li:not(.active)').addEventListener('click', function (e) {
398 if (this._match !== undefined)
399 this._match.open();
400 else {
401 matchClass.create(this).open();
402 }
403 });
404
hebasta94e47cb2019-07-24 22:24:27 +0200405 let vc= vcClass.create().fromJson({
406 '@type' : 'koral:doc',
407 'key' : 'title',
408 'match': 'match:eq',
409 'value' : 'TestTour!',
410 'type' : 'type:string'
411 });
412
413 KorAP.vc = vc;
hebastaf95226b2019-09-19 11:37:00 +0200414
hebasta75cfca52019-02-19 13:15:27 +0100415 describe('KorAP.GuidedTour', function(){
hebasta87f1b1f2019-07-30 13:03:23 +0200416
417 afterAll(function () {
418 KorAP.API.getMatchInfo = undefined;
419 var body = document.body;
420 var i = body.children.length - 1;
421 while (i >= 0) {
422 if (body.children[i].nodeType && body.children[i].nodeType === 1) {
423 if (!body.children[i].classList.contains("jasmine_html-reporter")) {
424 body.removeChild(body.children[i]);
425 };
426 };
427 i--;
428 };
429 })
hebastaf95226b2019-09-19 11:37:00 +0200430
431 KorAP.Hint = hintClass.create({inputField: intrkorap.getElementById("q-field")});
432
hebastafa118342021-11-02 19:56:01 +0100433
hebasta75cfca52019-02-19 13:15:27 +0100434 it('IDs and classes, that are needed for the guided tour should be in existence', function(){
hebasta87f1b1f2019-07-30 13:03:23 +0200435 //gTstartSearch
hebasta75cfca52019-02-19 13:15:27 +0100436 expect(intrkorap.querySelector('#searchbar')).not.toBeNull();
437 expect(intrkorap.querySelector('#q-field')).not.toBeNull();
hebasta0c93d8e2019-05-15 12:06:16 +0200438 expect(intrkorap.querySelector('#hint')).not.toBeNull();
439 expect(intrkorap.querySelector('#vc-choose')).not.toBeNull();
hebasta75cfca52019-02-19 13:15:27 +0100440 expect(intrkorap.querySelector('#vc-view')).not.toBeNull();
hebastafa118342021-11-02 19:56:01 +0100441 expect(intrkorap.querySelector('#vc-view * .doc')).not.toBeNull();
hebasta75cfca52019-02-19 13:15:27 +0100442 expect(intrkorap.querySelector('#ql-field').parentNode).not.toBeNull();
hebastabd53f822021-10-26 21:50:06 +0200443 expect(intrkorap.querySelector('#glimpse').parentNode).not.toBeNull();
hebasta75cfca52019-02-19 13:15:27 +0100444 expect(intrkorap.querySelector('#view-tutorial')).not.toBeNull();
hebasta5df796f2019-05-21 15:27:12 +0200445 expect(intrkorap.querySelector('#qsubmit')).not.toBeNull();
hebasta94e47cb2019-07-24 22:24:27 +0200446 let show = document.createElement('div');
hebastad090a512019-07-10 16:36:01 +0200447 show.appendChild(vc.element());
hebasta94e47cb2019-07-24 22:24:27 +0200448 let statbut = show.querySelector('.statistic');
449 expect(statbut).not.toBeNull();
450 statbut.click();
451 expect(show.querySelector('.stattable')).not.toBeNull();
hebastafa118342021-11-02 19:56:01 +0100452 let docUnspec = document.createElement('div');
453 let doc = docClassUnspec.create();
454 docUnspec.append(doc.element());
455 let vcbut = docUnspec.querySelector('.doc > span');
456 vcbut.click();
457 expect(docUnspec.querySelector('.menu.roll')).not.toBeNull();
458
hebasta87f1b1f2019-07-30 13:03:23 +0200459 //IDs and classes, that are needed for the second guided tour(gTshowResults()) should be in existence, too
460 expect(resultkor.querySelector('#search')).not.toBeNull();
461 expect(resultkor.querySelector('#search > ol > li')).not.toBeNull();
462 resultkor.querySelector("#search > ol > li").click();
463 expect(resultkor.querySelector('.action > .metatable')).not.toBeNull();
464 resultkor.querySelector(".metatable").click();
465 expect(resultkor.querySelector('.view.metatable')).not.toBeNull();
466 expect(resultkor.querySelector('.action > .info')).not.toBeNull();
467 resultkor.querySelector(".info").click();
468 expect(resultkor.querySelector('.view.tokentable')).not.toBeNull();
469 expect(resultkor.querySelector('.tree')).not.toBeNull();
hebastafa118342021-11-02 19:56:01 +0100470
hebasta75cfca52019-02-19 13:15:27 +0100471 });
hebasta87f1b1f2019-07-30 13:03:23 +0200472
hebasta75cfca52019-02-19 13:15:27 +0100473 it('Guided Tour should be started and display steps and labels in the right order', function(){
hebastaf95226b2019-09-19 11:37:00 +0200474
hebasta94e47cb2019-07-24 22:24:27 +0200475 let vcpanel = intrkorap.getElementById("vc-view");
476 vcpanel.appendChild(vc.element());
hebasta5df796f2019-05-21 15:27:12 +0200477 let searchTour = tourClass.gTstartSearch(intrkorap);
478 searchTour.start();
479 let totalSteps = searchTour.stepCount;
hebasta1e2d98e2019-10-30 15:58:17 +0100480 let welc = document.createElement("DIV");
481 welc.innerHTML = loc.TOUR_welc;
482 expect(document.querySelector(".introjs-tooltiptext").textContent).toEqual(welc.textContent);
hebasta75cfca52019-02-19 13:15:27 +0100483 expect(document.querySelector(".introjs-prevbutton").textContent).toEqual(loc.TOUR_lprev);
484 expect(document.querySelector(".introjs-nextbutton").textContent).toEqual(loc.TOUR_lnext);
hebastaa84c7a92021-10-26 21:12:40 +0200485 expect(document.querySelector(".introjs-skipbutton")).toBeDefined();
hebasta5df796f2019-05-21 15:27:12 +0200486 searchTour.exit();
hebasta75cfca52019-02-19 13:15:27 +0100487
hebastafa118342021-11-02 19:56:01 +0100488 let show = document.createElement('div');
489 show.appendChild(vc.element());
490 let statbut = show.querySelector('.statistic');
491 statbut.click();
492 let corpstat = show.querySelector('.stattable');
493 intrkorap.appendChild(corpstat);
494
hebasta75cfca52019-02-19 13:15:27 +0100495 for(let i = 2; i <= totalSteps; i++){
hebasta5df796f2019-05-21 15:27:12 +0200496 searchTour.goToStepNumber(i);
hebastaf898d7b2021-12-06 14:32:06 +0100497 if(i ==3){
498 //Test for equality. Ignore HTML-Tags, replace down arrow.
499 expect(document.querySelector(".introjs-tooltiptext").textContent).toEqual((searchTour.testIntros[i-1]).replace(/(<([^>]+)>)/ig,"").replace("&darr;","↓"));
500 }
501 else{
502 //Test for equality. Ignore HTML-Tags.
503 expect(document.querySelector(".introjs-tooltiptext").textContent).toEqual((searchTour.testIntros[i-1]).replace(/(<([^>]+)>)/ig,""));
504 }
hebastaf95226b2019-09-19 11:37:00 +0200505 switch(i){
hebastaee7b8a82020-01-20 12:45:04 +0100506 case 4:
hebastafa118342021-11-02 19:56:01 +0100507 expect(intrkorap.querySelector('#hint')).not.toBeNull();
508 expect(KorAP.Hint).not.toBeNull();
509 expect(KorAP.Hint.active().dontHide).toBe(true);
510 expect(KorAP.Hint._active).not.toBeNull();
511 break;
hebastaee7b8a82020-01-20 12:45:04 +0100512 case 5:
hebastafa118342021-11-02 19:56:01 +0100513 expect(KorAP.Hint._active).toBeNull();
514 break;
515 case 6:
516 expect(KorAP._vcKeyMenu.dontHide).toBe(false);
517 break;
518 case 7:
519 expect(KorAP._vcKeyMenu.dontHide).toBe(true);
520 break;
521 case 8:
522 expect(KorAP._vcKeyMenu.dontHide).toBe(false);
523 break;
hebastaf95226b2019-09-19 11:37:00 +0200524 case totalSteps:
hebastafa118342021-11-02 19:56:01 +0100525 expect(document.querySelector(".introjs-donebutton").textContent).toEqual(loc.TOUR_ldoneSearch);
526 expect(document.querySelector(".introjs-prevbutton").textContent).toEqual(loc.TOUR_lprev);
527 expect(document.querySelector(".introjs-skipbutton")).toBeDefined();
528 break;
hebastaf95226b2019-09-19 11:37:00 +0200529 }
hebasta5df796f2019-05-21 15:27:12 +0200530 searchTour.exit();
hebastafa118342021-11-02 19:56:01 +0100531 }
hebasta5df796f2019-05-21 15:27:12 +0200532
hebasta87f1b1f2019-07-30 13:03:23 +0200533 let resultTour = tourClass.gTshowResults(resultkor);
hebasta5df796f2019-05-21 15:27:12 +0200534 KorAP.session = sessionClass.create('KalamarJSDem');
hebastaf95226b2019-09-19 11:37:00 +0200535
hebasta87f1b1f2019-07-30 13:03:23 +0200536 resultTour.start(resultkor);
537 let totalStepsR = resultTour.stepCount;
538 expect(document.querySelector(".introjs-tooltiptext").textContent).toEqual(loc.TOUR_kwic);
hebasta87f1b1f2019-07-30 13:03:23 +0200539 expect(document.querySelector(".introjs-prevbutton").textContent).toEqual(loc.TOUR_lprev);
540 expect(document.querySelector(".introjs-nextbutton").textContent).toEqual(loc.TOUR_lnext);
hebastaa84c7a92021-10-26 21:12:40 +0200541 expect(document.querySelector(".introjs-skipbutton")).toBeDefined();
hebasta5df796f2019-05-21 15:27:12 +0200542 resultTour.exit();
hebastaf95226b2019-09-19 11:37:00 +0200543 for(let i = 2; i <= totalStepsR; i++){
hebasta87f1b1f2019-07-30 13:03:23 +0200544 resultTour.goToStepNumber(i);
545 expect(document.querySelector(".introjs-tooltiptext").textContent).toEqual(resultTour.testIntros[i-1]);
546 if(i == totalStepsR){
547 expect(document.querySelector(".introjs-donebutton").textContent).toEqual(loc.TOUR_ldone);
548 }
549 resultTour.exit();
550 }
551 });
hebastaf95226b2019-09-19 11:37:00 +0200552
hebastafa118342021-11-02 19:56:01 +0100553 it('Guided Tour should hide Hint if aborted', function(){
hebastaf95226b2019-09-19 11:37:00 +0200554 let tourAbort = tourClass.gTstartSearch(intrkorap);
555 tourAbort.start();
556 expect(KorAP.Hint._active).toBeNull();
557 expect(document.querySelector(".introjs-skipbutton")).not.toBeNull();
hebastaee7b8a82020-01-20 12:45:04 +0100558 tourAbort.goToStepNumber(4);
hebastaf95226b2019-09-19 11:37:00 +0200559 expect(KorAP.Hint._active).not.toBeNull()
560 expect(KorAP.Hint.active().dontHide).toBe(true);
561 tourAbort.exit();
562 expect(KorAP.Hint._active).toBeNull();
563 });
hebastafa118342021-11-02 19:56:01 +0100564
565 it('Guided Tour should hide vcKeyMenu if aborted', function(){
566 let tourAbort = tourClass.gTstartSearch(intrkorap);
567 tourAbort.start();
568 expect(KorAP._vcKeyMenu.dontHide).toBe(false);
569 tourAbort.goToStepNumber(6);
570 expect(KorAP._vcKeyMenu.dontHide).toBe(false);
571 tourAbort.goToStepNumber(7);
572 expect(KorAP._vcKeyMenu.dontHide).toBe(true);
573 tourAbort.exit();
574 expect(KorAP._vcKeyMenu.dontHide).toBe(false);
575 });
576
577 it('Guided Tour should hide vcKeyMenu in the next step ', function(){
578 let tourNext = tourClass.gTstartSearch(intrkorap);
579 tourNext.start();
580 expect(KorAP._vcKeyMenu.dontHide).toBe(false);
581 tourNext.goToStepNumber(7);
582 expect(KorAP._vcKeyMenu.dontHide).toBe(true);
583 tourNext.goToStepNumber(8);
584 expect(KorAP._vcKeyMenu.dontHide).toBe(false);
585 });
586
587
hebastaf95226b2019-09-19 11:37:00 +0200588
hebasta75cfca52019-02-19 13:15:27 +0100589 });
hebasta87f1b1f2019-07-30 13:03:23 +0200590});