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');
});
});
});