chrome-devtools-frontend
Version:
Chrome DevTools UI
77 lines (69 loc) • 1.97 kB
JavaScript
// Copyright 2020 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
'use strict';
const rule = require('../lib/enforce-bound-render-for-schedule-render.js');
const {ruleTester} = require('./utils/utils.js');
ruleTester.run('enforce-bound-render-for-schedule-render', rule, {
valid: [
{
code: `
class Component extends HTMLElement {
#boundRender = this.#render.bind(this);
get data(data) {
this.data = data;
void ComponentHelpers.ScheduledRender.scheduleRender(this, this.#boundRender);
}
#render() {}
}
`,
filename: 'front_end/ui/components/foo/Foo.ts',
},
{
code: `
class Component extends HTMLElement {
get data(data) {
this.data = data;
void ComponentHelpers.ScheduledRender.scheduleRender(this, this.#render);
}
#render = () => {};
}
`,
filename: 'front_end/ui/components/foo/Foo.ts',
},
{
code: `
class Renderer {
render() {
}
}
class Component extends HTMLElement {
#renderer = new Renderer();
#boundRender = this.#renderer.render.bind(this);
get data(data) {
this.data = data;
void ComponentHelpers.ScheduledRender.scheduleRender(this, this.#boundRender);
}
}
`,
filename: 'front_end/ui/components/foo/Foo.ts',
},
],
invalid: [
{
code: `class Component extends HTMLElement {
get data(data) {
this.data = data;
void ComponentHelpers.ScheduledRender.scheduleRender(this, this.#render);
}
#render() {}
}`,
filename: 'front_end/components/test.ts',
errors: [
{
message: 'Bind `render` method of `scheduleRender` to `this` in components',
},
],
},
],
});