+ runs(function () {
+ var clients = mkws.$("div.mkwsStat span.mkwsClientCount");
+ debug("span.mkwsClientCount: " + clients.text());
+ expect(clients.text()).toMatch("/[1-9]+[0-9]*$");
+
+ // exact match of active clients (e.g. a SP misconfiguration)
+ if (jasmine_config.active_clients) {
+ debug("check for " + jasmine_config.active_clients + " active connections");
+ expect(clients.text()).toMatch(" [0-9]+/" + jasmine_config.active_clients + "$");
+ }
+ });
+ });
+});
+
+describe("Check Source Facets", function () {
+ it("limit search to first source", function () {
+ var hits_all_targets = get_hit_counter();
+ var source_number = 2; // 2=first source
+ // wait for a stat response
+ var waitcount = 0;
+ // do not click on wikipedia link - no author or subject facets possible
+ var link = "div.mkwsFacet[data-mkws-facet='xtargets'] div.mkwsTerm a";
+
+ // wait for a visible source link in facets
+ waitsFor(function () {
+ var terms = mkws.$(link);
+ return terms && terms.length > 0;
+ }, "wait for source facets after author search", 5 * jasmine_config.second);
+
+
+ runs(function () {
+ var terms = mkws.$(link);
+ for (var i = 0; i < terms.length; i++) {
+ var term = mkws.$(terms[i]).text();
+ debug("check for good source: " + term);
+
+ if (term.match(/wikipedia/i)) {
+ debug("ignore source facet: " + term);
+ source_number++;
+ } else {
+ break;
+ }
+ }
+ debug("Source counter: " + terms.length + ", select: " + (source_number - 1));
+
+ if (mkws.$("div.mkwsFacet[data-mkws-facet='xtargets'] div.mkwsTerm:nth-child(" + source_number + ") a").text().length == 0) {
+ debug("No good source found. Not clicking on the bad ones");
+ return;
+ }
+
+ debug("click on source link nth-child(): " + source_number);
+ mkws.$("div.mkwsFacet[data-mkws-facet='xtargets'] div.mkwsTerm:nth-child(" + source_number + ") a").trigger("click");
+
+ mkws.$(".mkwsPager").bind("DOMNodeInserted DOMNodeRemoved propertychange", function () {
+ waitcount++;
+ debug("DOM wait for stat: " + waitcount);
+ });
+ });
+
+ waitsFor(function () {
+ if (mkws.$("div.mkwsNavi").length && mkws.$("div.mkwsNavi").text().match(/(Source|datenquelle|kilder): /i)) {
+ return true;
+ } else {
+ return false;
+ }
+ }, "Search for source in navi bar", 4 * jasmine_config.second);
+
+ // 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 () {
+ var hits_single_target = get_hit_counter();
+
+ return waitcount >= 2 && hits_single_target > 0 && hits_single_target <= hits_all_targets ? true : false;
+ }, "Limited source search for less than " + hits_all_targets + " hits", 5 * jasmine_config.second);
+
+ 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).not.toBeLessThan(hits_single_target);
+ jasmine_status.source_click = 1;
+
+ mkws.$(".mkwsPager").unbind("DOMNodeInserted DOMNodeRemoved propertychange");
+ });
+ });
+});
+
+
+describe("Check record list", function () {
+ it("check for single active client", function () {
+ if (!jasmine_status.source_click) {
+ debug("skip clients check due missing source click");
+ return;
+ }
+
+ waitsFor(function () {
+ var clients = mkws.$("div.mkwsStat span.mkwsClientCount");
+ //debug("clients: " + clients.text());
+ return clients.length == 1 && clients.text().match("/1$");
+ }, "wait for Active clients: x/1", 5 * jasmine_config.second);
+
+ runs(function () {
+ var clients = mkws.$("div.mkwsStat span.mkwsClientCount");
+ debug("span.mkwsClientCount: " + clients.text());
+ expect(clients.text()).toMatch("/1$");
+ });
+ });
+
+ it("got a record", function () {
+ var linkaddr = "div.mkwsRecords div.mkwsSummary:nth-child(1) a";
+
+ waitsFor(function () {
+ // remove + insert node: must be at least 2
+ return mkws.$(linkaddr).length > 0;
+ }, "wait until we see a new record", 2.5 * jasmine_config.second);
+
+ runs(function () {
+ expect(mkws.$(linkaddr).length).toBeGreaterThan(0);
+ });
+ });
+});
+
+describe("Show record", function () {
+ var record_number = 1; // the Nth record in hit list
+ it("show record author", function () {
+ var click = mkws.$("div.mkwsRecords div.mkwsSummary:nth-child(" + record_number + ") a").trigger("click");
+ debug("show record click is success: " + click.length);
+ expect(click.length).toBe(1);
+
+ // wait until the record pops up
+ waitsFor(function () {
+ var show = mkws.$("div.mkwsRecords div.mkwsSummary:nth-child(" + record_number + ") > div.mkwsDetails");
+ //debug("poprecord: " + (show ? show.length : -1) + " " + mkws.$("div.mkwsRecords div.mkwsSummary").text());
+ return show != null && show.length ? true : false;
+ }, "wait some miliseconds to show up a record", 2 * jasmine_config.second);
+
+ runs(function () {
+ debug("show record pop up");
+ expect(mkws.$("div.mkwsRecords div.mkwsSummary:nth-child(" + record_number + ") div")).not.toBe(null);
+ });
+ });
+
+ it("extract URL", function () {
+ if (jasmine_config.show_record_url == false) {
+ debug("ignore test for URL in record")
+ return;
+ }
+
+ var urls = mkws.$("div.mkwsRecords div.mkwsSummary:nth-child(" + record_number + ") div table tbody tr td a");
+ debug("number of extracted URL from record: " + urls.length);
+ // expect(urls.length).toBeGreaterThan(0); // LoC has records without links
+ for (var i = 0; i < urls.length; i++) {
+ var url = mkws.$(urls[i]);
+ debug("URL: " + url.attr('href') + " text: " + url.text());
+
+ expect(url.attr('href')).not.toBe(null);
+ expect(url.attr('href')).toMatch(/^https?:\/\/[a-z0-9\-]+\.[0-9a-z].*\//i);
+ expect(url.text()).not.toBe("");
+ }
+ });
+});
+
+describe("Check switch menu Records/Targets", function () {
+ it("check mkwsSwitch", function () {
+ expect(mkws.$("div.mkwsSwitch").length).toBe(1);
+
+ // expect 2 clickable links
+ expect(mkws.$("div.mkwsSwitch a").length).toBe(2);
+ });
+
+ it("switch to target view", function () {
+ mkws.$("div.mkwsSwitch").children('a').eq(1).trigger("click");
+
+ // now the target table must be visible
+ expect(mkws.$("div.mkwsTargets").is(":visible")).toBe(true);
+ expect(mkws.$("div.mkwsRecords").is(":visible")).toBe(false);
+
+ // wait a half second, to show the target view
+ var time = (new Date).getTime();
+ waitsFor(function () {
+ return (new Date).getTime() - time > 700 ? true : false;
+ }, "wait some miliseconds", 1 * jasmine_config.second);
+
+ // look for table header
+ runs(function () {
+ expect(mkws.$("div.mkwsTargets").html()).toMatch(/Target ID/);
+ });
+ });
+
+ it("switch back to record view", function () {
+ mkws.$("div.mkwsSwitch").children('a').eq(0).trigger("click");
+
+ // now the target table must be visible
+ expect(mkws.$("div.mkwsTargets").is(":visible")).toBe(false);
+ expect(mkws.$("div.mkwsRecords").is(":visible")).toBe(true);
+ });
+});
+
+describe("Check status client counter", function () {
+ function get_time() {
+ var date = new Date();
+ return date.getTime();
+ }
+ var time = get_time();
+
+ it("check status clients", function () {
+ if (!jasmine_status.source_click) {
+ debug("skip clients check due missing source click");
+ return;
+ }
+
+ waitsFor(function () {
+ var clients = mkws.$("div.mkwsStat span.mkwsClientCount");
+ debug("clients: " + clients.text());
+ if (clients.length == 1 && clients.text().match("0/1$")) {
+ return true;
+ } else {
+ return false;
+ }
+ }, "wait for Active clients: 0/1", 4 * jasmine_config.second);
+
+ runs(function () {
+ var clients = mkws.$("div.mkwsStat span.mkwsClientCount");
+ debug("span.mkwsClientCount: " + clients.text());
+ expect(clients.text()).toMatch("0/1$");
+ });
+ });
+});
+
+/* done */
+describe("All tests are done", function () {
+ it(">>> hooray <<<", function () {
+ mkws.jasmine_done = true;
+ });