2015-05-06 21:28:24 -04:00
|
|
|
import {
|
|
|
|
AsyncTestCompleter,
|
|
|
|
describe,
|
|
|
|
proxy,
|
2015-05-29 17:58:41 -04:00
|
|
|
it,
|
|
|
|
iit,
|
|
|
|
ddescribe,
|
|
|
|
expect,
|
|
|
|
inject,
|
|
|
|
beforeEach,
|
|
|
|
beforeEachBindings,
|
|
|
|
SpyObject
|
2015-10-13 03:29:13 -04:00
|
|
|
} from 'angular2/testing_internal';
|
2015-05-06 21:28:24 -04:00
|
|
|
|
2015-10-11 01:11:13 -04:00
|
|
|
import {Injector, provide} from 'angular2/core';
|
2015-08-20 17:28:25 -04:00
|
|
|
import {CONST_EXPR} from 'angular2/src/core/facade/lang';
|
2015-08-11 00:42:47 -04:00
|
|
|
import {Location, APP_BASE_HREF} from 'angular2/src/router/location';
|
2015-06-22 15:14:19 -04:00
|
|
|
import {LocationStrategy} from 'angular2/src/router/location_strategy';
|
|
|
|
import {MockLocationStrategy} from 'angular2/src/mock/mock_location_strategy';
|
2015-05-06 21:28:24 -04:00
|
|
|
|
|
|
|
export function main() {
|
|
|
|
describe('Location', () => {
|
|
|
|
|
2015-06-22 15:14:19 -04:00
|
|
|
var locationStrategy, location;
|
2015-05-06 21:28:24 -04:00
|
|
|
|
2015-10-11 01:11:13 -04:00
|
|
|
function makeLocation(baseHref: string = '/my/app', provider: any = CONST_EXPR([])): Location {
|
2015-06-22 15:14:19 -04:00
|
|
|
locationStrategy = new MockLocationStrategy();
|
|
|
|
locationStrategy.internalBaseHref = baseHref;
|
2015-06-15 18:41:09 -04:00
|
|
|
let injector = Injector.resolveAndCreate(
|
2015-10-12 14:30:34 -04:00
|
|
|
[Location, provide(LocationStrategy, {useValue: locationStrategy}), provider]);
|
2015-06-15 18:41:09 -04:00
|
|
|
return location = injector.get(Location);
|
|
|
|
}
|
|
|
|
|
|
|
|
beforeEach(makeLocation);
|
2015-05-06 21:28:24 -04:00
|
|
|
|
2015-05-11 17:49:55 -04:00
|
|
|
it('should normalize relative urls on navigate', () => {
|
|
|
|
location.go('user/btford');
|
2015-06-22 15:14:19 -04:00
|
|
|
expect(locationStrategy.path()).toEqual('/my/app/user/btford');
|
2015-05-11 17:49:55 -04:00
|
|
|
});
|
|
|
|
|
2015-06-12 14:29:31 -04:00
|
|
|
it('should not prepend urls with starting slash when an empty URL is provided',
|
2015-06-22 15:14:19 -04:00
|
|
|
() => { expect(location.normalizeAbsolutely('')).toEqual(locationStrategy.getBaseHref()); });
|
2015-06-12 14:29:31 -04:00
|
|
|
|
2015-06-12 15:57:35 -04:00
|
|
|
it('should not prepend path with an extra slash when a baseHref has a trailing slash', () => {
|
2015-06-15 18:41:09 -04:00
|
|
|
let location = makeLocation('/my/slashed/app/');
|
2015-06-12 15:57:35 -04:00
|
|
|
expect(location.normalizeAbsolutely('/page')).toEqual('/my/slashed/app/page');
|
|
|
|
});
|
|
|
|
|
2015-05-11 17:49:55 -04:00
|
|
|
it('should not append urls with leading slash on navigate', () => {
|
2015-05-06 21:28:24 -04:00
|
|
|
location.go('/my/app/user/btford');
|
2015-06-22 15:14:19 -04:00
|
|
|
expect(locationStrategy.path()).toEqual('/my/app/user/btford');
|
2015-05-06 21:28:24 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should remove index.html from base href', () => {
|
2015-06-15 18:41:09 -04:00
|
|
|
let location = makeLocation('/my/app/index.html');
|
2015-05-11 17:49:55 -04:00
|
|
|
location.go('user/btford');
|
2015-06-22 15:14:19 -04:00
|
|
|
expect(locationStrategy.path()).toEqual('/my/app/user/btford');
|
2015-05-06 21:28:24 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should normalize urls on popstate', inject([AsyncTestCompleter], (async) => {
|
2015-06-22 15:14:19 -04:00
|
|
|
locationStrategy.simulatePopState('/my/app/user/btford');
|
2015-05-29 17:58:41 -04:00
|
|
|
location.subscribe((ev) => {
|
|
|
|
expect(ev['url']).toEqual('/user/btford');
|
|
|
|
async.done();
|
|
|
|
})
|
2015-09-09 10:41:11 -04:00
|
|
|
}));
|
2015-05-06 21:28:24 -04:00
|
|
|
|
|
|
|
it('should normalize location path', () => {
|
2015-06-22 15:14:19 -04:00
|
|
|
locationStrategy.internalPath = '/my/app/user/btford';
|
2015-05-06 21:28:24 -04:00
|
|
|
expect(location.path()).toEqual('/user/btford');
|
|
|
|
});
|
|
|
|
|
2015-06-15 18:41:09 -04:00
|
|
|
it('should use optional base href param', () => {
|
2015-10-12 14:30:34 -04:00
|
|
|
let location = makeLocation('/', provide(APP_BASE_HREF, {useValue: '/my/custom/href'}));
|
2015-06-15 18:41:09 -04:00
|
|
|
location.go('user/btford');
|
2015-06-22 15:14:19 -04:00
|
|
|
expect(locationStrategy.path()).toEqual('/my/custom/href/user/btford');
|
2015-06-15 18:41:09 -04:00
|
|
|
});
|
2015-07-17 15:14:48 -04:00
|
|
|
|
|
|
|
it('should throw when no base href is provided', () => {
|
|
|
|
var locationStrategy = new MockLocationStrategy();
|
|
|
|
locationStrategy.internalBaseHref = null;
|
|
|
|
expect(() => new Location(locationStrategy))
|
|
|
|
.toThrowError(
|
2015-10-11 01:11:13 -04:00
|
|
|
`No base href set. Either provide a provider for the APP_BASE_HREF token or add a base element to the document.`);
|
2015-07-17 15:14:48 -04:00
|
|
|
});
|
2015-07-28 23:19:56 -04:00
|
|
|
|
|
|
|
it('should revert to the previous path when a back() operation is executed', () => {
|
|
|
|
var locationStrategy = new MockLocationStrategy();
|
|
|
|
var location = new Location(locationStrategy);
|
|
|
|
|
2015-07-28 01:46:09 -04:00
|
|
|
function assertUrl(path) { expect(location.path()).toEqual(path); }
|
|
|
|
|
2015-07-28 23:19:56 -04:00
|
|
|
location.go('/ready');
|
|
|
|
assertUrl('/ready');
|
|
|
|
|
|
|
|
location.go('/ready/set');
|
|
|
|
assertUrl('/ready/set');
|
|
|
|
|
|
|
|
location.go('/ready/set/go');
|
|
|
|
assertUrl('/ready/set/go');
|
|
|
|
|
|
|
|
location.back();
|
|
|
|
assertUrl('/ready/set');
|
|
|
|
|
|
|
|
location.back();
|
|
|
|
assertUrl('/ready');
|
|
|
|
});
|
2015-10-07 19:56:35 -04:00
|
|
|
|
|
|
|
it('should incorporate the provided query values into the location change', () => {
|
|
|
|
var locationStrategy = new MockLocationStrategy();
|
|
|
|
var location = new Location(locationStrategy);
|
|
|
|
|
|
|
|
location.go('/home', "key=value");
|
|
|
|
expect(location.path()).toEqual("/home?key=value");
|
|
|
|
});
|
2015-06-15 18:41:09 -04:00
|
|
|
});
|
2015-05-06 21:28:24 -04:00
|
|
|
}
|