diff options
Diffstat (limited to 'src/scenario/Application.js')
| -rw-r--r-- | src/scenario/Application.js | 61 |
1 files changed, 47 insertions, 14 deletions
diff --git a/src/scenario/Application.js b/src/scenario/Application.js index 4ee0dd03..e2d34551 100644 --- a/src/scenario/Application.js +++ b/src/scenario/Application.js @@ -1,51 +1,84 @@ /** * Represents the application currently being tested and abstracts usage * of iframes or separate windows. + * + * @param {Object} context jQuery wrapper around HTML context. */ angular.scenario.Application = function(context) { this.context = context; - context.append('<h2>Current URL: <a href="about:blank">None</a></h2>'); + context.append( + '<h2>Current URL: <a href="about:blank">None</a></h2>' + + '<div id="test-frames"></div>' + ); }; /** * Gets the jQuery collection of frames. Don't use this directly because * frames may go stale. * + * @private * @return {Object} jQuery collection */ -angular.scenario.Application.prototype.getFrame = function() { - return this.context.find('> iframe'); +angular.scenario.Application.prototype.getFrame_ = function() { + return this.context.find('#test-frames iframe:last'); }; /** - * Gets the window of the test runner frame. Always favor executeAction() + * Gets the window of the test runner frame. Always favor executeAction() * instead of this method since it prevents you from getting a stale window. * + * @private * @return {Object} the window of the frame */ -angular.scenario.Application.prototype.getWindow = function() { - var contentWindow = this.getFrame().attr('contentWindow'); +angular.scenario.Application.prototype.getWindow_ = function() { + var contentWindow = this.getFrame_().attr('contentWindow'); if (!contentWindow) - throw 'No window available because frame not loaded.'; + throw 'Frame window is not accessible.'; return contentWindow; }; /** * Changes the location of the frame. + * + * @param {string} url The URL. If it begins with a # then only the + * hash of the page is changed. + * @param {Function} onloadFn function($window, $document) */ angular.scenario.Application.prototype.navigateTo = function(url, onloadFn) { - this.getFrame().remove(); - this.context.append('<iframe src=""></iframe>'); + var self = this; + var frame = this.getFrame_(); + if (url.charAt(0) === '#') { + url = frame.attr('src').split('#')[0] + url; + frame.attr('src', url); + this.executeAction(onloadFn); + } else { + frame.css('display', 'none').attr('src', 'about:blank'); + this.context.find('#test-frames').append('<iframe>'); + frame = this.getFrame_(); + frame.load(function() { + self.executeAction(onloadFn); + frame.unbind(); + }).attr('src', url); + } 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. + * Executes a function in the context of the tested application. Will wait + * for all pending angular xhr requests before executing. * - * @param {Function} The callback to execute. function($window, $document) + * @param {Function} action The callback to execute. function($window, $document) + * $document is a jQuery wrapped document. */ angular.scenario.Application.prototype.executeAction = function(action) { - var $window = this.getWindow(); - return action.call(this, $window, _jQuery($window.document)); + var self = this; + var $window = this.getWindow_(); + if (!$window.angular) { + return action.call(this, $window, _jQuery($window.document)); + } + var $browser = $window.angular.service.$browser(); + $browser.poll(); + $browser.notifyWhenNoOutstandingRequests(function() { + action.call(self, $window, _jQuery($window.document)); + }); }; |
