semaphore/tests/spec/013-compose-media.js

129 lines
5.2 KiB
JavaScript
Raw Normal View History

import {
composeInput,
getNthDeleteMediaButton,
getNthMedia,
getNthMediaAltInput,
getNthMediaListItem,
homeNavButton,
mediaButton,
settingsNavButton,
sleep,
uploadKittenImage
} from '../utils'
import { loginAsFoobar } from '../roles'
2018-03-03 05:55:04 +00:00
2018-03-07 05:32:51 +00:00
fixture`013-compose-media.js`
2018-03-03 05:55:04 +00:00
.page`http://localhost:4002`
test('inserts media', async t => {
await loginAsFoobar(t)
await t
2018-03-03 05:55:04 +00:00
.expect(mediaButton.hasAttribute('disabled')).notOk()
await (uploadKittenImage(1)())
await t.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
2018-03-03 05:55:04 +00:00
await (uploadKittenImage(2)())
await t.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
.expect(getNthMediaListItem(2).getAttribute('aria-label')).eql('kitten2.jpg')
2018-03-03 05:55:04 +00:00
.expect(mediaButton.hasAttribute('disabled')).notOk()
await (uploadKittenImage(3)())
await t.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
.expect(getNthMediaListItem(2).getAttribute('aria-label')).eql('kitten2.jpg')
.expect(getNthMediaListItem(3).getAttribute('aria-label')).eql('kitten3.jpg')
2018-03-03 05:55:04 +00:00
.expect(mediaButton.hasAttribute('disabled')).notOk()
await (uploadKittenImage(4)())
await t.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
.expect(getNthMediaListItem(2).getAttribute('aria-label')).eql('kitten2.jpg')
.expect(getNthMediaListItem(3).getAttribute('aria-label')).eql('kitten3.jpg')
.expect(getNthMediaListItem(4).getAttribute('aria-label')).eql('kitten4.jpg')
2018-03-03 05:55:04 +00:00
.expect(mediaButton.getAttribute('disabled')).eql('')
2018-03-03 18:27:14 +00:00
.click(getNthDeleteMediaButton(4))
.click(getNthDeleteMediaButton(3))
.click(getNthDeleteMediaButton(2))
.click(getNthDeleteMediaButton(1))
2018-03-11 19:10:59 +00:00
.expect(mediaButton.hasAttribute('disabled')).notOk()
2018-03-03 05:55:04 +00:00
})
test('removes media', async t => {
await loginAsFoobar(t)
await t
2018-03-14 03:00:35 +00:00
.expect(mediaButton.exists).ok()
2018-03-03 05:55:04 +00:00
await (uploadKittenImage(1)())
await t.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
2018-03-03 05:55:04 +00:00
await (uploadKittenImage(2)())
await t.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
.expect(getNthMediaListItem(2).getAttribute('aria-label')).eql('kitten2.jpg')
2018-03-03 18:27:14 +00:00
.click(getNthDeleteMediaButton(2))
2018-03-03 05:55:04 +00:00
.expect(getNthMedia(2).exists).notOk()
.expect(getNthMedia(1).exists).ok()
2018-03-03 19:26:10 +00:00
.click(getNthDeleteMediaButton(1))
.expect(getNthMedia(2).exists).notOk()
})
test('does not add URLs as media is added/removed', async t => {
await loginAsFoobar(t)
await t
.typeText(composeInput, 'this is a toot')
2018-03-14 03:00:35 +00:00
.expect(mediaButton.exists).ok()
2018-03-03 19:26:10 +00:00
await (uploadKittenImage(1)())
await t.expect(composeInput.value).eql('this is a toot')
2018-03-03 19:26:10 +00:00
await (uploadKittenImage(1)())
await t.expect(composeInput.value).eql('this is a toot')
2018-03-03 19:26:10 +00:00
.click(getNthDeleteMediaButton(1))
.expect(composeInput.value).eql('this is a toot')
2018-03-03 19:26:10 +00:00
.click(getNthDeleteMediaButton(1))
.expect(composeInput.value).eql('this is a toot')
})
test('keeps media descriptions as media is removed', async t => {
await loginAsFoobar(t)
await t
.expect(mediaButton.exists).ok()
await (uploadKittenImage(1)())
await t
.typeText(getNthMediaAltInput(1), 'kitten numero uno')
await (uploadKittenImage(2)())
await t
.typeText(getNthMediaAltInput(2), 'kitten numero dos')
.expect(getNthMediaAltInput(1).value).eql('kitten numero uno')
.expect(getNthMediaAltInput(2).value).eql('kitten numero dos')
.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
.expect(getNthMediaListItem(2).getAttribute('aria-label')).eql('kitten2.jpg')
.click(getNthDeleteMediaButton(1))
.expect(getNthMediaAltInput(1).value).eql('kitten numero dos')
.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten2.jpg')
})
test('keeps media in local storage', async t => {
await loginAsFoobar(t)
await t
.expect(mediaButton.exists).ok()
await (uploadKittenImage(1)())
await t
.typeText(getNthMediaAltInput(1), 'kitten numero uno')
await (uploadKittenImage(2)())
await t
.typeText(getNthMediaAltInput(2), 'kitten numero dos')
await t
.typeText(composeInput, 'hello hello')
.expect(composeInput.value).eql('hello hello')
.expect(getNthMediaAltInput(1).value).eql('kitten numero uno')
.expect(getNthMediaAltInput(2).value).eql('kitten numero dos')
.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
.expect(getNthMediaListItem(2).getAttribute('aria-label')).eql('kitten2.jpg')
await sleep(1)
await t
.click(settingsNavButton)
.click(homeNavButton)
.expect(composeInput.value).eql('hello hello')
.expect(getNthMediaAltInput(1).value).eql('kitten numero uno')
.expect(getNthMediaAltInput(2).value).eql('kitten numero dos')
.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
.expect(getNthMediaListItem(2).getAttribute('aria-label')).eql('kitten2.jpg')
.navigateTo('/')
.expect(composeInput.value).eql('hello hello')
.expect(getNthMediaAltInput(1).value).eql('kitten numero uno')
.expect(getNthMediaAltInput(2).value).eql('kitten numero dos')
.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
.expect(getNthMediaListItem(2).getAttribute('aria-label')).eql('kitten2.jpg')
2018-03-03 05:55:04 +00:00
})