2019-05-31 15:56:07 +00:00
|
|
|
/**
|
|
|
|
|
* @license
|
2020-05-19 19:08:49 +00:00
|
|
|
* Copyright Google LLC All Rights Reserved.
|
2019-05-31 15:56:07 +00:00
|
|
|
*
|
|
|
|
|
* Use of this source code is governed by an MIT-style license that can be
|
2024-09-20 15:23:15 +00:00
|
|
|
* found in the LICENSE file at https://angular.dev/license
|
2019-05-31 15:56:07 +00:00
|
|
|
*/
|
|
|
|
|
|
2025-07-24 18:12:12 +00:00
|
|
|
import {ifEnvSupports, ifEnvSupportsWithDone} from '../test-util';
|
2019-05-31 15:56:07 +00:00
|
|
|
declare const global: any;
|
|
|
|
|
|
|
|
|
|
describe(
|
|
|
|
|
'MutationObserver',
|
|
|
|
|
ifEnvSupports('MutationObserver', function () {
|
|
|
|
|
let elt: HTMLDivElement;
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2020-04-13 23:40:21 +00:00
|
|
|
beforeEach(function () {
|
|
|
|
|
elt = document.createElement('div');
|
2023-05-06 07:04:24 +00:00
|
|
|
document.body.appendChild(elt);
|
|
|
|
|
});
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2023-05-06 07:04:24 +00:00
|
|
|
afterEach(function () {
|
|
|
|
|
document.body.removeChild(elt);
|
2020-04-13 23:40:21 +00:00
|
|
|
});
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2019-05-31 15:56:07 +00:00
|
|
|
it('should run observers within the zone', function (done) {
|
2022-07-14 20:49:00 +00:00
|
|
|
const testZone = Zone.current.fork({name: 'test'});
|
2019-05-31 15:56:07 +00:00
|
|
|
let ob;
|
2023-05-06 07:04:24 +00:00
|
|
|
elt = document.createElement('div');
|
|
|
|
|
document.body.appendChild(elt);
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2019-05-31 15:56:07 +00:00
|
|
|
testZone.run(function () {
|
|
|
|
|
ob = new MutationObserver(function () {
|
|
|
|
|
expect(Zone.current).toBe(testZone);
|
|
|
|
|
done();
|
|
|
|
|
});
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2019-05-31 15:56:07 +00:00
|
|
|
ob.observe(elt, {childList: true});
|
|
|
|
|
});
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2019-05-31 15:56:07 +00:00
|
|
|
elt.innerHTML = '<p>hey</p>';
|
|
|
|
|
});
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2019-05-31 15:56:07 +00:00
|
|
|
it('should only dequeue upon disconnect if something is observed', function () {
|
|
|
|
|
let ob: MutationObserver;
|
|
|
|
|
let flag = false;
|
|
|
|
|
const elt = document.createElement('div');
|
2020-04-13 23:40:21 +00:00
|
|
|
const childZone = Zone.current.fork({
|
|
|
|
|
name: 'test',
|
|
|
|
|
onInvokeTask: function () {
|
|
|
|
|
flag = true;
|
|
|
|
|
},
|
|
|
|
|
});
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2020-04-13 23:40:21 +00:00
|
|
|
childZone.run(function () {
|
|
|
|
|
ob = new MutationObserver(function () {});
|
|
|
|
|
});
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2020-04-13 23:40:21 +00:00
|
|
|
ob!.disconnect();
|
2019-05-31 15:56:07 +00:00
|
|
|
expect(flag).toBe(false);
|
|
|
|
|
});
|
|
|
|
|
}),
|
|
|
|
|
);
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2025-07-24 18:12:12 +00:00
|
|
|
describe('WebKitMutationObserver', () => {
|
|
|
|
|
it(
|
|
|
|
|
'should run observers within the zone',
|
|
|
|
|
ifEnvSupportsWithDone('WebKitMutationObserver', function (done: DoneFn) {
|
2022-07-14 20:49:00 +00:00
|
|
|
const testZone = Zone.current.fork({name: 'test'});
|
2019-05-31 15:56:07 +00:00
|
|
|
let elt: HTMLDivElement;
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2019-05-31 15:56:07 +00:00
|
|
|
testZone.run(function () {
|
|
|
|
|
elt = document.createElement('div');
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2019-05-31 15:56:07 +00:00
|
|
|
const ob = new global['WebKitMutationObserver'](function () {
|
|
|
|
|
expect(Zone.current).toBe(testZone);
|
|
|
|
|
done();
|
|
|
|
|
});
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2019-05-31 15:56:07 +00:00
|
|
|
ob.observe(elt, {childList: true});
|
|
|
|
|
});
|
2024-04-19 16:53:49 +00:00
|
|
|
|
2020-04-13 23:40:21 +00:00
|
|
|
elt!.innerHTML = '<p>hey</p>';
|
2025-07-24 18:12:12 +00:00
|
|
|
}),
|
|
|
|
|
);
|
|
|
|
|
});
|