describe("Spec", function() { it("#isPendingSpecException returns true for a pending spec exception", function() { var e = new Error(j$.Spec.pendingSpecExceptionMessage); expect(j$.Spec.isPendingSpecException(e)).toBe(true); }); it("#isPendingSpecException returns true for a pending spec exception (even when FF bug is present)", function() { var fakeError = { toString: function() { return "Error: " + j$.Spec.pendingSpecExceptionMessage; } }; expect(j$.Spec.isPendingSpecException(fakeError)).toBe(true); }); it("#isPendingSpecException returns true for a pending spec exception", function() { var e = new Error("foo"); expect(j$.Spec.isPendingSpecException(e)).toBe(false); }); it("delegates execution to a QueueRunner", function() { var fakeQueueRunner = jasmine.createSpy('fakeQueueRunner'), spec = new j$.Spec({ description: 'my test', id: 'some-id', fn: function() {}, queueRunner: fakeQueueRunner }); spec.execute(); expect(fakeQueueRunner).toHaveBeenCalled(); }); it("should call the start callback on execution", function() { var fakeQueueRunner = jasmine.createSpy('fakeQueueRunner'), startCallback = jasmine.createSpy('startCallback'), spec = new j$.Spec({ id: 123, description: 'foo bar', fn: function() {}, onStart: startCallback, queueRunner: fakeQueueRunner }); spec.execute(); // TODO: due to some issue with the Pretty Printer, this line fails, but the other two pass. // This means toHaveBeenCalledWith on IE8 will always be broken. // expect(startCallback).toHaveBeenCalledWith(spec); expect(startCallback).toHaveBeenCalled(); expect(startCallback.calls.first().object).toEqual(spec); }); it("should call the start callback on execution but before any befores are called", function() { var fakeQueueRunner = jasmine.createSpy('fakeQueueRunner'), beforesWereCalled = false, startCallback = jasmine.createSpy('start-callback').and.callFake(function() { expect(beforesWereCalled).toBe(false); }), spec = new j$.Spec({ fn: function() {}, beforeFns: function() { return [function() { beforesWereCalled = true }] }, onStart: startCallback, queueRunner: fakeQueueRunner }); spec.execute(); expect(startCallback).toHaveBeenCalled(); }); it("provides all before fns and after fns to be run", function() { var fakeQueueRunner = jasmine.createSpy('fakeQueueRunner'), before = jasmine.createSpy('before'), after = jasmine.createSpy('after'), fn = jasmine.createSpy('test body').and.callFake(function() { expect(before).toHaveBeenCalled(); expect(after).not.toHaveBeenCalled(); }), spec = new j$.Spec({ fn: fn, beforeFns: function() { return [before] }, afterFns: function() { return [after] }, queueRunner: fakeQueueRunner }); spec.execute(); var allSpecFns = fakeQueueRunner.calls.mostRecent().args[0].fns; expect(allSpecFns).toEqual([before, fn, after]); }); it("is marked pending if created without a function body", function() { var fakeQueueRunner = jasmine.createSpy('fakeQueueRunner'), startCallback = jasmine.createSpy('startCallback'), resultCallback = jasmine.createSpy('resultCallback'), spec = new j$.Spec({ onStart: startCallback, fn: null, resultCallback: resultCallback, queueRunner: fakeQueueRunner }); expect(spec.status()).toBe('pending'); }); it("can be disabled, but still calls callbacks", function() { var fakeQueueRunner = jasmine.createSpy('fakeQueueRunner'), startCallback = jasmine.createSpy('startCallback'), specBody = jasmine.createSpy('specBody'), resultCallback = jasmine.createSpy('resultCallback'), spec = new j$.Spec({ onStart:startCallback, fn: specBody, resultCallback: resultCallback, queueRunner: fakeQueueRunner }); spec.disable(); expect(spec.status()).toBe('disabled'); spec.execute(); expect(fakeQueueRunner).not.toHaveBeenCalled(); expect(specBody).not.toHaveBeenCalled(); expect(startCallback).toHaveBeenCalled(); expect(resultCallback).toHaveBeenCalled(); }); it("can be marked pending, but still calls callbacks when executed", function() { var fakeQueueRunner = jasmine.createSpy('fakeQueueRunner'), startCallback = jasmine.createSpy('startCallback'), resultCallback = jasmine.createSpy('resultCallback'), spec = new j$.Spec({ onStart: startCallback, resultCallback: resultCallback, description: "with a spec", getSpecName: function() { return "a suite with a spec" }, queueRunner: fakeQueueRunner }); spec.pend(); expect(spec.status()).toBe('pending'); spec.execute(); expect(fakeQueueRunner).not.toHaveBeenCalled(); expect(startCallback).toHaveBeenCalled(); expect(resultCallback).toHaveBeenCalledWith({ id: spec.id, status: 'pending', description: 'with a spec', fullName: 'a suite with a spec', failedExpectations: [] }); }); it("should call the done callback on execution complete", function() { var done = jasmine.createSpy('done callback'), spec = new j$.Spec({ fn: function() {}, catchExceptions: function() { return false; }, resultCallback: function() {}, queueRunner: function(attrs) { attrs.onComplete(); } }); spec.execute(done); expect(done).toHaveBeenCalled(); }); it("#status returns pending by default", function() { var spec = new j$.Spec({fn: jasmine.createSpy("spec body")}); expect(spec.status()).toEqual('pending'); }); it("#status returns pending if no expectations were encountered", function() { var specBody = jasmine.createSpy("spec body"), spec = new j$.Spec({fn: specBody}); spec.execute(); expect(spec.status()).toEqual('pending'); }); it("#status returns passed if all expectations in the spec have passed", function() { var spec = new j$.Spec({fn: jasmine.createSpy("spec body")}); spec.addExpectationResult(true); expect(spec.status()).toBe('passed'); }); it("#status returns failed if any expectations in the spec have failed", function() { var spec = new j$.Spec({ fn: jasmine.createSpy("spec body") }); spec.addExpectationResult(true); spec.addExpectationResult(false); expect(spec.status()).toBe('failed'); }); it("can return its full name", function() { var spec; spec = new j$.Spec({ getSpecName: function(passedVal) { // expect(passedVal).toBe(spec); TODO: a exec time, spec is undefined WTF? return 'expected val'; } }); expect(spec.getFullName()).toBe('expected val'); }); describe("when a spec is marked pending during execution", function() { it("should mark the spec as pending", function() { var fakeQueueRunner = function(opts) { opts.onException(new Error(j$.Spec.pendingSpecExceptionMessage)); }, spec = new j$.Spec({ description: 'my test', id: 'some-id', fn: function() { }, queueRunner: fakeQueueRunner }); spec.execute(); expect(spec.status()).toEqual("pending"); }); }); });