X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=test%2Fspec%2Fmkws-pazpar2.js;h=0571fc3493644c9c612a6e4b795165e4c84ae31b;hb=70d7a8f39e2cebf24eaa40349626284adf8e980f;hp=cce2bb778f20f45e6db16af2ca5b85600fc07fc0;hpb=dc4efce7b2513756ce971f598a7dcf3bef0a2b8f;p=mkws-moved-to-github.git diff --git a/test/spec/mkws-pazpar2.js b/test/spec/mkws-pazpar2.js index cce2bb7..0571fc3 100644 --- a/test/spec/mkws-pazpar2.js +++ b/test/spec/mkws-pazpar2.js @@ -4,8 +4,10 @@ * */ -var debug_level = mkws.debug_level; -var debug = mkws.debug_function; +// get references from mkws.js, lazy evaluation +var debug = function (text) { + mkws.debug_function(text) + } var get_hit_counter = function () { // not yet here @@ -44,10 +46,14 @@ describe("Check pazpar2 search", function () { debug("set search query: " + search_query) expect($("input#mkwsQuery").val()).toMatch("^" + search_query + "$"); - // wait for service proxy auth - waitsFor(function () { - return mkws.authenticated; - }, "SP auth done", 10 * 1000); + if (mkws_config.use_service_proxy) { + // wait for service proxy auth + waitsFor(function () { + return mkws.authenticated; + }, "SP auth done", 10 * 1000); + } else { + debug("running raw pp2, don't wait for mkws auth"); + } runs(function () { debug("Click on submit button"); @@ -155,14 +161,21 @@ describe("Check Termlist", function () { it("limit search to first author", function () { var hits_all_targets = get_hit_counter(); + var author_number = 2; // 2=first author + + var author_name = $("div#mkwsFacetAuthors div.term:nth-child(" + author_number + ") a").text(); + // do not click on author with numbers, e.g.: Bower, James M. Beeman, David, 1938- + if (author_name.match(/[0-9].+[0-9]/)) { + author_number++; + } - var click = $("div#mkwsFacetAuthors div.term:nth-child(2) a").trigger("click"); + var click = $("div#mkwsFacetAuthors div.term:nth-child(" + author_number + ") a").trigger("click"); debug("limit author click is success: " + click.length); expect(click.length).toBe(1); waitsFor(function () { return get_hit_counter() < hits_all_targets ? true : false; - }, "Limited author search for less than " + hits_all_targets + " hits", 8 * 1000); + }, "Limited author search for less than " + hits_all_targets + " hits", 6 * 1000); runs(function () { var hits_single_target = get_hit_counter(); @@ -192,14 +205,16 @@ describe("Check Termlist", function () { } }, "Search for source in navi bar", 1000); + // Note: it may happens that limited source search returns the same number of hits + // as before. Thats not really an error, but unfortunate waitsFor(function () { - return get_hit_counter() < hits_all_targets ? true : false; - }, "Limited source earch for less than " + hits_all_targets + " hits", 9 * 1000); + return get_hit_counter() <= hits_all_targets ? true : false; + }, "Limited source search for less than " + hits_all_targets + " hits", 5 * 1000); runs(function () { var hits_single_target = get_hit_counter(); debug("get less hits for sources: " + hits_all_targets + " > " + hits_single_target); - expect(hits_all_targets).toBeGreaterThan(hits_single_target); + expect(hits_all_targets).not.toBeLessThan(hits_single_target); }); }); }); @@ -224,6 +239,11 @@ describe("Show record", function () { }); it("extract URL", function () { + if (mkws_config.jasmine && mkws_config.jasmine.show_record_url == false) { + debug("ignore test for URL in record") + return; + } + var url = $("div#mkwsRecords div.record:nth-child(" + record_number + ") div table tbody tr td a").text(); debug("extracted URL from record: " + url); @@ -282,19 +302,21 @@ describe("Check status client counter", function () { it("check status clients", function () { waitsFor(function () { var clients = $("div#mkwsStat span.clients"); - if (clients.length == 1 && clients.text() == "0/1") { + if (clients.length == 1 && clients.text().match("0/1$")) { return true; } else { return false; } - }, "wait for status", 4 * 1000); + }, "wait for Active clients: 0/1", 4 * 1000); +/* runs(function () { var clients = $("div#mkwsStat span.clients"); debug("span.clients: " + clients.text()); expect(clients.text()).toEqual("0/1"); }); + */ });