2019-05-31 11:56:07 -04:00
|
|
|
/**
|
|
|
|
* @license
|
2020-05-19 15:08:49 -04:00
|
|
|
* Copyright Google LLC All Rights Reserved.
|
2019-05-31 11:56:07 -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
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* check that document.registerElement(name, { prototype: proto });
|
|
|
|
* is properly patched
|
|
|
|
*/
|
|
|
|
|
|
|
|
function customElementsSupport() {
|
|
|
|
return 'registerElement' in document;
|
|
|
|
}
|
|
|
|
customElementsSupport.message = 'window.customElements';
|
|
|
|
|
|
|
|
describe('customElements', function() {
|
|
|
|
const testZone = Zone.current.fork({name: 'test'});
|
|
|
|
const bridge = {
|
|
|
|
connectedCallback: () => {},
|
|
|
|
disconnectedCallback: () => {},
|
|
|
|
adoptedCallback: () => {},
|
|
|
|
attributeChangedCallback: () => {}
|
|
|
|
};
|
|
|
|
|
|
|
|
class TestCustomElement extends HTMLElement {
|
2020-04-13 19:40:21 -04:00
|
|
|
constructor() {
|
|
|
|
super();
|
|
|
|
}
|
2019-05-31 11:56:07 -04:00
|
|
|
|
2020-04-13 19:40:21 -04:00
|
|
|
static get observedAttributes() {
|
|
|
|
return ['attr1', 'attr2'];
|
|
|
|
}
|
2019-05-31 11:56:07 -04:00
|
|
|
|
2020-04-13 19:40:21 -04:00
|
|
|
connectedCallback() {
|
|
|
|
return bridge.connectedCallback();
|
|
|
|
}
|
2019-05-31 11:56:07 -04:00
|
|
|
|
2020-04-13 19:40:21 -04:00
|
|
|
disconnectedCallback() {
|
|
|
|
return bridge.disconnectedCallback();
|
|
|
|
}
|
2019-05-31 11:56:07 -04:00
|
|
|
|
|
|
|
attributeChangedCallback(attrName, oldVal, newVal) {
|
|
|
|
return bridge.attributeChangedCallback(attrName, oldVal, newVal);
|
|
|
|
}
|
|
|
|
|
2020-04-13 19:40:21 -04:00
|
|
|
adoptedCallback() {
|
|
|
|
return bridge.adoptedCallback();
|
|
|
|
}
|
2019-05-31 11:56:07 -04:00
|
|
|
}
|
|
|
|
|
2020-04-13 19:40:21 -04:00
|
|
|
testZone.run(() => {
|
|
|
|
customElements.define('x-test', TestCustomElement);
|
|
|
|
});
|
2019-05-31 11:56:07 -04:00
|
|
|
|
|
|
|
let elt;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
bridge.connectedCallback = () => {};
|
|
|
|
bridge.disconnectedCallback = () => {};
|
|
|
|
bridge.attributeChangedCallback = () => {};
|
|
|
|
bridge.adoptedCallback = () => {};
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
if (elt) {
|
|
|
|
document.body.removeChild(elt);
|
|
|
|
elt = null;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should work with connectedCallback', function(done) {
|
|
|
|
bridge.connectedCallback = function() {
|
|
|
|
expect(Zone.current.name).toBe(testZone.name);
|
|
|
|
done();
|
|
|
|
};
|
|
|
|
|
|
|
|
elt = document.createElement('x-test');
|
|
|
|
document.body.appendChild(elt);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should work with disconnectedCallback', function(done) {
|
|
|
|
bridge.disconnectedCallback = function() {
|
|
|
|
expect(Zone.current.name).toBe(testZone.name);
|
|
|
|
done();
|
|
|
|
};
|
|
|
|
|
|
|
|
elt = document.createElement('x-test');
|
|
|
|
document.body.appendChild(elt);
|
|
|
|
document.body.removeChild(elt);
|
|
|
|
elt = null;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should work with attributeChanged', function(done) {
|
|
|
|
bridge.attributeChangedCallback = function(attrName, oldVal, newVal) {
|
|
|
|
expect(Zone.current.name).toBe(testZone.name);
|
|
|
|
expect(attrName).toEqual('attr1');
|
|
|
|
expect(newVal).toEqual('value1');
|
|
|
|
done();
|
|
|
|
};
|
|
|
|
|
|
|
|
elt = document.createElement('x-test');
|
|
|
|
document.body.appendChild(elt);
|
|
|
|
elt.setAttribute('attr1', 'value1');
|
|
|
|
});
|
|
|
|
});
|