首页 > web前端 > js教程 > 正文

测试每个 MutationObserver 是否已断开连接以避免内存泄漏

WBOY
发布: 2024-08-22 22:34:02
原创
780 人浏览过

Test that every MutationObserver is disconnected to avoid memory leaks

MutationObserver 是一种有用的机制,可以监视 DOM 中的更改并对其做出响应。

MutationObserver 接口提供了监视 DOM 树发生更改的能力。

这是一个监视主题类更改的示例。

    function setUpThemeClassObservers() {
        const observer = new MutationObserver(() => {
            const themeClass = this.getThemeClass();
            this.fireStylesChangedEvent('themeChanged');
        });

        observer.observe(this.eGridDiv, {
            attributes: true,
            attributeFilter: ['class'],
        });

        // we must disconnect otherwise "this" will not be GC'd
        // causing a memory leak
        return () => observer.disconnect();
    }
登录后复制

但是,如果您忘记断开连接,则可能会导致内存泄漏,具体取决于从 MutationObserver 函数中访问的内容。

如果有一个测试可以验证我们是否断开了观察者的连接不是很好吗?

自动验证代码

事实证明,可以验证每个正在观察 DOM 的 MutationObserver 也已断开连接。 (如果您必须使用不同的代码路径来设置 MutationObservers,您可能需要多个测试)

这个想法是用子模拟来模拟全局 MutationObserver 的观察和断开连接方法。在返回模拟之前,我们将其记录在一个数组中,以便我们可以在测试运行结束时验证所有实例。

describe('Mutation Observers Disconnected', () => {

    let originalMutationObserver: typeof MutationObserver;

    const allMockedObservers: any = [];
    const mutationObserverMock = jest.fn<MutationObserver, [MutationCallback]>().mockImplementation(() => {
        const mock = {
            observe: jest.fn(),
            disconnect: jest.fn(),
            takeRecords: jest.fn(),
        };
        allMockedObservers.push(mock);
        return mock;
    });

    beforeEach(() => {
        // Ensure we can restore the real MutationObserver after the test
        originalMutationObserver = global.MutationObserver;
        global.MutationObserver = mutationObserverMock;
    });

    afterEach(() => {
        global.MutationObserver = originalMutationObserver;
    });

    test('observer always disconnected after destroy', async () => {
        const api = createGrid();
        // Perform some actions if required to exercise the code paths
        api.destroy();

        expect(allMockedObservers.length).toBeGreaterThan(0);
        for (const mock of allMockedObservers) {
            expect(mock.observe).toHaveBeenCalled();
            expect(mock.disconnect).toHaveBeenCalled();
        }
    });
});
登录后复制

通过这种方式,我们可以验证在测试期间设置的每个 MutationObserver 在测试结束时也已断开连接。


Stephen Cooper - AG Grid 高级开发人员
在 X @ScooperDev 上关注我

以上是测试每个 MutationObserver 是否已断开连接以避免内存泄漏的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!