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],
 | 
						|
       }));
 | 
						|
  });
 | 
						|
});
 |