BREAKING CHANGE
The ROUTE_DATA token has been removed and replaced with a type RouteData,
allowing a type injection like we do with RouteParams.
Before:
    constructor(routeParams: RouteParams, @Inject(ROUTE_DATA) routeData) {
      let id = routeParams.get('id');
      let name = ROUTE_DATA.name;
    }
After:
    constructor(routeParams: RouteParams, routeData: RouteData) {
      let id = routeParams.get('id');
      let name = routeData.get('name');
    }
Fixes #4392
Closes #4428
		
	
			
		
			
				
	
	
		
			117 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {
 | |
|   AsyncTestCompleter,
 | |
|   beforeEach,
 | |
|   ddescribe,
 | |
|   xdescribe,
 | |
|   describe,
 | |
|   dispatchEvent,
 | |
|   expect,
 | |
|   iit,
 | |
|   inject,
 | |
|   beforeEachBindings,
 | |
|   it,
 | |
|   xit,
 | |
|   TestComponentBuilder
 | |
| } from 'angular2/testing_internal';
 | |
| 
 | |
| import {SpyRouter, SpyLocation} from './spies';
 | |
| 
 | |
| import {provide, Component, View} from 'angular2/core';
 | |
| import {By} from 'angular2/src/core/debug';
 | |
| 
 | |
| import {
 | |
|   Location,
 | |
|   Router,
 | |
|   RouteRegistry,
 | |
|   RouterLink,
 | |
|   RouterOutlet,
 | |
|   Route,
 | |
|   RouteParams,
 | |
|   Instruction,
 | |
|   ComponentInstruction
 | |
| } from 'angular2/router';
 | |
| 
 | |
| import {DOM} from 'angular2/src/core/dom/dom_adapter';
 | |
| import {ComponentInstruction_} from 'angular2/src/router/instruction';
 | |
| import {PathRecognizer} from 'angular2/src/router/path_recognizer';
 | |
| import {SyncRouteHandler} from 'angular2/src/router/sync_route_handler';
 | |
| 
 | |
| let dummyPathRecognizer = new PathRecognizer('', new SyncRouteHandler(null));
 | |
| let dummyInstruction =
 | |
|     new Instruction(new ComponentInstruction_('detail', [], dummyPathRecognizer), null, {});
 | |
| 
 | |
| export function main() {
 | |
|   describe('router-link directive', function() {
 | |
|     var tcb: TestComponentBuilder;
 | |
| 
 | |
|     beforeEachBindings(() => [
 | |
|       provide(Location, {useValue: makeDummyLocation()}),
 | |
|       provide(Router, {useValue: makeDummyRouter()})
 | |
|     ]);
 | |
| 
 | |
|     beforeEach(inject([TestComponentBuilder], (tcBuilder) => { tcb = tcBuilder; }));
 | |
| 
 | |
|     it('should update a[href] attribute', inject([AsyncTestCompleter], (async) => {
 | |
| 
 | |
|          tcb.createAsync(TestComponent)
 | |
|              .then((testComponent) => {
 | |
|                testComponent.detectChanges();
 | |
|                let anchorElement = testComponent.debugElement.query(By.css('a')).nativeElement;
 | |
|                expect(DOM.getAttribute(anchorElement, 'href')).toEqual('detail');
 | |
|                async.done();
 | |
|              });
 | |
|        }));
 | |
| 
 | |
| 
 | |
|     it('should call router.navigate when a link is clicked',
 | |
|        inject([AsyncTestCompleter, Router], (async, router) => {
 | |
| 
 | |
|          tcb.createAsync(TestComponent)
 | |
|              .then((testComponent) => {
 | |
|                testComponent.detectChanges();
 | |
|                // TODO: shouldn't this be just 'click' rather than '^click'?
 | |
|                testComponent.debugElement.query(By.css('a')).triggerEventHandler('click', null);
 | |
|                expect(router.spy('navigateByInstruction')).toHaveBeenCalledWith(dummyInstruction);
 | |
|                async.done();
 | |
|              });
 | |
|        }));
 | |
|   });
 | |
| }
 | |
| 
 | |
| @Component({selector: 'my-comp'})
 | |
| class MyComp {
 | |
|   name;
 | |
| }
 | |
| 
 | |
| @Component({selector: 'user-cmp'})
 | |
| @View({template: "hello {{user}}"})
 | |
| class UserCmp {
 | |
|   user: string;
 | |
|   constructor(params: RouteParams) { this.user = params.get('name'); }
 | |
| }
 | |
| 
 | |
| @Component({selector: 'test-component'})
 | |
| @View({
 | |
|   template: `
 | |
|     <div>
 | |
|       <a [router-link]="['/Detail']">detail view</a>
 | |
|     </div>`,
 | |
|   directives: [RouterLink]
 | |
| })
 | |
| class TestComponent {
 | |
| }
 | |
| 
 | |
| function makeDummyLocation() {
 | |
|   var dl = new SpyLocation();
 | |
|   dl.spy('prepareExternalUrl').andCallFake((url) => url);
 | |
|   return dl;
 | |
| }
 | |
| 
 | |
| function makeDummyRouter() {
 | |
|   var dr = new SpyRouter();
 | |
|   dr.spy('generate').andCallFake((routeParams) => dummyInstruction);
 | |
|   dr.spy('isRouteActive').andCallFake((_) => false);
 | |
|   dr.spy('navigateInstruction');
 | |
|   return dr;
 | |
| }
 |