131 lines
4.1 KiB
JavaScript
131 lines
4.1 KiB
JavaScript
import { Selector, t } from "testcafe";
|
|
|
|
export default class Page {
|
|
constructor() {}
|
|
|
|
async getNthPhotoUid(type, nth) {
|
|
if (type === "all") {
|
|
const NthPhoto = await Selector("div.is-photo").nth(nth).getAttribute("data-uid");
|
|
return NthPhoto;
|
|
} else {
|
|
const NthPhoto = await Selector("div.type-" + type)
|
|
.nth(nth)
|
|
.getAttribute("data-uid");
|
|
return NthPhoto;
|
|
}
|
|
}
|
|
|
|
async getPhotoCount(type) {
|
|
if (type === "all") {
|
|
const PhotoCount = await Selector("div.is-photo", { timeout: 2000 }).count;
|
|
return PhotoCount;
|
|
} else {
|
|
const PhotoCount = await Selector("div.type-" + type, { timeout: 2000 }).count;
|
|
return PhotoCount;
|
|
}
|
|
}
|
|
|
|
async selectPhotoFromUID(uid) {
|
|
await t
|
|
.hover(Selector("div.is-photo").withAttribute("data-uid", uid))
|
|
.click(Selector(`.uid-${uid} .input-select`));
|
|
}
|
|
|
|
async toggleSelectNthPhoto(nPhoto, type) {
|
|
if (type === "all") {
|
|
await t
|
|
.hover(Selector(".is-photo", { timeout: 4000 }).nth(nPhoto))
|
|
.click(Selector(".is-photo .input-select").nth(nPhoto));
|
|
} else {
|
|
await t
|
|
.hover(Selector("div.type-" + type, { timeout: 4000 }).nth(nPhoto))
|
|
.click(Selector("div.type-" + type + " .input-select").nth(nPhoto));
|
|
}
|
|
}
|
|
|
|
async checkPhotoVisibility(uid, visible) {
|
|
if (visible) {
|
|
await t.expect(Selector("div.is-photo").withAttribute("data-uid", uid).exists).ok();
|
|
} else {
|
|
await t.expect(Selector("div.is-photo").withAttribute("data-uid", uid).exists).notOk();
|
|
}
|
|
}
|
|
|
|
async checkHoverActionAvailability(mode, uidOrNth, action, visible) {
|
|
if (mode === "uid") {
|
|
await t.hover(Selector("div.is-photo").withAttribute("data-uid", uidOrNth));
|
|
if (visible) {
|
|
await t.expect(Selector(`.uid-${uidOrNth} .input-` + action).visible).ok();
|
|
} else {
|
|
await t.expect(Selector(`.uid-${uidOrNth} .input-` + action).visible).notOk();
|
|
}
|
|
}
|
|
if (mode === "nth") {
|
|
await t.hover(Selector("div.is-photo").nth(uidOrNth));
|
|
if (visible) {
|
|
await t.expect(Selector(`div.is-photo .input-` + action).visible).ok();
|
|
} else {
|
|
await t.expect(Selector(`div.is-photo .input-` + action).visible).notOk();
|
|
}
|
|
}
|
|
}
|
|
|
|
async triggerHoverAction(mode, uidOrNth, action) {
|
|
if (mode === "uid") {
|
|
await t.hover(Selector("div.is-photo").withAttribute("data-uid", uidOrNth));
|
|
await t.click(Selector(`div.uid-${uidOrNth} .input-` + action));
|
|
}
|
|
if (mode === "nth") {
|
|
await t.hover(Selector("div.is-photo").nth(uidOrNth));
|
|
await t.click(Selector(`div.is-photo .input-` + action).nth(uidOrNth));
|
|
}
|
|
}
|
|
|
|
async checkHoverActionState(mode, uidOrNth, action, set) {
|
|
if (mode === "uid") {
|
|
await t.hover(Selector("div.is-photo").withAttribute("data-uid", uidOrNth));
|
|
if (set) {
|
|
await t.expect(Selector(`div.uid-${uidOrNth}`).hasClass("is-" + action)).ok();
|
|
} else {
|
|
await t.expect(Selector(`div.uid-${uidOrNth}`).hasClass("is-" + action)).notOk();
|
|
}
|
|
}
|
|
if (mode === "nth") {
|
|
await t.hover(Selector("div.is-photo").nth(uidOrNth));
|
|
if (set) {
|
|
await t
|
|
.expect(
|
|
Selector("div.is-photo")
|
|
.nth(uidOrNth)
|
|
.hasClass("is-" + action)
|
|
)
|
|
.ok();
|
|
} else {
|
|
await t
|
|
.expect(
|
|
Selector("div.is-photo")
|
|
.nth(uidOrNth)
|
|
.hasClass("is-" + action)
|
|
)
|
|
.notOk();
|
|
}
|
|
}
|
|
}
|
|
|
|
async triggerListViewActions(mode, uidOrnth, action) {
|
|
if (mode === "nth") {
|
|
await t.click(Selector(`td button.input-` + action).nth(uidOrnth));
|
|
} else if (mode === "uid") {
|
|
await t.click(Selector(`td button.input-` + action).withAttribute("data-uid", uidOrnth));
|
|
}
|
|
}
|
|
|
|
async checkListViewActionAvailability(action, disabled) {
|
|
if (disabled) {
|
|
await t.expect(Selector(`td button.input-` + action).hasAttribute("disabled")).ok();
|
|
} else {
|
|
await t.expect(Selector(`td button.input-` + action).hasAttribute("disabled")).notOk();
|
|
}
|
|
}
|
|
}
|