Skip to content

Commit 3fb49aa

Browse files
authored
Merge pull request #73 from nut-tree/feature/69/press_release_mouse_buttons
Closes #69
2 parents aa09ce0 + a8551a2 commit 3fb49aa

File tree

2 files changed

+39
-0
lines changed

2 files changed

+39
-0
lines changed

lib/mouse.class.spec.ts

Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -136,3 +136,20 @@ describe("Mouse class", () => {
136136
expect(result).toBe(SUT);
137137
});
138138
});
139+
140+
describe("Mousebuttons", () => {
141+
it.each([
142+
[Button.LEFT, Button.LEFT],
143+
[Button.MIDDLE, Button.MIDDLE],
144+
[Button.RIGHT, Button.RIGHT],
145+
] as Array<[Button, Button]>)("should be pressed and released", async (input: Button, expected: Button) => {
146+
const nativeAdapterMock = new NativeAdapter();
147+
const SUT = new Mouse(nativeAdapterMock);
148+
const pressed = await SUT.pressButton(input);
149+
const released = await SUT.releaseButton(input);
150+
expect(nativeAdapterMock.pressButton).toBeCalledWith(expected);
151+
expect(nativeAdapterMock.releaseButton).toBeCalledWith(expected);
152+
expect(pressed).toBe(SUT);
153+
expect(released).toBe(SUT);
154+
});
155+
});

lib/mouse.class.ts

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -128,4 +128,26 @@ export class Mouse {
128128
}
129129
});
130130
}
131+
132+
public async pressButton(btn: Button): Promise<Mouse> {
133+
return new Promise<Mouse>(async (resolve, reject) => {
134+
try {
135+
await this.native.pressButton(btn);
136+
resolve(this);
137+
} catch (e) {
138+
reject(e);
139+
}
140+
});
141+
}
142+
143+
public async releaseButton(btn: Button): Promise<Mouse> {
144+
return new Promise<Mouse>(async (resolve, reject) => {
145+
try {
146+
await this.native.releaseButton(btn);
147+
resolve(this);
148+
} catch (e) {
149+
reject(e);
150+
}
151+
});
152+
}
131153
}

0 commit comments

Comments
 (0)