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