mirror of
https://github.com/zhigang1992/DefinitelyTyped.git
synced 2026-04-23 12:56:46 +08:00
1010 lines
26 KiB
TypeScript
1010 lines
26 KiB
TypeScript
// tests based on http://jasmine.github.io/2.2/introduction.html
|
|
|
|
describe("A suite", () => {
|
|
it("contains spec with an expectation", () => {
|
|
expect(true).toBe(true);
|
|
});
|
|
});
|
|
|
|
describe("A suite is just a function", () => {
|
|
var a: boolean;
|
|
|
|
it("and so is a spec", () => {
|
|
a = true;
|
|
expect(a).toBe(true);
|
|
});
|
|
});
|
|
|
|
describe("The 'toBe' matcher compares with ===", () => {
|
|
|
|
it("and has a positive case", () => {
|
|
expect(true).toBe(true);
|
|
});
|
|
|
|
it("and can have a negative case", () => {
|
|
expect(false).not.toBe(true);
|
|
});
|
|
});
|
|
|
|
describe("Included matchers:", () => {
|
|
|
|
it("The 'toBe' matcher compares with ===", () => {
|
|
var a = 12;
|
|
var b = a;
|
|
|
|
expect(a).toBe(b);
|
|
expect(a).not.toBe(null);
|
|
});
|
|
|
|
describe("The 'toEqual' matcher", () => {
|
|
|
|
it("works for simple literals and variables", () => {
|
|
var a = 12;
|
|
expect(a).toEqual(12);
|
|
});
|
|
|
|
it("should work for objects", () => {
|
|
var foo = {
|
|
a: 12,
|
|
b: 34
|
|
};
|
|
var bar = {
|
|
a: 12,
|
|
b: 34
|
|
};
|
|
expect(foo).toEqual(bar);
|
|
});
|
|
});
|
|
|
|
it("The 'toMatch' matcher is for regular expressions", () => {
|
|
var message = "foo bar baz";
|
|
|
|
expect(message).toMatch(/bar/);
|
|
expect(message).toMatch("bar");
|
|
expect(message).not.toMatch(/quux/);
|
|
});
|
|
|
|
it("The 'toBeDefined' matcher compares against `undefined`", () => {
|
|
var a = {
|
|
foo: "foo"
|
|
};
|
|
|
|
expect(a.foo).toBeDefined();
|
|
expect((a as any).bar).not.toBeDefined();
|
|
});
|
|
|
|
it("The `toBeUndefined` matcher compares against `undefined`", () => {
|
|
var a = {
|
|
foo: "foo"
|
|
};
|
|
|
|
expect(a.foo).not.toBeUndefined();
|
|
expect((a as any).bar).toBeUndefined();
|
|
});
|
|
|
|
it("The 'toBeNull' matcher compares against null", () => {
|
|
var a: string = null;
|
|
var foo = "foo";
|
|
|
|
expect(null).toBeNull();
|
|
expect(a).toBeNull();
|
|
expect(foo).not.toBeNull();
|
|
});
|
|
|
|
it("The 'toBeTruthy' matcher is for boolean casting testing", () => {
|
|
var a: string, foo = "foo";
|
|
|
|
expect(foo).toBeTruthy();
|
|
expect(a).not.toBeTruthy();
|
|
});
|
|
|
|
it("The 'toBeFalsy' matcher is for boolean casting testing", () => {
|
|
var a: string, foo = "foo";
|
|
|
|
expect(a).toBeFalsy();
|
|
expect(foo).not.toBeFalsy();
|
|
});
|
|
|
|
it("The 'toContain' matcher is for finding an item in an Array", () => {
|
|
var a = ["foo", "bar", "baz"];
|
|
|
|
expect(a).toContain('foo');
|
|
expect(a).not.toContain("quux");
|
|
});
|
|
|
|
it("The 'toBeLessThan' matcher is for mathematical comparisons", () => {
|
|
var pi = 3.1415926,
|
|
e = 2.78;
|
|
|
|
expect(e).toBeLessThan(pi);
|
|
expect(pi).not.toBeLessThan(e);
|
|
});
|
|
|
|
it("The 'toBeGreaterThan' is for mathematical comparisons", () => {
|
|
var pi = 3.1415926,
|
|
e = 2.78;
|
|
|
|
expect(pi).toBeGreaterThan(e);
|
|
expect(e).not.toBeGreaterThan(pi);
|
|
});
|
|
|
|
it("The 'toBeCloseTo' matcher is for precision math comparison", () => {
|
|
var pi = 3.1415926,
|
|
e = 2.78;
|
|
|
|
expect(pi).not.toBeCloseTo(e, 2);
|
|
expect(pi).toBeCloseTo(e, 0);
|
|
});
|
|
|
|
it("The 'toThrow' matcher is for testing if a function throws an exception", () => {
|
|
var foo = () => {
|
|
return 1 + 2;
|
|
};
|
|
var bar = () => {
|
|
var a: any;
|
|
return a + 1;
|
|
};
|
|
|
|
expect(foo).not.toThrow();
|
|
expect(bar).toThrow();
|
|
});
|
|
|
|
it("The 'toThrowError' matcher is for testing a specific thrown exception", () => {
|
|
var foo = () => {
|
|
throw new TypeError("foo bar baz");
|
|
};
|
|
|
|
expect(foo).toThrowError("foo bar baz");
|
|
expect(foo).toThrowError(/bar/);
|
|
expect(foo).toThrowError(TypeError);
|
|
expect(foo).toThrowError(TypeError, "foo bar baz");
|
|
});
|
|
});
|
|
|
|
describe("A spec", () => {
|
|
it("is just a function, so it can contain any code", () => {
|
|
var foo = 0;
|
|
foo += 1;
|
|
|
|
expect(foo).toEqual(1);
|
|
});
|
|
|
|
it("can have more than one expectation", () => {
|
|
var foo = 0;
|
|
foo += 1;
|
|
|
|
expect(foo).toEqual(1);
|
|
expect(true).toEqual(true);
|
|
});
|
|
});
|
|
|
|
describe("A spec (with setup and tear-down)", () => {
|
|
var foo: number;
|
|
|
|
beforeEach(() => {
|
|
foo = 0;
|
|
foo += 1;
|
|
});
|
|
|
|
afterEach(() => {
|
|
foo = 0;
|
|
});
|
|
|
|
it("is just a function, so it can contain any code", () => {
|
|
expect(foo).toEqual(1);
|
|
});
|
|
|
|
it("can have more than one expectation", () => {
|
|
expect(foo).toEqual(1);
|
|
expect(true).toEqual(true);
|
|
});
|
|
});
|
|
|
|
describe("A spec", () => {
|
|
var foo: number;
|
|
|
|
beforeEach(() => {
|
|
foo = 0;
|
|
foo += 1;
|
|
});
|
|
|
|
afterEach(() => {
|
|
foo = 0;
|
|
});
|
|
|
|
it("is just a function, so it can contain any code", () => {
|
|
expect(foo).toEqual(1);
|
|
});
|
|
|
|
it("can have more than one expectation", () => {
|
|
expect(foo).toEqual(1);
|
|
expect(true).toEqual(true);
|
|
});
|
|
|
|
describe("nested inside a second describe", () => {
|
|
var bar: number;
|
|
|
|
beforeEach(() => {
|
|
bar = 1;
|
|
});
|
|
|
|
it("can reference both scopes as needed", () => {
|
|
expect(foo).toEqual(bar);
|
|
});
|
|
});
|
|
});
|
|
|
|
xdescribe("A spec", () => {
|
|
var foo: number;
|
|
|
|
beforeEach(() => {
|
|
foo = 0;
|
|
foo += 1;
|
|
});
|
|
|
|
it("is just a function, so it can contain any code", () => {
|
|
expect(foo).toEqual(1);
|
|
});
|
|
});
|
|
|
|
describe("Pending specs", () => {
|
|
|
|
xit("can be declared 'xit'", () => {
|
|
expect(true).toBe(false);
|
|
});
|
|
|
|
it("can be declared with 'it' but without a function");
|
|
|
|
it("can be declared by calling 'pending' in the spec body", () => {
|
|
expect(true).toBe(false);
|
|
pending(); // without reason
|
|
pending('this is why it is pending');
|
|
});
|
|
});
|
|
|
|
describe("A spy", () => {
|
|
var foo: any, bar: any = null;
|
|
|
|
beforeEach(() => {
|
|
foo = {
|
|
setBar: (value: any) => {
|
|
bar = value;
|
|
}
|
|
};
|
|
|
|
spyOn(foo, 'setBar');
|
|
|
|
foo.setBar(123);
|
|
foo.setBar(456, 'another param');
|
|
});
|
|
|
|
it("tracks that the spy was called", () => {
|
|
expect(foo.setBar).toHaveBeenCalled();
|
|
});
|
|
|
|
it("tracks all the arguments of its calls", () => {
|
|
expect(foo.setBar).toHaveBeenCalledWith(123);
|
|
expect(foo.setBar).toHaveBeenCalledWith(456, 'another param');
|
|
});
|
|
|
|
it("stops all execution on a function", () => {
|
|
expect(bar).toBeNull();
|
|
});
|
|
});
|
|
|
|
describe("A spy, when configured to call through", () => {
|
|
var foo: any, bar: any, fetchedBar: any;
|
|
|
|
beforeEach(() => {
|
|
foo = {
|
|
setBar: (value: any) => {
|
|
bar = value;
|
|
},
|
|
getBar: () => {
|
|
return bar;
|
|
}
|
|
};
|
|
|
|
spyOn(foo, 'getBar').and.callThrough();
|
|
|
|
foo.setBar(123);
|
|
fetchedBar = foo.getBar();
|
|
});
|
|
|
|
it("tracks that the spy was called", () => {
|
|
expect(foo.getBar).toHaveBeenCalled();
|
|
});
|
|
|
|
it("should not effect other functions", () => {
|
|
expect(bar).toEqual(123);
|
|
});
|
|
|
|
it("when called returns the requested value", () => {
|
|
expect(fetchedBar).toEqual(123);
|
|
});
|
|
});
|
|
|
|
describe("A spy, when configured to fake a return value", () => {
|
|
var foo: any, bar: any, fetchedBar: any;
|
|
|
|
beforeEach(() => {
|
|
foo = {
|
|
setBar: (value: any) => {
|
|
bar = value;
|
|
},
|
|
getBar: () => {
|
|
return bar;
|
|
}
|
|
};
|
|
|
|
spyOn(foo, "getBar").and.returnValue(745);
|
|
|
|
foo.setBar(123);
|
|
fetchedBar = foo.getBar();
|
|
});
|
|
|
|
it("tracks that the spy was called", () => {
|
|
expect(foo.getBar).toHaveBeenCalled();
|
|
});
|
|
|
|
it("should not effect other functions", () => {
|
|
expect(bar).toEqual(123);
|
|
});
|
|
|
|
it("when called returns the requested value", () => {
|
|
expect(fetchedBar).toEqual(745);
|
|
});
|
|
});
|
|
|
|
describe("A spy, when configured to fake a series of return values", () => {
|
|
var foo: any, bar: any;
|
|
|
|
beforeEach(() => {
|
|
foo = {
|
|
setBar: (value: any) => {
|
|
bar = value;
|
|
},
|
|
getBar: () => {
|
|
return bar;
|
|
}
|
|
};
|
|
|
|
spyOn(foo, "getBar").and.returnValues("fetched first", "fetched second");
|
|
|
|
foo.setBar(123);
|
|
});
|
|
|
|
it("tracks that the spy was called", () => {
|
|
foo.getBar(123);
|
|
expect(foo.getBar).toHaveBeenCalled();
|
|
});
|
|
|
|
it("should not affect other functions", () => {
|
|
expect(bar).toEqual(123);
|
|
});
|
|
|
|
it("when called multiple times returns the requested values in order", () => {
|
|
expect(foo.getBar()).toEqual("fetched first");
|
|
expect(foo.getBar()).toEqual("fetched second");
|
|
expect(foo.getBar()).toBeUndefined();
|
|
});
|
|
});
|
|
|
|
describe("A spy, when configured with an alternate implementation", () => {
|
|
var foo: any, bar: any, fetchedBar: any;
|
|
|
|
beforeEach(() => {
|
|
foo = {
|
|
setBar: (value: any) => {
|
|
bar = value;
|
|
},
|
|
getBar: () => {
|
|
return bar;
|
|
}
|
|
};
|
|
|
|
spyOn(foo, "getBar").and.callFake(() => {
|
|
return 1001;
|
|
});
|
|
|
|
foo.setBar(123);
|
|
fetchedBar = foo.getBar();
|
|
});
|
|
|
|
it("tracks that the spy was called", () => {
|
|
expect(foo.getBar).toHaveBeenCalled();
|
|
});
|
|
|
|
it("should not effect other functions", () => {
|
|
expect(bar).toEqual(123);
|
|
});
|
|
|
|
it("when called returns the requested value", () => {
|
|
expect(fetchedBar).toEqual(1001);
|
|
});
|
|
});
|
|
|
|
describe("A spy, when configured to throw a value", () => {
|
|
var foo: any, bar: any;
|
|
|
|
beforeEach(() => {
|
|
foo = {
|
|
setBar: (value: any) => {
|
|
bar = value;
|
|
}
|
|
};
|
|
|
|
spyOn(foo, "setBar").and.throwError("quux");
|
|
});
|
|
|
|
it("throws the value", () => {
|
|
expect(() => {
|
|
foo.setBar(123);
|
|
}).toThrowError("quux");
|
|
});
|
|
});
|
|
|
|
describe("A spy, when configured with multiple actions", () => {
|
|
var foo: any, bar: any, fetchedBar: any;
|
|
|
|
beforeEach(() => {
|
|
foo = {
|
|
setBar: (value: any) => {
|
|
bar = value;
|
|
},
|
|
getBar: () => {
|
|
return bar;
|
|
}
|
|
};
|
|
|
|
spyOn(foo, 'getBar').and.callThrough().and.callFake(() => {
|
|
this.fakeCalled = true;
|
|
});
|
|
|
|
foo.setBar(123);
|
|
fetchedBar = foo.getBar();
|
|
});
|
|
|
|
it("tracks that the spy was called", () => {
|
|
expect(foo.getBar).toHaveBeenCalled();
|
|
});
|
|
|
|
it("should not effect other functions", () => {
|
|
expect(bar).toEqual(123);
|
|
});
|
|
|
|
it("when called returns the requested value", () => {
|
|
expect(fetchedBar).toEqual(123);
|
|
});
|
|
|
|
it("should have called the fake implementation", () => {
|
|
expect(this.fakeCalled).toEqual(true);
|
|
});
|
|
});
|
|
|
|
describe("A spy", () => {
|
|
var foo: any, bar: any = null;
|
|
|
|
beforeEach(() => {
|
|
foo = {
|
|
setBar: (value: any) => {
|
|
bar = value;
|
|
}
|
|
};
|
|
|
|
spyOn(foo, 'setBar').and.callThrough();
|
|
});
|
|
|
|
it("can call through and then stub in the same spec", () => {
|
|
foo.setBar(123);
|
|
expect(bar).toEqual(123);
|
|
|
|
foo.setBar.and.stub();
|
|
bar = null;
|
|
|
|
foo.setBar(123);
|
|
expect(bar).toBe(null);
|
|
});
|
|
});
|
|
|
|
describe("A spy", () => {
|
|
var foo: any, bar: any = null;
|
|
|
|
beforeEach(() => {
|
|
foo = {
|
|
setBar: (value: any) => {
|
|
bar = value;
|
|
}
|
|
};
|
|
|
|
spyOn(foo, 'setBar');
|
|
});
|
|
|
|
it("tracks if it was called at all", () => {
|
|
expect(foo.setBar.calls.any()).toEqual(false);
|
|
|
|
foo.setBar();
|
|
|
|
expect(foo.setBar.calls.any()).toEqual(true);
|
|
});
|
|
|
|
it("tracks the number of times it was called", () => {
|
|
expect(foo.setBar.calls.count()).toEqual(0);
|
|
|
|
foo.setBar();
|
|
foo.setBar();
|
|
|
|
expect(foo.setBar.calls.count()).toEqual(2);
|
|
});
|
|
|
|
it("tracks the arguments of each call", () => {
|
|
foo.setBar(123);
|
|
foo.setBar(456, "baz");
|
|
|
|
expect(foo.setBar.calls.argsFor(0)).toEqual([123]);
|
|
expect(foo.setBar.calls.argsFor(1)).toEqual([456, "baz"]);
|
|
});
|
|
|
|
it("tracks the arguments of all calls", () => {
|
|
foo.setBar(123);
|
|
foo.setBar(456, "baz");
|
|
|
|
expect(foo.setBar.calls.allArgs()).toEqual([[123], [456, "baz"]]);
|
|
});
|
|
|
|
it("can provide the context and arguments to all calls", () => {
|
|
foo.setBar(123);
|
|
|
|
expect(foo.setBar.calls.all()).toEqual([{ object: foo, args: [123], returnValue: undefined }]);
|
|
});
|
|
|
|
it("has a shortcut to the most recent call", () => {
|
|
foo.setBar(123);
|
|
foo.setBar(456, "baz");
|
|
|
|
expect(foo.setBar.calls.mostRecent()).toEqual({ object: foo, args: [456, "baz"], returnValue: undefined });
|
|
});
|
|
|
|
it("has a shortcut to the first call", () => {
|
|
foo.setBar(123);
|
|
foo.setBar(456, "baz");
|
|
|
|
expect(foo.setBar.calls.first()).toEqual({ object: foo, args: [123], returnValue: undefined });
|
|
});
|
|
|
|
it("can be reset", () => {
|
|
foo.setBar(123);
|
|
foo.setBar(456, "baz");
|
|
|
|
expect(foo.setBar.calls.any()).toBe(true);
|
|
|
|
foo.setBar.calls.reset();
|
|
|
|
expect(foo.setBar.calls.any()).toBe(false);
|
|
});
|
|
});
|
|
|
|
describe("A spy, when created manually", () => {
|
|
var whatAmI: any;
|
|
|
|
beforeEach(() => {
|
|
whatAmI = jasmine.createSpy('whatAmI');
|
|
|
|
whatAmI("I", "am", "a", "spy");
|
|
});
|
|
|
|
it("is named, which helps in error reporting", () => {
|
|
expect(whatAmI.and.identity()).toEqual('whatAmI');
|
|
});
|
|
|
|
it("tracks that the spy was called", () => {
|
|
expect(whatAmI).toHaveBeenCalled();
|
|
});
|
|
|
|
it("tracks its number of calls", () => {
|
|
expect(whatAmI.calls.count()).toEqual(1);
|
|
});
|
|
|
|
it("tracks all the arguments of its calls", () => {
|
|
expect(whatAmI).toHaveBeenCalledWith("I", "am", "a", "spy");
|
|
});
|
|
|
|
it("allows access to the most recent call", () => {
|
|
expect(whatAmI.calls.mostRecent().args[0]).toEqual("I");
|
|
});
|
|
});
|
|
|
|
describe("Multiple spies, when created manually", () => {
|
|
var tape: any;
|
|
|
|
beforeEach(() => {
|
|
tape = jasmine.createSpyObj('tape', ['play', 'pause', 'stop', 'rewind']);
|
|
|
|
tape.play();
|
|
tape.pause();
|
|
tape.rewind(0);
|
|
});
|
|
|
|
it("creates spies for each requested function", () => {
|
|
expect(tape.play).toBeDefined();
|
|
expect(tape.pause).toBeDefined();
|
|
expect(tape.stop).toBeDefined();
|
|
expect(tape.rewind).toBeDefined();
|
|
});
|
|
|
|
it("tracks that the spies were called", () => {
|
|
expect(tape.play).toHaveBeenCalled();
|
|
expect(tape.pause).toHaveBeenCalled();
|
|
expect(tape.rewind).toHaveBeenCalled();
|
|
expect(tape.stop).not.toHaveBeenCalled();
|
|
});
|
|
|
|
it("tracks all the arguments of its calls", () => {
|
|
expect(tape.rewind).toHaveBeenCalledWith(0);
|
|
});
|
|
});
|
|
|
|
describe("jasmine.any", () => {
|
|
it("matches any value", () => {
|
|
expect({}).toEqual(jasmine.any(Object));
|
|
expect(12).toEqual(jasmine.any(Number));
|
|
});
|
|
|
|
describe("when used with a spy", () => {
|
|
it("is useful for comparing arguments", () => {
|
|
var foo = jasmine.createSpy('foo');
|
|
foo(12, () => {
|
|
return true;
|
|
});
|
|
|
|
expect(foo).toHaveBeenCalledWith(jasmine.any(Number), jasmine.any(Function));
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("jasmine.objectContaining", () => {
|
|
interface fooType {
|
|
a: number;
|
|
b: number;
|
|
bar: string;
|
|
}
|
|
var foo: fooType;
|
|
|
|
beforeEach(() => {
|
|
foo = {
|
|
a: 1,
|
|
b: 2,
|
|
bar: "baz"
|
|
};
|
|
});
|
|
|
|
it("matches objects with the expect key/value pairs", () => {
|
|
// not explictly providing the type on objectContaining only guards against
|
|
// missmatching types on know properties
|
|
expect(foo).not.toEqual(jasmine.objectContaining({
|
|
a: 37,
|
|
foo: 2, // <-- this does not cause an error as the compiler cannot infer the type completely
|
|
// b: '123', <-- this would cause an error as `b` defined as number in fooType
|
|
}));
|
|
|
|
// explictly providing the type on objectContaining makes the guard more precise
|
|
// as misspelled properties are detected as well
|
|
expect(foo).not.toEqual(jasmine.objectContaining<fooType>({
|
|
bar: '',
|
|
// foo: 1, <-- this would cause an error as `foo` is not defined in fooType
|
|
}));
|
|
});
|
|
|
|
describe("when used with a spy", () => {
|
|
it("is useful for comparing arguments", () => {
|
|
var callback = jasmine.createSpy('callback');
|
|
|
|
callback({
|
|
bar: "baz"
|
|
});
|
|
|
|
expect(callback).toHaveBeenCalledWith(jasmine.objectContaining({
|
|
bar: "baz"
|
|
}));
|
|
expect(callback).not.toHaveBeenCalledWith(jasmine.objectContaining({
|
|
c: 37
|
|
}));
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("jasmine.arrayContaining", () => {
|
|
var foo: any;
|
|
|
|
beforeEach(() => {
|
|
foo = [1, 2, 3, 4];
|
|
});
|
|
|
|
it("matches arrays with some of the values", () => {
|
|
expect(foo).toEqual(jasmine.arrayContaining([3, 1]));
|
|
expect(foo).not.toEqual(jasmine.arrayContaining([6]));
|
|
});
|
|
|
|
describe("when used with a spy", () => {
|
|
it("is useful when comparing arguments", () => {
|
|
var callback = jasmine.createSpy('callback');
|
|
|
|
callback([1, 2, 3, 4]);
|
|
|
|
expect(callback).toHaveBeenCalledWith(jasmine.arrayContaining([4, 2, 3]));
|
|
expect(callback).not.toHaveBeenCalledWith(jasmine.arrayContaining([5, 2]));
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Manually ticking the Jasmine Clock", () => {
|
|
var timerCallback: any;
|
|
|
|
beforeEach(() => {
|
|
timerCallback = jasmine.createSpy("timerCallback");
|
|
jasmine.clock().install();
|
|
});
|
|
|
|
afterEach(() => {
|
|
jasmine.clock().uninstall();
|
|
});
|
|
|
|
it("causes a timeout to be called synchronously", () => {
|
|
setTimeout(() => {
|
|
timerCallback();
|
|
}, 100);
|
|
|
|
expect(timerCallback).not.toHaveBeenCalled();
|
|
|
|
jasmine.clock().tick(101);
|
|
|
|
expect(timerCallback).toHaveBeenCalled();
|
|
});
|
|
|
|
it("causes an interval to be called synchronously", () => {
|
|
setInterval(() => {
|
|
timerCallback();
|
|
}, 100);
|
|
|
|
expect(timerCallback).not.toHaveBeenCalled();
|
|
|
|
jasmine.clock().tick(101);
|
|
expect(timerCallback.calls.count()).toEqual(1);
|
|
|
|
jasmine.clock().tick(50);
|
|
expect(timerCallback.calls.count()).toEqual(1);
|
|
|
|
jasmine.clock().tick(50);
|
|
expect(timerCallback.calls.count()).toEqual(2);
|
|
});
|
|
|
|
describe("Mocking the Date object", () => {
|
|
it("mocks the Date object and sets it to a given time", () => {
|
|
var baseTime = new Date(2013, 9, 23);
|
|
|
|
jasmine.clock().mockDate(baseTime);
|
|
|
|
jasmine.clock().tick(50);
|
|
expect(new Date().getTime()).toEqual(baseTime.getTime() + 50);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("Asynchronous specs", () => {
|
|
var value: number;
|
|
beforeEach((done: DoneFn) => {
|
|
setTimeout(() => {
|
|
value = 0;
|
|
done();
|
|
}, 1);
|
|
});
|
|
|
|
it("should support async execution of test preparation and expectations", (done: DoneFn) => {
|
|
value++;
|
|
expect(value).toBeGreaterThan(0);
|
|
done();
|
|
});
|
|
|
|
describe("long asynchronous specs", () => {
|
|
beforeEach((done: DoneFn) => {
|
|
done();
|
|
}, 1000);
|
|
|
|
it("takes a long time", (done: DoneFn) => {
|
|
setTimeout(() => {
|
|
done();
|
|
}, 9000);
|
|
}, 10000);
|
|
|
|
afterEach((done: DoneFn) => {
|
|
done();
|
|
}, 1000);
|
|
});
|
|
|
|
});
|
|
|
|
describe("Fail", () => {
|
|
|
|
it("should fail test when called without arguments", () => {
|
|
fail();
|
|
});
|
|
|
|
it("should fail test when called with a fail message", () => {
|
|
fail("The test failed");
|
|
});
|
|
|
|
it("should fail test when called an error", () => {
|
|
fail(new Error("The test failed with this error"));
|
|
});
|
|
|
|
});
|
|
|
|
// test based on http://jasmine.github.io/2.2/custom_equality.html
|
|
describe("custom equality", () => {
|
|
var myCustomEquality: jasmine.CustomEqualityTester = function(first: any, second: any): boolean {
|
|
if (typeof first === "string" && typeof second === "string") {
|
|
return first[0] === second[1];
|
|
}
|
|
};
|
|
|
|
beforeEach(() => {
|
|
jasmine.addCustomEqualityTester(myCustomEquality);
|
|
});
|
|
|
|
|
|
it("should be custom equal", () => {
|
|
expect("abc").toEqual("aaa");
|
|
});
|
|
|
|
it("should be custom not equal", () => {
|
|
expect("abc").not.toEqual("abc");
|
|
});
|
|
});
|
|
|
|
// test based on http://jasmine.github.io/2.2/custom_matcher.html
|
|
var customMatchers: jasmine.CustomMatcherFactories = {
|
|
toBeGoofy: (util: jasmine.MatchersUtil, customEqualityTesters: jasmine.CustomEqualityTester[]) => {
|
|
return {
|
|
compare: (actual: any, expected: any): jasmine.CustomMatcherResult => {
|
|
if (expected === undefined) {
|
|
expected = '';
|
|
}
|
|
var result: jasmine.CustomMatcherResult = { pass: false };
|
|
|
|
result.pass = util.equals(actual.hyuk, "gawrsh" + expected, customEqualityTesters);
|
|
|
|
if (result.pass) {
|
|
result.message = "Expected " + actual + " not to be quite so goofy";
|
|
} else {
|
|
result.message = "Expected " + actual + " to be goofy, but it was not very goofy";
|
|
}
|
|
|
|
return result;
|
|
}
|
|
};
|
|
}
|
|
};
|
|
// add the custom matchers to interface jasmine.Matchers via TypeScript declaration merging
|
|
// if your test files import or export anything, you'll want to use:
|
|
// declare global {
|
|
// namespace jasmine {
|
|
// interface Matchers {
|
|
// ...
|
|
// }
|
|
// }
|
|
// }
|
|
declare namespace jasmine {
|
|
interface Matchers<T> {
|
|
toBeGoofy(expected?: jasmine.Expected<T>): boolean;
|
|
}
|
|
}
|
|
|
|
describe("Custom matcher: 'toBeGoofy'", () => {
|
|
beforeEach(() => {
|
|
jasmine.addMatchers(customMatchers);
|
|
});
|
|
|
|
it("is available on an expectation", () => {
|
|
expect({
|
|
hyuk: 'gawrsh'
|
|
}).toBeGoofy();
|
|
});
|
|
|
|
it("can take an 'expected' parameter", () => {
|
|
expect({
|
|
hyuk: 'gawrsh is fun'
|
|
}).toBeGoofy({ hyuk: ' is fun' });
|
|
});
|
|
|
|
it("can be negated", () => {
|
|
expect({
|
|
hyuk: 'this is fun'
|
|
}).not.toBeGoofy();
|
|
});
|
|
});
|
|
|
|
// test based on http://jasmine.github.io/2.5/custom_reporter.html
|
|
var myReporter: jasmine.CustomReporter = {
|
|
jasmineStarted: (suiteInfo: jasmine.SuiteInfo) => {
|
|
console.log("Running suite with " + suiteInfo.totalSpecsDefined);
|
|
},
|
|
|
|
suiteStarted: (result: jasmine.CustomReporterResult) => {
|
|
console.log("Suite started: " + result.description + " whose full description is: " + result.fullName);
|
|
},
|
|
|
|
specStarted: (result: jasmine.CustomReporterResult) => {
|
|
console.log("Spec started: " + result.description + " whose full description is: " + result.fullName);
|
|
},
|
|
|
|
specDone: (result: jasmine.CustomReporterResult) => {
|
|
console.log("Spec: " + result.description + " was " + result.status);
|
|
//tslint:disable-next-line:prefer-for-of
|
|
for (var i = 0; i < result.failedExpectations.length; i++) {
|
|
console.log("Failure: " + result.failedExpectations[i].message);
|
|
console.log("Actual: " + result.failedExpectations[i].actual);
|
|
console.log("Expected: " + result.failedExpectations[i].expected);
|
|
console.log(result.failedExpectations[i].stack);
|
|
}
|
|
console.log(result.passedExpectations.length);
|
|
},
|
|
|
|
suiteDone: (result: jasmine.CustomReporterResult) => {
|
|
console.log('Suite: ' + result.description + ' was ' + result.status);
|
|
//tslint:disable-next-line:prefer-for-of
|
|
for (var i = 0; i < result.failedExpectations.length; i++) {
|
|
console.log('AfterAll ' + result.failedExpectations[i].message);
|
|
console.log(result.failedExpectations[i].stack);
|
|
}
|
|
},
|
|
|
|
jasmineDone: (runDetails: jasmine.RunDetails) => {
|
|
console.log('Finished suite');
|
|
console.log('Random:', runDetails.order.random);
|
|
}
|
|
};
|
|
|
|
jasmine.getEnv().addReporter(myReporter);
|
|
|
|
describe("Randomize Tests", () => {
|
|
it("should allow randomization of the order of tests", () => {
|
|
expect(() => {
|
|
var env = jasmine.getEnv();
|
|
return env.randomizeTests(true);
|
|
}).not.toThrow();
|
|
});
|
|
|
|
it("should allow a seed to be passed in for randomization", () => {
|
|
expect(() => {
|
|
var env = jasmine.getEnv();
|
|
env.randomizeTests(true);
|
|
return env.seed(1234);
|
|
}).not.toThrow();
|
|
});
|
|
});
|
|
|
|
(() => {
|
|
// from boot.js
|
|
var env = jasmine.getEnv();
|
|
|
|
var htmlReporter = new jasmine.HtmlReporter();
|
|
env.addReporter(htmlReporter);
|
|
|
|
var specFilter = new jasmine.HtmlSpecFilter();
|
|
env.specFilter = (spec) => {
|
|
return specFilter.matches(spec.getFullName());
|
|
};
|
|
|
|
var currentWindowOnload = window.onload;
|
|
window.onload = () => {
|
|
if (currentWindowOnload) {
|
|
(currentWindowOnload as any)(null);
|
|
}
|
|
htmlReporter.initialize();
|
|
env.execute();
|
|
};
|
|
|
|
})();
|
|
|
|
jasmine.DEFAULT_TIMEOUT_INTERVAL = 1000;
|
|
jasmine.MAX_PRETTY_PRINT_DEPTH = 40; |