describe('Custom Async Matchers (Integration)', function() { var env; beforeEach(function() { env = new jasmineUnderTest.Env(); env.configure({random: false}); }); afterEach(function() { env.cleanup_(); }); it('passes the spec if the custom async matcher passes', function(done) { jasmine.getEnv().requirePromises(); env.it('spec using custom async matcher', function() { env.addAsyncMatchers({ toBeReal: function() { return { compare: function() { return Promise.resolve({ pass: true }); } }; } }); return env.expectAsync(true).toBeReal(); }); var specExpectations = function(result) { expect(result.status).toEqual('passed'); }; env.addReporter({ specDone: specExpectations, jasmineDone: done }); env.execute(); }); it('uses the negative compare function for a negative comparison, if provided', function(done) { jasmine.getEnv().requirePromises(); env.it('spec with custom negative comparison matcher', function() { env.addAsyncMatchers({ toBeReal: function() { return { compare: function() { return Promise.resolve({ pass: true }); }, negativeCompare: function() { return Promise.resolve({ pass: true }); } }; } }); return env.expectAsync(true).not.toBeReal(); }); var specExpectations = function(result) { expect(result.status).toEqual('passed'); }; env.addReporter({ specDone: specExpectations, jasmineDone: done }); env.execute(); }); it('generates messages with the same rules as built in matchers absent a custom message', function(done) { jasmine.getEnv().requirePromises(); env.it('spec with an expectation', function() { env.addAsyncMatchers({ toBeReal: function() { return { compare: function() { return Promise.resolve({ pass: false }); } }; } }); return env.expectAsync('a').toBeReal(); }); var specExpectations = function(result) { expect(result.failedExpectations[0].message).toEqual("Expected 'a' to be real."); }; env.addReporter({ specDone: specExpectations, jasmineDone: done }); env.execute(); }); // TODO: remove this in the next major release. it("passes the jasmine utility and current equality testers to the matcher factory", function(done) { jasmine.getEnv().requirePromises(); var matcherFactory = function () { return { compare: function () { return Promise.resolve({pass: true}); } }; }, matcherFactorySpy = jasmine.createSpy("matcherFactorySpy").and.callFake(matcherFactory), customEqualityFn = function () { return true; }; env.it("spec with expectation", function() { env.addCustomEqualityTester(customEqualityFn); env.addAsyncMatchers({ toBeReal: matcherFactorySpy }); return env.expectAsync(true).toBeReal(); }); var specExpectations = function() { expect(matcherFactorySpy).toHaveBeenCalledWith( jasmine.any(jasmineUnderTest.MatchersUtil), [customEqualityFn] ); }; env.addReporter({ specDone: specExpectations, jasmineDone: done }); env.execute(); }); it("provides custom equality testers to the matcher factory via matchersUtil", function(done) { jasmine.getEnv().requirePromises(); var matcherFactory = function (matchersUtil) { return { compare: function (actual, expected) { return Promise.resolve({pass: matchersUtil.equals(actual[0], expected)}); } }; }, customEqualityFn = jasmine.createSpy("customEqualityFn").and.callFake(function (a, b) { return a.toString() === b; }); env.it("spec with expectation", function() { env.addCustomEqualityTester(customEqualityFn); env.addAsyncMatchers({ toBeArrayWithFirstElement: matcherFactory }); return env.expectAsync([1, 2]).toBeArrayWithFirstElement("1"); }); var specExpectations = function(result) { expect(customEqualityFn).toHaveBeenCalledWith(1, "1"); expect(result.failedExpectations).toEqual([]); }; env.addReporter({ specDone: specExpectations, jasmineDone: done }); env.execute(); }); });