fix(core): meta addTag() adds incorrect attribute for httpEquiv (#32531)

Meta::addTag() adds a meta tag with httpEquiv attribute instead of http-equiv when
MetaDefinition contains httpEquiv property.

PR Close #32531
This commit is contained in:
Kara Erickson 2019-08-30 12:52:48 -07:00 committed by Andrew Kushnir
parent 156f9f30ae
commit ff0a90e4a8
2 changed files with 27 additions and 2 deletions

View File

@ -180,7 +180,8 @@ export class Meta {
} }
private _setMetaElementAttributes(tag: MetaDefinition, el: HTMLMetaElement): HTMLMetaElement { private _setMetaElementAttributes(tag: MetaDefinition, el: HTMLMetaElement): HTMLMetaElement {
Object.keys(tag).forEach((prop: string) => el.setAttribute(prop, tag[prop])); Object.keys(tag).forEach(
(prop: string) => el.setAttribute(this._getMetaKeyMap(prop), tag[prop]));
return el; return el;
} }
@ -190,6 +191,18 @@ export class Meta {
} }
private _containsAttributes(tag: MetaDefinition, elem: HTMLMetaElement): boolean { private _containsAttributes(tag: MetaDefinition, elem: HTMLMetaElement): boolean {
return Object.keys(tag).every((key: string) => elem.getAttribute(key) === tag[key]); return Object.keys(tag).every(
(key: string) => elem.getAttribute(this._getMetaKeyMap(key)) === tag[key]);
}
private _getMetaKeyMap(prop: string): string {
return META_KEYS_MAP[prop] || prop;
} }
} }
/**
* Mapping for MetaDefinition properties with their correct meta attribute names
*/
const META_KEYS_MAP: {[prop: string]: string;} = {
httpEquiv: 'http-equiv'
};

View File

@ -126,6 +126,18 @@ import {expect} from '@angular/platform-browser/testing/src/matchers';
metaService.removeTagElement(actual); metaService.removeTagElement(actual);
}); });
it('should add httpEquiv meta tag as http-equiv', () => {
metaService.addTag({httpEquiv: 'refresh', content: '3;url=http://test'});
const actual = metaService.getTag('http-equiv')!;
expect(actual).not.toBeNull();
expect(actual.getAttribute('http-equiv')).toEqual('refresh');
expect(actual.getAttribute('content')).toEqual('3;url=http://test');
// clean up
metaService.removeTagElement(actual);
});
it('should add multiple new meta tags', () => { it('should add multiple new meta tags', () => {
const nameSelector = 'name="twitter:title"'; const nameSelector = 'name="twitter:title"';
const propertySelector = 'property="og:title"'; const propertySelector = 'property="og:title"';