jsPsych/packages/plugin-serial-reaction-time-mouse/src/index.spec.ts

79 lines
2.1 KiB
TypeScript

import { mouseDownMouseUpTarget, simulateTimeline, startTimeline } from "@jspsych/test-utils";
import serialReactionTimeMouse from ".";
jest.useFakeTimers();
const getCellElement = (
cellId: string,
displayElement: HTMLElement
) =>
displayElement.querySelector(`#jspsych-serial-reaction-time-stimulus-cell-${cellId}`) as HTMLElement;
describe("serial-reaction-time-mouse plugin", () => {
test("default behavior", async () => {
const { getHTML, expectFinished, displayElement } = await startTimeline([
{
type: serialReactionTimeMouse,
target: [0, 0],
},
]);
expect(getCellElement("0-0", displayElement).style.backgroundColor).toBe("rgb(153, 153, 153)");
expect(getCellElement("0-1", displayElement).style.backgroundColor).toBe("");
expect(getCellElement("0-2", displayElement).style.backgroundColor).toBe("");
expect(getCellElement("0-3", displayElement).style.backgroundColor).toBe("");
mouseDownMouseUpTarget(getCellElement("0-1", displayElement));
expect(getHTML()).not.toBe("");
mouseDownMouseUpTarget(getCellElement("0-0", displayElement));
await expectFinished();
});
});
describe("serial-reaction-time plugin simulation", () => {
test("data-only mode works", async () => {
const { expectFinished, getData } = await simulateTimeline([
{
type: serialReactionTimeMouse,
grid: [[1, 1, 1, 1]],
target: [0, 0],
},
]);
await expectFinished();
const data = getData().values()[0];
expect(data.correct).toBe(data.response[1] == data.target[1]);
expect(data.rt).toBeGreaterThan(0);
});
test("visual mode works", async () => {
const { expectFinished, expectRunning, getData } = await simulateTimeline(
[
{
type: serialReactionTimeMouse,
grid: [[1, 1, 1, 1]],
target: [0, 0],
},
],
"visual"
);
await expectRunning();
jest.runAllTimers();
await expectFinished();
const data = getData().values()[0];
expect(data.correct).toBe(data.response[1] == data.target[1]);
expect(data.rt).toBeGreaterThan(0);
});
});