mirror of https://github.com/01-edu/public.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
56 lines
1.6 KiB
56 lines
1.6 KiB
2 years ago
|
export const tests = []
|
||
|
|
||
|
export const setup = async ({ page }) => ({
|
||
|
getNotes: async () =>
|
||
|
await page.$$eval('.note', (nodes) => {
|
||
|
return nodes.map((note) => note.textContent)
|
||
|
}),
|
||
|
})
|
||
|
|
||
|
const characters = `didyouhandlethekeydowneventcorrectly`
|
||
|
|
||
|
tests.push(async ({ page, eq, ctx }) => {
|
||
|
// check that a note is created and matches the right letter when a key is pressed
|
||
|
for (const [i, character] of characters.split('').entries()) {
|
||
|
await page.keyboard.down(character)
|
||
|
const typed = characters.slice(0, i + 1).split('')
|
||
|
eq(await ctx.getNotes(), typed)
|
||
|
}
|
||
|
})
|
||
|
|
||
|
tests.push(async ({ page, eq, ctx }) => {
|
||
|
// check that the last note is removed when Backspace key is pressed
|
||
|
let step = 1
|
||
|
while (step < 10) {
|
||
|
await page.keyboard.down('Backspace')
|
||
|
const typed = characters.slice(0, characters.length - step).split('')
|
||
|
eq(await ctx.getNotes(), typed)
|
||
|
step++
|
||
|
}
|
||
|
})
|
||
|
|
||
|
tests.push(async ({ page, eq, ctx }) => {
|
||
|
// check that all the notes are cleared when Escape key is pressed
|
||
|
await page.keyboard.down('Escape')
|
||
|
const cleared = (await ctx.getNotes()).length === 0
|
||
|
eq(await cleared, true)
|
||
|
})
|
||
|
|
||
|
tests.push(async ({ page, eq }) => {
|
||
|
// check that notes have different background colors
|
||
|
const test = 'abcdefghijklmnopqrstuvwxyz'
|
||
|
let step = 0
|
||
|
while (step < test.length) {
|
||
|
await page.keyboard.down(test[step])
|
||
|
step++
|
||
|
}
|
||
|
|
||
|
const getNotesBg = await page.$$eval('.note', (nodes) => {
|
||
|
return nodes.map((note) => note.style.backgroundColor)
|
||
|
})
|
||
|
|
||
|
const colors = [...new Set(getNotesBg)]
|
||
|
const allDifferent = colors.length === test.length
|
||
|
eq(allDifferent, true)
|
||
|
})
|