mirror of
https://github.com/zhigang1992/angular.js.git
synced 2026-03-29 00:09:01 +08:00
- "this" always means the current chain scope inside a DSL
- addFutureAction callbacks now take ($window, $document, done)
- $document has a special method elements() that uses the currently selected nodes in the document as defined by using() statements.
- $document.elements() allows placeholder insertion into selectors to make them more readable.
ex. $document.elements('input[name="$1"]', myVar) will substitute the value of myVar for $1 in the selector. Subsequent arguments are $2 and so on.
- $document.elements() results have a special method trigger(event) which should be used to events. This method implements some hacks to make sure browser UI controls update and the correct angular events fire.
- futures now allow custom formatting. By default any chain that results in a future can use toJson() or fromJson() to convert the future value to and from json. A custom parser can be provided with parsedWith(fn) where fn is a callback(value) that must return the parsed result.
Note: The entire widgets.html UI is now able to be controlled and asserted through DSL statements!!! Victory! :)
52 lines
1.6 KiB
JavaScript
52 lines
1.6 KiB
JavaScript
/**
|
|
* Represents the application currently being tested and abstracts usage
|
|
* of iframes or separate windows.
|
|
*/
|
|
angular.scenario.Application = function(context) {
|
|
this.context = context;
|
|
context.append('<h2>Current URL: <a href="about:blank">None</a></h2>');
|
|
};
|
|
|
|
/**
|
|
* Gets the jQuery collection of frames. Don't use this directly because
|
|
* frames may go stale.
|
|
*
|
|
* @return {Object} jQuery collection
|
|
*/
|
|
angular.scenario.Application.prototype.getFrame = function() {
|
|
return this.context.find('> iframe');
|
|
};
|
|
|
|
/**
|
|
* Gets the window of the test runner frame. Always favor executeAction()
|
|
* instead of this method since it prevents you from getting a stale window.
|
|
*
|
|
* @return {Object} the window of the frame
|
|
*/
|
|
angular.scenario.Application.prototype.getWindow = function() {
|
|
var contentWindow = this.getFrame().attr('contentWindow');
|
|
if (!contentWindow)
|
|
throw 'No window available because frame not loaded.';
|
|
return contentWindow;
|
|
};
|
|
|
|
/**
|
|
* Changes the location of the frame.
|
|
*/
|
|
angular.scenario.Application.prototype.navigateTo = function(url, onloadFn) {
|
|
this.getFrame().remove();
|
|
this.context.append('<iframe src=""></iframe>');
|
|
this.context.find('> h2 a').attr('href', url).text(url);
|
|
this.getFrame().attr('src', url).load(onloadFn);
|
|
};
|
|
|
|
/**
|
|
* Executes a function in the context of the tested application.
|
|
*
|
|
* @param {Function} The callback to execute. function($window, $document)
|
|
*/
|
|
angular.scenario.Application.prototype.executeAction = function(action) {
|
|
var $window = this.getWindow();
|
|
return action.call(this, $window, _jQuery($window.document));
|
|
};
|