describe(“HtmlReporter”, function() {
var env; var htmlReporter; var body; var fakeDocument; beforeEach(function() { env = new jasmine.Env(); env.updateInterval = 0; body = document.createElement("body"); fakeDocument = { body: body, location: { search: "" } }; htmlReporter = new jasmine.HtmlReporter(fakeDocument); }); function fakeSpec(name) { return { getFullName: function() { return name; } }; } function findElements(divs, withClass) { var els = []; for (var i = 0; i < divs.length; i++) { if (divs[i].className == withClass) els.push(divs[i]); } return els; } function findElement(divs, withClass) { var els = findElements(divs, withClass); if (els.length > 0) { return els[0]; } throw new Error("couldn't find div with class " + withClass); } it("should run only specs beginning with spec parameter", function() { fakeDocument.location.search = "?spec=run%20this"; expect(htmlReporter.specFilter(fakeSpec("run this"))).toBeTruthy(); expect(htmlReporter.specFilter(fakeSpec("not the right spec"))).toBeFalsy(); expect(htmlReporter.specFilter(fakeSpec("not run this"))).toBeFalsy(); }); describe("running without any specs", function() { var runner; beforeEach(function() { runner = env.currentRunner(); env.addReporter(htmlReporter); }); it("should not error", function() { var exec = function() { runner.execute(); }; expect(exec).not.toThrow(); }); }); describe('Matcher reporting', function() { var getResultMessageDiv = function(body) { var divs = body.getElementsByTagName("div"); for (var i = 0; i < divs.length; i++) { if (divs[i].className.match(/resultMessage/)) { return divs[i]; } } }; var runner, spec, fakeTimer; beforeEach(function() { fakeTimer = new jasmine.FakeTimer(); env.setTimeout = fakeTimer.setTimeout; env.clearTimeout = fakeTimer.clearTimeout; env.setInterval = fakeTimer.setInterval; env.clearInterval = fakeTimer.clearInterval; runner = env.currentRunner(); var suite = new jasmine.Suite(env, 'some suite'); runner.add(suite); spec = new jasmine.Spec(env, suite, 'some spec'); suite.add(spec); fakeDocument.location.search = "?"; env.addReporter(htmlReporter); }); describe('toContain', function() { it('should show actual and expected', function() { spec.runs(function() { this.expect('foo').toContain('bar'); }); runner.execute(); fakeTimer.tick(0); var resultEl = getResultMessageDiv(body); expect(resultEl.innerHTML).toMatch(/foo/); expect(resultEl.innerHTML).toMatch(/bar/); }); }); }); describe("failure messages (integration)", function() { var spec, results, expectationResult; it("should add the failure message to the DOM (non-toEquals matchers)", function() { env.describe("suite", function() { env.it("will have log messages", function() { this.expect('a').toBeNull(); }); }); env.addReporter(htmlReporter); env.execute(); var divs = body.getElementsByTagName("div"); var errorDiv = findElement(divs, 'resultMessage fail'); expect(errorDiv.innerHTML).toMatch(/Expected 'a' to be null/); }); it("should add the failure message to the DOM (non-toEquals matchers) html escaping", function() { env.describe("suite", function() { env.it("will have log messages", function() { this.expect('1 < 2').toBeNull(); }); }); env.addReporter(htmlReporter); env.execute(); var divs = body.getElementsByTagName("div"); var errorDiv = findElement(divs, 'resultMessage fail'); expect(errorDiv.innerHTML).toMatch(/Expected '1 < 2' to be null/); }); }); describe("log messages", function() { it("should appear in the report of a failed spec", function() { env.describe("suite", function() { env.it("will have log messages", function() { this.log("this is a", "multipart log message"); this.expect(true).toBeFalsy(); }); }); env.addReporter(htmlReporter); env.execute(); var divs = body.getElementsByTagName("div"); var errorDiv = findElement(divs, 'specDetail failed'); expect(errorDiv.innerHTML).toMatch("this is a multipart log message"); }); xit("should work on IE without console.log.apply", function() { }); }); describe("duplicate example names", function() { it("should report failures correctly", function() { var suite1 = env.describe("suite", function() { env.it("will have log messages", function() { this.log("this one fails!"); this.expect(true).toBeFalsy(); }); }); var suite2 = env.describe("suite", function() { env.it("will have log messages", function() { this.log("this one passes!"); this.expect(true).toBeTruthy(); }); }); env.addReporter(htmlReporter); env.execute(); var divs = body.getElementsByTagName("div"); var failedSpecDiv = findElement(divs, 'specDetail failed'); expect(failedSpecDiv.className).toEqual('specDetail failed'); expect(failedSpecDiv.innerHTML).toContain("this one fails!"); expect(failedSpecDiv.innerHTML).not.toContain("this one passes!"); }); }); describe('#reportSpecStarting', function() { beforeEach(function() { env.describe("suite 1", function() { env.it("spec 1", function() { }); }); spyOn(htmlReporter, 'log').andCallThrough(); }); it('DOES NOT log running specs by default', function() { env.addReporter(htmlReporter); env.execute(); expect(htmlReporter.log).not.toHaveBeenCalled(); }); it('logs running specs when log_running_specs is true', function() { htmlReporter.logRunningSpecs = true; env.addReporter(htmlReporter); env.execute(); expect(htmlReporter.log).toHaveBeenCalledWith('>> Jasmine Running suite 1 spec 1...'); }); });
});