82 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			82 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @license
							 | 
						||
| 
								 | 
							
								 * Copyright Google Inc. All Rights Reserved.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Use of this source code is governed by an MIT-style license that can be
							 | 
						||
| 
								 | 
							
								 * found in the LICENSE file at https://angular.io/license
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								import {extractProjectableNodes} from '../src/extract-projectable-nodes';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								describe('extractProjectableNodes()', () => {
							 | 
						||
| 
								 | 
							
								  let elem: HTMLElement;
							 | 
						||
| 
								 | 
							
								  let childNodes: NodeList;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  const expectProjectableNodes = (matches: {[selector: string]: number[]}) => {
							 | 
						||
| 
								 | 
							
								    const selectors = Object.keys(matches);
							 | 
						||
| 
								 | 
							
								    const expected = selectors.map(selector => {
							 | 
						||
| 
								 | 
							
								      const matchingIndices = matches[selector];
							 | 
						||
| 
								 | 
							
								      return matchingIndices.map(idx => childNodes[idx]);
							 | 
						||
| 
								 | 
							
								    });
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    expect(extractProjectableNodes(elem, selectors)).toEqual(expected);
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								  const test = (matches: {[selector: string]: number[]}) => () => expectProjectableNodes(matches);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  beforeEach(() => {
							 | 
						||
| 
								 | 
							
								    elem = document.createElement('div');
							 | 
						||
| 
								 | 
							
								    elem.innerHTML = '<div class="foo" first="">' +
							 | 
						||
| 
								 | 
							
								        '<span class="bar"></span>' +
							 | 
						||
| 
								 | 
							
								        '</div>' +
							 | 
						||
| 
								 | 
							
								        '<span id="bar"></span>' +
							 | 
						||
| 
								 | 
							
								        '<!-- Comment -->' +
							 | 
						||
| 
								 | 
							
								        'Text' +
							 | 
						||
| 
								 | 
							
								        '<blink class="foo" id="quux"></blink>' +
							 | 
						||
| 
								 | 
							
								        'More text';
							 | 
						||
| 
								 | 
							
								    childNodes = Array.prototype.slice.call(elem.childNodes);
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  it('should match each node to the corresponding selector', test({
							 | 
						||
| 
								 | 
							
								       '[first]': [0],
							 | 
						||
| 
								 | 
							
								       '#bar': [1],
							 | 
						||
| 
								 | 
							
								       '#quux': [4],
							 | 
						||
| 
								 | 
							
								     }));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  it('should ignore non-matching nodes', test({
							 | 
						||
| 
								 | 
							
								       '.zoo': [],
							 | 
						||
| 
								 | 
							
								     }));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  it('should only match top-level child nodes', test({
							 | 
						||
| 
								 | 
							
								       'span': [1],
							 | 
						||
| 
								 | 
							
								       '.bar': [],
							 | 
						||
| 
								 | 
							
								     }));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  it('should support complex selectors', test({
							 | 
						||
| 
								 | 
							
								       '.foo:not(div)': [4],
							 | 
						||
| 
								 | 
							
								       'div + #bar': [1],
							 | 
						||
| 
								 | 
							
								     }));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  it('should match each node with the first matching selector', test({
							 | 
						||
| 
								 | 
							
								       'div': [0],
							 | 
						||
| 
								 | 
							
								       '.foo': [4],
							 | 
						||
| 
								 | 
							
								       'blink': [],
							 | 
						||
| 
								 | 
							
								     }));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  describe('(with wildcard selector)', () => {
							 | 
						||
| 
								 | 
							
								    it('should match non-element nodes to `*` (but still ignore comments)', test({
							 | 
						||
| 
								 | 
							
								         'div,span,blink': [0, 1, 4],
							 | 
						||
| 
								 | 
							
								         '*': [2, 3, 5],
							 | 
						||
| 
								 | 
							
								       }));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    it('should match otherwise unmatched nodes to `*`', test({
							 | 
						||
| 
								 | 
							
								         'div,blink': [0, 4],
							 | 
						||
| 
								 | 
							
								         '*': [1, 2, 3, 5],
							 | 
						||
| 
								 | 
							
								       }));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    it('should give higher priority to `*` (eve if it appears first)', test({
							 | 
						||
| 
								 | 
							
								         '*': [2, 3, 5],
							 | 
						||
| 
								 | 
							
								         'div,span,blink': [0, 1, 4],
							 | 
						||
| 
								 | 
							
								       }));
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								});
							 |