mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-05-09 04:32:51 +00:00
Libraries: Move to Userland/Libraries/
This commit is contained in:
parent
dc28c07fa5
commit
13d7c09125
Notes:
sideshowbarker
2024-07-18 23:53:55 +09:00
Author: https://github.com/awesomekling
Commit: 13d7c09125
1857 changed files with 266 additions and 274 deletions
|
@ -1,112 +0,0 @@
|
|||
describe("correct behavior", () => {
|
||||
test("basic functionality", () => {
|
||||
class A {
|
||||
static get x() {
|
||||
return this._x;
|
||||
}
|
||||
|
||||
static set x(value) {
|
||||
this._x = value * 2;
|
||||
}
|
||||
}
|
||||
|
||||
expect(A.x).toBeUndefined();
|
||||
expect(A).not.toHaveProperty("_x");
|
||||
A.x = 3;
|
||||
expect(A.x).toBe(6);
|
||||
expect(A).toHaveProperty("_x", 6);
|
||||
});
|
||||
|
||||
test("name", () => {
|
||||
class A {
|
||||
static set x(v) {}
|
||||
}
|
||||
|
||||
const d = Object.getOwnPropertyDescriptor(A, "x");
|
||||
expect(d.set.name).toBe("set x");
|
||||
});
|
||||
|
||||
test("extended name syntax", () => {
|
||||
const s = Symbol("foo");
|
||||
|
||||
class A {
|
||||
static set "method with space"(value) {
|
||||
this.a = value;
|
||||
}
|
||||
|
||||
static set 12(value) {
|
||||
this.b = value;
|
||||
}
|
||||
|
||||
static set [`he${"llo"}`](value) {
|
||||
this.c = value;
|
||||
}
|
||||
|
||||
static set [s](value) {
|
||||
this.d = value;
|
||||
}
|
||||
}
|
||||
|
||||
A["method with space"] = 1;
|
||||
A[12] = 2;
|
||||
A.hello = 3;
|
||||
A[s] = 4;
|
||||
expect(A.a).toBe(1);
|
||||
expect(A.b).toBe(2);
|
||||
expect(A.c).toBe(3);
|
||||
expect(A.d).toBe(4);
|
||||
});
|
||||
|
||||
test("inherited static setter", () => {
|
||||
class Parent {
|
||||
static get x() {
|
||||
return this._x;
|
||||
}
|
||||
|
||||
static set x(value) {
|
||||
this._x = value * 2;
|
||||
}
|
||||
}
|
||||
|
||||
class Child extends Parent {}
|
||||
|
||||
expect(Child.x).toBeUndefined();
|
||||
Child.x = 10;
|
||||
expect(Child.x).toBe(20);
|
||||
});
|
||||
|
||||
test("inherited static setter overriding", () => {
|
||||
class Parent {
|
||||
static get x() {
|
||||
return this._x;
|
||||
}
|
||||
|
||||
static set x(value) {
|
||||
this._x = value * 2;
|
||||
}
|
||||
}
|
||||
|
||||
class Child extends Parent {
|
||||
static get x() {
|
||||
return this._x;
|
||||
}
|
||||
|
||||
static set x(value) {
|
||||
this._x = value * 3;
|
||||
}
|
||||
}
|
||||
|
||||
expect(Child.x).toBeUndefined();
|
||||
Child.x = 10;
|
||||
expect(Child.x).toBe(30);
|
||||
});
|
||||
});
|
||||
|
||||
describe("errors", () => {
|
||||
test('"set static" is a syntax error', () => {
|
||||
expect(`
|
||||
class A {
|
||||
set static foo(value) {}
|
||||
}`).not.toEval();
|
||||
});
|
||||
});
|
Loading…
Add table
Add a link
Reference in a new issue