Skip to content

Commit

Permalink
[BUGFIX beta] Fixes #12899
Browse files Browse the repository at this point in the history
Ensure transitionTo returns a transition object. Addresses
#12899
  • Loading branch information
asakusuma committed Feb 9, 2016
1 parent 31bc4eb commit b1cf8f6
Show file tree
Hide file tree
Showing 2 changed files with 61 additions and 5 deletions.
27 changes: 22 additions & 5 deletions packages/ember-routing/lib/system/router.js
Original file line number Diff line number Diff line change
Expand Up @@ -303,9 +303,26 @@ var EmberRouter = EmberObject.extend(Evented, {

_doURLTransition(routerJsMethod, url) {
var transition = this.router[routerJsMethod](url || '/');
return didBeginTransition(transition, this);
didBeginTransition(transition, this);
return transition;
},

/**
Transition the application into another route. The route may
be either a single route or route path:
See [Route.transitionTo](http://emberjs.com/api/classes/Ember.Route.html#method_transitionTo) for more info.
@method transitionTo
@param {String} name the name of the route or a URL
@param {...Object} models the model(s) or identifier(s) to be used while
transitioning to the route.
@param {Object} [options] optional hash with a queryParams property
containing a mapping of query parameters
@return {Transition} the transition object associated with this
attempted transition
@private
*/
transitionTo(...args) {
var queryParams;
if (resemblesURL(args[0])) {
Expand Down Expand Up @@ -618,11 +635,11 @@ var EmberRouter = EmberObject.extend(Evented, {
this._prepareQueryParams(targetRouteName, models, queryParams);

var transitionArgs = routeArgs(targetRouteName, models, queryParams);
var transitionPromise = this.router.transitionTo.apply(this.router, transitionArgs);
var transition = this.router.transitionTo.apply(this.router, transitionArgs);

didBeginTransition(transitionPromise, this);
didBeginTransition(transition, this);

return transitionPromise;
return transition;
},

_prepareQueryParams(targetRouteName, models, queryParams) {
Expand Down Expand Up @@ -1070,7 +1087,7 @@ function didBeginTransition(transition, router) {
}
router.set('targetState', routerState);

return transition.catch(function(error) {
transition.promise = transition.catch(function(error) {
var errorId = guidFor(error);

if (router._isErrorHandled(errorId)) {
Expand Down
39 changes: 39 additions & 0 deletions packages/ember/tests/routing/basic_test.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import { A as emberA } from 'ember-runtime/system/native_array';
import NoneLocation from 'ember-routing/location/none_location';
import HistoryLocation from 'ember-routing/location/history_location';
import { getOwner } from 'container/owner';
import { Transition } from 'router/transition';

var trim = jQuery.trim;

Expand Down Expand Up @@ -3020,6 +3021,44 @@ QUnit.test('Actions can be handled by inherited action handlers', function() {
router.send('baz');
});

QUnit.test('transitionTo returns Transition when passed a route name', function() {
expect(1);
Router.map(function() {
this.route('root', { path: '/' });
this.route('bar');
});

var transition = null;

bootApplication();

run(function() {
transition = router.transitionTo('bar');
});

equal(transition instanceof Transition, true);
});

QUnit.test('transitionTo returns Transition when passed a url', function() {
expect(1);
Router.map(function() {
this.route('root', { path: '/' });
this.route('bar', function() {
this.route('baz');
});
});

var transition = null;

bootApplication();

run(function() {
transition = router.transitionTo('/bar/baz');
});

equal(transition instanceof Transition, true);
});

QUnit.test('currentRouteName is a property installed on ApplicationController that can be used in transitionTo', function() {
expect(24);

Expand Down

0 comments on commit b1cf8f6

Please sign in to comment.