85b75900c1
* feat: add ability to set focal points for media fixes #739 * fix tests * actually fix tests * really really fix tests * really really really fix tests pinkie swear
100 lines
3.8 KiB
JavaScript
100 lines
3.8 KiB
JavaScript
import {
|
|
composeButton,
|
|
composeInput,
|
|
getNthDeleteMediaButton,
|
|
getNthMedia,
|
|
getNthMediaAltInput,
|
|
getNthMediaListItem,
|
|
getNthStatusAndImage,
|
|
getUrl,
|
|
homeNavButton,
|
|
mediaButton,
|
|
notificationsNavButton,
|
|
uploadKittenImage
|
|
} from '../utils'
|
|
import { loginAsFoobar } from '../roles'
|
|
|
|
fixture`109-compose-media.js`
|
|
.page`http://localhost:4002`
|
|
|
|
async function uploadTwoKittens (t) {
|
|
await (uploadKittenImage(1)())
|
|
await t.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
|
|
await (uploadKittenImage(2)())
|
|
await t.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
|
|
.expect(getNthMediaListItem(2).getAttribute('aria-label')).eql('kitten2.jpg')
|
|
}
|
|
|
|
test('uploads alts for media', async t => {
|
|
await loginAsFoobar(t)
|
|
await t
|
|
.expect(mediaButton.hasAttribute('disabled')).notOk()
|
|
await uploadTwoKittens(t)
|
|
await t.typeText(getNthMediaAltInput(2), 'kitten 2')
|
|
.typeText(getNthMediaAltInput(1), 'kitten 1')
|
|
.click(composeButton)
|
|
.expect(getNthStatusAndImage(1, 1).getAttribute('alt')).eql('kitten 1')
|
|
.expect(getNthStatusAndImage(1, 1).getAttribute('title')).eql('kitten 1')
|
|
.expect(getNthStatusAndImage(1, 2).getAttribute('alt')).eql('kitten 2')
|
|
.expect(getNthStatusAndImage(1, 2).getAttribute('title')).eql('kitten 2')
|
|
})
|
|
|
|
test('uploads alts when deleting and re-uploading media', async t => {
|
|
await loginAsFoobar(t)
|
|
await t
|
|
.expect(mediaButton.hasAttribute('disabled')).notOk()
|
|
await (uploadKittenImage(1)())
|
|
await t.typeText(getNthMediaAltInput(1), 'this will be deleted')
|
|
.click(getNthDeleteMediaButton(1))
|
|
.expect(getNthMedia(1).exists).notOk()
|
|
await (uploadKittenImage(2)())
|
|
await t.expect(getNthMediaAltInput(1).value).eql('')
|
|
.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten2.jpg')
|
|
.typeText(getNthMediaAltInput(1), 'this will not be deleted')
|
|
.click(composeButton)
|
|
.expect(getNthStatusAndImage(1, 1).getAttribute('alt')).eql('this will not be deleted')
|
|
})
|
|
|
|
test('uploads alts mixed with no-alts', async t => {
|
|
await loginAsFoobar(t)
|
|
await t
|
|
.expect(mediaButton.hasAttribute('disabled')).notOk()
|
|
await uploadTwoKittens(t)
|
|
await t.typeText(getNthMediaAltInput(2), 'kitten numero dos')
|
|
.click(composeButton)
|
|
.expect(getNthStatusAndImage(1, 1).getAttribute('alt')).eql('')
|
|
.expect(getNthStatusAndImage(1, 2).getAttribute('alt')).eql('kitten numero dos')
|
|
})
|
|
|
|
test('saves alts to local storage', async t => {
|
|
await loginAsFoobar(t)
|
|
await t
|
|
.expect(mediaButton.hasAttribute('disabled')).notOk()
|
|
await uploadTwoKittens(t)
|
|
await t.typeText(getNthMediaAltInput(1), 'kitten numero uno')
|
|
.typeText(getNthMediaAltInput(2), 'kitten numero dos')
|
|
.click(notificationsNavButton)
|
|
.expect(getUrl()).contains('/notifications')
|
|
.click(homeNavButton)
|
|
.expect(getUrl()).eql('http://localhost:4002/')
|
|
.expect(getNthMediaListItem(1).getAttribute('aria-label')).eql('kitten1.jpg')
|
|
.expect(getNthMediaListItem(2).getAttribute('aria-label')).eql('kitten2.jpg')
|
|
.expect(getNthMediaAltInput(1).value).eql('kitten numero uno')
|
|
.expect(getNthMediaAltInput(2).value).eql('kitten numero dos')
|
|
.click(composeButton)
|
|
.expect(getNthStatusAndImage(1, 1).getAttribute('alt')).eql('kitten numero uno')
|
|
.expect(getNthStatusAndImage(1, 2).getAttribute('alt')).eql('kitten numero dos')
|
|
})
|
|
|
|
test('can post a status with empty content if there is media', async t => {
|
|
await loginAsFoobar(t)
|
|
await t
|
|
.expect(mediaButton.hasAttribute('disabled')).notOk()
|
|
.typeText(composeInput, 'this is a toot')
|
|
await (uploadKittenImage(1)())
|
|
await t
|
|
.typeText(getNthMediaAltInput(1), 'just an image!')
|
|
await t.click(composeButton)
|
|
.expect(getNthStatusAndImage(1, 1).getAttribute('alt')).eql('just an image!')
|
|
})
|