Skip to content

Commit

Permalink
fix(metadata): Allow spacing in multiple selectors (#7418)
Browse files Browse the repository at this point in the history
  • Loading branch information
Suguru Inatomi authored and mhevery committed May 26, 2016
1 parent 85ce184 commit b2e804c
Show file tree
Hide file tree
Showing 2 changed files with 109 additions and 2 deletions.
4 changes: 2 additions & 2 deletions modules/@angular/core/src/metadata/di.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import {stringify, isString, Type} from '../../src/facade/lang';
import {stringify, isString, Type, StringWrapper} from '../../src/facade/lang';
import {DependencyMetadata} from '../di/metadata';
import {resolveForwardRef} from '../di/forward_ref';

Expand Down Expand Up @@ -184,7 +184,7 @@ export class QueryMetadata extends DependencyMetadata {
* returns a list of variable bindings this is querying for.
* Only applicable if this is a variable bindings query.
*/
get varBindings(): string[] { return this.selector.split(','); }
get varBindings(): string[] { return StringWrapper.split(this.selector, /\s*,\s*/g); }

toString(): string { return `@Query(${stringify(this.selector)})`; }
}
Expand Down
107 changes: 107 additions & 0 deletions modules/@angular/core/test/metadata/di_spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,107 @@
import {
AsyncTestCompleter,
beforeEach,
ddescribe,
describe,
expect,
iit,
inject,
it,
xit,
} from '@angular/core/testing/testing_internal';
import { TestComponentBuilder } from '@angular/compiler/testing';

import {
Component,
ViewMetadata,
Input,
Directive,
ViewChild,
ViewChildren,
QueryList,
ElementRef
} from '@angular/core';

export function main() {
describe('ViewChild', () => {
it('should support type selector',
inject([TestComponentBuilder, AsyncTestCompleter], (tcb: TestComponentBuilder, async) => {
tcb.overrideView(ViewChildTypeSelectorComponent,
new ViewMetadata(
{template: `<simple [marker]="'1'"></simple><simple [marker]="'2'"></simple>`, directives: [Simple]}))
.createAsync(ViewChildTypeSelectorComponent)
.then((view) => {
view.detectChanges();
expect(view.componentInstance.child).toBeDefined();
expect(view.componentInstance.child.marker).toBe("1");
async.done();
});
}));
it('should support string selector',
inject([TestComponentBuilder, AsyncTestCompleter], (tcb: TestComponentBuilder, async) => {
tcb.overrideView(
ViewChildStringSelectorComponent,
new ViewMetadata({template: `<simple #child></simple>`, directives: [Simple]}))
.createAsync(ViewChildStringSelectorComponent)
.then((view) => {
view.detectChanges();
expect(view.componentInstance.child).toBeDefined();
async.done();
});
}));
});
describe('ViewChildren', () => {
it('should support type selector',
inject([TestComponentBuilder, AsyncTestCompleter], (tcb: TestComponentBuilder, async) => {
tcb.overrideView(ViewChildrenTypeSelectorComponent,
new ViewMetadata({template: `<simple></simple><simple></simple>`, directives: [Simple]}))
.createAsync(ViewChildrenTypeSelectorComponent)
.then((view) => {
view.detectChanges();
expect(view.componentInstance.children).toBeDefined();
expect(view.componentInstance.children.length).toBe(2);
async.done();
});
}));
it('should support string selector',
inject([TestComponentBuilder, AsyncTestCompleter], (tcb: TestComponentBuilder, async) => {
tcb.overrideView(
ViewChildrenStringSelectorComponent,
new ViewMetadata({template: `<simple #child1></simple><simple #child2></simple>`, directives: [Simple]}))
.createAsync(ViewChildrenStringSelectorComponent)
.then((view) => {
view.detectChanges();
expect(view.componentInstance.children).toBeDefined();
expect(view.componentInstance.children.length).toBe(2);
async.done();
});
}));
});
}


@Directive({selector: "simple"})
class Simple {
@Input() marker: string;
}

@Component({selector: 'view-child-type-selector'})
class ViewChildTypeSelectorComponent {
@ViewChild(Simple) child: Simple;
}

@Component({selector: 'view-child-string-selector'})
class ViewChildStringSelectorComponent {
@ViewChild("child") child: ElementRef;
}

@Component({selector: 'view-children-type-selector'})
class ViewChildrenTypeSelectorComponent {
@ViewChildren(Simple) children: QueryList<Simple>;
}

@Component({selector: 'view-child-string-selector'})
class ViewChildrenStringSelectorComponent {
// Allow comma separated selector (with spaces).
@ViewChildren("child1 , child2") children: QueryList<ElementRef>;
}

0 comments on commit b2e804c

Please sign in to comment.