describe("DSL", function() { var lastDocument, executeFuture, Expect; beforeEach(function() { setUpContext(); executeFuture = function(future, html, callback) { lastDocument = _jQuery('
' + html + '
'); lastFrame = _jQuery(''); _jQuery(document.body).append(lastDocument); var specThis = { testWindow: window, testDocument: lastDocument, testFrame: lastFrame, jQuery: _jQuery }; future.behavior.call(specThis, callback || noop); }; Expect = _window.expect; }); describe("input", function() { var input = angular.scenario.dsl.input; it('should enter', function() { var future = input('name').enter('John'); expect(future.name).toEqual("input 'name' enter 'John'"); executeFuture(future, ''); expect(lastDocument.find('input').val()).toEqual('John'); }); it('should select', function() { var future = input('gender').select('female'); expect(future.name).toEqual("input 'gender' select 'female'"); executeFuture(future, '' + ''); expect(lastDocument.find(':radio:checked').length).toEqual(1); expect(lastDocument.find(':radio:checked').val()).toEqual('female'); }); }); describe('browser', function() { var browser = angular.scenario.dsl.browser; it('shoud return true if location with empty hash provided is same ' + 'as location of the page', function() { browser.location.href = "http://server"; expect(browser.location.toEqual("http://server")).toEqual(true); }); it('shoud return true if location with hash provided is same ' + 'as location of the page', function() { browser.location.href = "http://server"; browser.location.hash = "hashPath"; expect(browser.location.toEqual("http://server/#/hashPath")) .toEqual(true); }); it('should return true if the location provided is the same as which ' + 'browser navigated to', function() { var future = browser.navigateTo("http://server/#/hashPath"); expect(future.name).toEqual("Navigate to: http://server/#/hashPath"); executeFuture(future, ''); expect(browser.location.toEqual("http://server/#/hashPath")) .toEqual(true); expect(browser.location.toEqual("http://server/")) .toEqual(false); future = browser.navigateTo("http://server/"); expect(future.name).toEqual("Navigate to: http://server/"); executeFuture(future, ''); expect(browser.location.toEqual("http://server/")) .toEqual(true); }); }); describe('repeater', function() { var repeater = angular.scenario.dsl.repeater; var html; beforeEach(function() { html = "" + "" + "" + "" + "" + "" + "" + "" + "" + "
" + "John Marston" + "" + "Red Dead Redemption" + "
" + "Nathan Drake" + "" + "Uncharted" + "
"; }); it('should count', function() { var future = repeater('.repeater-row').count(); expect(future.name).toEqual("repeater '.repeater-row' count"); executeFuture(future, "
a
" + "
b
", function(value) { future.fulfill(value); }); expect(future.fulfilled).toBeTruthy(); expect(future.value).toEqual(2); }); function assertFutureState(future, expectedName, expectedValue) { expect(future.name).toEqual(expectedName); executeFuture(future, html, function(value) { future.fulfill(value); }); expect(future.fulfilled).toBeTruthy(); expect(future.value).toEqual(expectedValue); } it('should collect bindings', function() { assertFutureState(repeater('.epic').collect('{{hero}}'), "repeater '.epic' collect '{{hero}}'", ['John Marston', 'Nathan Drake']); assertFutureState(repeater('.epic').collect('{{game}}'), "repeater '.epic' collect '{{game}}'", ['Red Dead Redemption', 'Uncharted']); }); it('should collect normal selectors', function() { assertFutureState(repeater('.epic').collect('.hero-name'), "repeater '.epic' collect '.hero-name'", ['John Marston', 'Nathan Drake']); assertFutureState(repeater('.epic').collect('.game-name'), "repeater '.epic' collect '.game-name'", ['Red Dead Redemption', 'Uncharted']); }); it('should collect normal attributes', function() { //TODO(shyamseshadri) : Left as an exercise to the user }); }); describe('element', function() { var element = angular.scenario.dsl.element; var html; beforeEach(function() { html = '
' + '
' + 'Description : ' + 'Details...' + '' + 'Date created: ' + '01/01/01' + '' + '
' + '
'; }); function timeTravel(future) { executeFuture(future, html, function(value) { future.fulfill(value); }); expect(future.fulfilled).toBeTruthy(); } it('should find elements on the page and provide jquery api', function() { var future = element('.reports-detail').find(); expect(future.name).toEqual("Find element '.reports-detail'"); timeTravel(future); expect(future.value.text()). toEqual('Description : Details...Date created: 01/01/01'); expect(future.value.find('.desc').text()). toEqual('Description : Details...'); }); it('should find elements with angular syntax', function() { var future = element('{{report.description}}').find(); expect(future.name).toEqual("Find element '{{report.description}}'"); timeTravel(future); expect(future.value.text()).toEqual('Details...'); expect(future.value.attr('ng:bind')).toEqual('report.description'); }); }); });