2016-06-23 12:47:54 -04:00
|
|
|
/**
|
|
|
|
* @license
|
2020-05-19 15:08:49 -04:00
|
|
|
* Copyright Google LLC All Rights Reserved.
|
2016-06-23 12:47:54 -04:00
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
2021-05-23 16:16:02 -04:00
|
|
|
import {inject} from '../../../core/testing';
|
2016-08-01 15:19:09 -04:00
|
|
|
import {Element} from '../../src/ml_parser/ast';
|
|
|
|
import {HtmlParser} from '../../src/ml_parser/html_parser';
|
2016-07-21 14:41:25 -04:00
|
|
|
import {PreparsedElement, PreparsedElementType, preparseElement} from '../../src/template_parser/template_preparser';
|
2015-09-18 13:33:23 -04:00
|
|
|
|
2017-12-16 17:42:55 -05:00
|
|
|
{
|
2015-09-18 13:33:23 -04:00
|
|
|
describe('preparseElement', () => {
|
2016-11-12 08:08:58 -05:00
|
|
|
let htmlParser: HtmlParser;
|
2020-04-08 13:14:18 -04:00
|
|
|
beforeEach(inject([HtmlParser], (_htmlParser: HtmlParser) => {
|
|
|
|
htmlParser = _htmlParser;
|
|
|
|
}));
|
2015-09-18 13:33:23 -04:00
|
|
|
|
|
|
|
function preparse(html: string): PreparsedElement {
|
2016-07-21 16:56:58 -04:00
|
|
|
return preparseElement(htmlParser.parse(html, 'TestComp').rootNodes[0] as Element);
|
2015-09-18 13:33:23 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
it('should detect script elements', inject([HtmlParser], (htmlParser: HtmlParser) => {
|
|
|
|
expect(preparse('<script>').type).toBe(PreparsedElementType.SCRIPT);
|
|
|
|
}));
|
|
|
|
|
|
|
|
it('should detect style elements', inject([HtmlParser], (htmlParser: HtmlParser) => {
|
|
|
|
expect(preparse('<style>').type).toBe(PreparsedElementType.STYLE);
|
|
|
|
}));
|
|
|
|
|
|
|
|
it('should detect stylesheet elements', inject([HtmlParser], (htmlParser: HtmlParser) => {
|
|
|
|
expect(preparse('<link rel="stylesheet">').type).toBe(PreparsedElementType.STYLESHEET);
|
|
|
|
expect(preparse('<link rel="stylesheet" href="someUrl">').hrefAttr).toEqual('someUrl');
|
|
|
|
expect(preparse('<link rel="someRel">').type).toBe(PreparsedElementType.OTHER);
|
|
|
|
}));
|
|
|
|
|
|
|
|
it('should detect ng-content elements', inject([HtmlParser], (htmlParser: HtmlParser) => {
|
|
|
|
expect(preparse('<ng-content>').type).toBe(PreparsedElementType.NG_CONTENT);
|
|
|
|
}));
|
|
|
|
|
|
|
|
it('should normalize ng-content.select attribute',
|
|
|
|
inject([HtmlParser], (htmlParser: HtmlParser) => {
|
|
|
|
expect(preparse('<ng-content>').selectAttr).toEqual('*');
|
|
|
|
expect(preparse('<ng-content select>').selectAttr).toEqual('*');
|
|
|
|
expect(preparse('<ng-content select="*">').selectAttr).toEqual('*');
|
|
|
|
}));
|
|
|
|
|
2016-03-23 17:15:05 -04:00
|
|
|
it('should extract ngProjectAs value', () => {
|
|
|
|
expect(preparse('<p ngProjectAs="el[attr].class"></p>').projectAs).toEqual('el[attr].class');
|
|
|
|
});
|
2015-09-18 13:33:23 -04:00
|
|
|
});
|
2015-10-02 10:57:29 -04:00
|
|
|
}
|