https://github.com/angular/angular
Raw File
Tip revision: 2fa61e8ee11bbbe4e9bafa9dce907e91aa2ab095 authored by George Kalpakas on 04 February 2019, 14:45:45 UTC
build(docs-infra): use pinned dependencies when possible in `ng-packages-installer` (#28510)
Tip revision: 2fa61e8
binding_parser_spec.ts
/**
 * @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 {SecurityContext} from '@angular/core';
import {inject} from '@angular/core/testing';

import {ElementSchemaRegistry} from '../../src/schema/element_schema_registry';
import {calcPossibleSecurityContexts} from '../../src/template_parser/binding_parser';

{
  describe('BindingParser', () => {
    let registry: ElementSchemaRegistry;

    beforeEach(inject(
        [ElementSchemaRegistry], (_registry: ElementSchemaRegistry) => { registry = _registry; }));

    describe('possibleSecurityContexts', () => {
      function hrefSecurityContexts(selector: string) {
        return calcPossibleSecurityContexts(registry, selector, 'href', false);
      }

      it('should return a single security context if the selector as an element name',
         () => { expect(hrefSecurityContexts('a')).toEqual([SecurityContext.URL]); });

      it('should return the possible security contexts if the selector has no element name', () => {
        expect(hrefSecurityContexts('[myDir]')).toEqual([
          SecurityContext.NONE, SecurityContext.URL, SecurityContext.RESOURCE_URL
        ]);
      });

      it('should exclude possible elements via :not', () => {
        expect(hrefSecurityContexts('[myDir]:not(link):not(base)')).toEqual([
          SecurityContext.NONE, SecurityContext.URL
        ]);
      });

      it('should not exclude possible narrowed elements via :not', () => {
        expect(hrefSecurityContexts('[myDir]:not(link.someClass):not(base.someClass)')).toEqual([
          SecurityContext.NONE, SecurityContext.URL, SecurityContext.RESOURCE_URL
        ]);
      });

      it('should return SecurityContext.NONE if there are no possible elements',
         () => { expect(hrefSecurityContexts('img:not(img)')).toEqual([SecurityContext.NONE]); });

      it('should return the union of the possible security contexts if multiple selectors are specified',
         () => {
           expect(calcPossibleSecurityContexts(registry, 'a,link', 'href', false)).toEqual([
             SecurityContext.URL, SecurityContext.RESOURCE_URL
           ]);
         });
    });
  });
}
back to top