angular-cn/packages/elements/test/extract-projectable-nodes_spec.ts
Paul Gschwendtner 647d7bdd88 refactor: fix typescript strict flag failures in all tests (#30993)
Fixes all TypeScript failures caused by enabling the `--strict`
flag for test source files. We also want to enable the strict
options for tests as the strictness enforcement improves the
overall codehealth, unveiled common issues and additionally it
allows us to enable `strict` in the `tsconfig.json` that is picked
up by IDE's.

PR Close #30993
2019-07-18 14:21:26 -07:00

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