pinafore/tests/spec/017-compose-reply.js

145 lines
5.9 KiB
JavaScript
Raw Normal View History

2018-03-09 16:45:12 +00:00
import {
2018-03-30 08:06:17 +00:00
composeInput,
2018-04-08 20:42:31 +00:00
getNthComposeReplyInput, getNthPostPrivacyButton, getNthPostPrivacyOptionInDialog, getNthReplyButton,
getNthReplyContentWarningButton,
getNthReplyContentWarningInput, getNthReplyPostPrivacyButton,
getNthStatus, getNthStatusRelativeDate, getUrl, homeNavButton, notificationsNavButton, scrollToStatus
2018-03-09 16:45:12 +00:00
} from '../utils'
import { loginAsFoobar } from '../roles'
import { homeTimeline } from '../fixtures'
2018-03-09 16:45:12 +00:00
fixture`017-compose-reply.js`
.page`http://localhost:4002`
test('account handle populated correctly for replies', async t => {
await loginAsFoobar(t)
await t
.click(getNthReplyButton(1))
.expect(getNthComposeReplyInput(1).value).eql('@quux ')
.typeText(getNthComposeReplyInput(1), 'hello quux', { paste: true })
.expect(getNthComposeReplyInput(1).value).eql('@quux hello quux')
2018-03-30 08:06:17 +00:00
.click(notificationsNavButton)
.expect(getUrl()).contains('/notifications')
.click(homeNavButton)
.expect(getUrl()).notContains('/notifications')
.expect(getNthComposeReplyInput(1).value).eql('@quux hello quux')
2018-03-09 16:45:12 +00:00
.expect(composeInput.value).eql('')
.hover(getNthStatus(3))
.hover(getNthStatus(5))
.click(getNthReplyButton(5))
.expect(getNthComposeReplyInput(5).value).eql('')
2018-03-09 16:45:12 +00:00
})
2018-03-10 06:31:26 +00:00
test('replying to posts with mentions', async t => {
await loginAsFoobar(t)
await t
.click(getNthReplyButton(2))
.expect(getNthComposeReplyInput(2).value).eql('@admin ')
2018-03-09 16:45:12 +00:00
.navigateTo('/accounts/4')
.click(getNthReplyButton(1))
.expect(getNthComposeReplyInput(1).value).eql('@ExternalLinks @admin @quux ')
2018-03-09 16:45:12 +00:00
})
2018-03-30 17:04:35 +00:00
test('replies have same privacy as replied-to status by default', async t => {
await loginAsFoobar(t)
const unlistedIdx = homeTimeline.findIndex(_ => _.content === 'notification of unlisted message')
const privateIdx = homeTimeline.findIndex(_ => _.content === 'notification of followers-only message')
const publicIdx = homeTimeline.findIndex(_ => _.spoiler === 'kitten CW')
await t.hover(getNthStatus(1))
await scrollToStatus(t, 1 + unlistedIdx)
await t
.click(getNthReplyButton(1 + unlistedIdx))
.expect(getNthPostPrivacyButton(1 + unlistedIdx).getAttribute('aria-label')).eql(
'Adjust privacy (currently Unlisted)'
)
.click(getNthReplyButton(1 + unlistedIdx))
await scrollToStatus(t, 1 + privateIdx)
await t
.click(getNthReplyButton(1 + privateIdx))
.expect(getNthPostPrivacyButton(1 + privateIdx).getAttribute('aria-label')).eql(
'Adjust privacy (currently Followers-only)'
)
.click(getNthReplyButton(1 + privateIdx))
await scrollToStatus(t, 1 + publicIdx)
await t
.click(getNthReplyButton(1 + publicIdx))
.expect(getNthPostPrivacyButton(1 + publicIdx).getAttribute('aria-label')).eql(
'Adjust privacy (currently Public)'
)
.click(getNthReplyButton(1 + publicIdx))
2018-03-30 17:04:35 +00:00
})
2018-04-08 20:42:31 +00:00
test('replies have same CW as replied-to status', async t => {
await loginAsFoobar(t)
2019-08-03 20:49:37 +00:00
const kittenIdx = homeTimeline.findIndex(_ => _.spoiler === 'kitten CW')
await t.hover(getNthStatus(1))
await scrollToStatus(t, 1 + kittenIdx)
await t.click(getNthReplyButton(1 + kittenIdx))
.expect(getNthReplyContentWarningInput(1 + kittenIdx).value).eql('kitten CW')
.click(getNthStatusRelativeDate(1 + kittenIdx))
.expect(getUrl()).contains('/statuses')
.click(getNthReplyButton(1))
.expect(getNthReplyContentWarningInput(1).value).eql('kitten CW')
2018-04-08 20:42:31 +00:00
})
test('replies save deletions of CW', async t => {
await loginAsFoobar(t)
2019-08-03 20:49:37 +00:00
const kittenIdx = homeTimeline.findIndex(_ => _.spoiler === 'kitten CW')
await scrollToStatus(t, 1 + kittenIdx)
await t.click(getNthReplyButton(1 + kittenIdx))
.expect(getNthReplyContentWarningInput(1 + kittenIdx).value).eql('kitten CW')
.click(getNthReplyContentWarningButton(1 + kittenIdx))
.expect(getNthReplyContentWarningInput(1 + kittenIdx).exists).notOk()
.click(getNthStatusRelativeDate(1 + kittenIdx))
.expect(getUrl()).contains('/statuses')
.click(getNthReplyButton(1))
.expect(getNthReplyContentWarningInput(1).exists).notOk()
2018-04-08 20:42:31 +00:00
})
test('replies save changes to CW', async t => {
await loginAsFoobar(t)
2019-08-03 20:49:37 +00:00
const kittenIdx = homeTimeline.findIndex(_ => _.spoiler === 'kitten CW')
await scrollToStatus(t, 1 + kittenIdx)
await t.click(getNthReplyButton(1 + kittenIdx))
.expect(getNthReplyContentWarningInput(1 + kittenIdx).value).eql('kitten CW')
.typeText(getNthReplyContentWarningInput(1 + kittenIdx), ' yolo', { paste: true })
.expect(getNthReplyContentWarningInput(1 + kittenIdx).value).eql('kitten CW yolo')
.click(getNthStatusRelativeDate(1 + kittenIdx))
.expect(getUrl()).contains('/statuses')
.click(getNthReplyButton(1))
.expect(getNthReplyContentWarningInput(1).value).eql('kitten CW yolo')
2018-04-08 20:42:31 +00:00
})
test('replies save changes to post privacy', async t => {
await loginAsFoobar(t)
await t
2018-04-08 20:42:31 +00:00
.hover(getNthStatus(1))
.hover(getNthStatus(2))
.click(getNthReplyButton(2))
.expect(getNthPostPrivacyButton(2).getAttribute('aria-label')).eql('Adjust privacy (currently Unlisted)')
.click(getNthReplyPostPrivacyButton(2))
2018-04-08 20:42:31 +00:00
.click(getNthPostPrivacyOptionInDialog(1))
.expect(getNthPostPrivacyButton(2).getAttribute('aria-label')).eql('Adjust privacy (currently Public)')
.click(getNthStatusRelativeDate(2))
.expect(getUrl()).contains('/statuses')
.click(getNthReplyButton(1))
.expect(getNthPostPrivacyButton(1).getAttribute('aria-label')).eql('Adjust privacy (currently Public)')
})
test('replies are the same whatever thread they are in', async t => {
await loginAsFoobar(t)
await t
.hover(getNthStatus(1))
.hover(getNthStatus(2))
.click(getNthReplyButton(2))
.typeText(getNthComposeReplyInput(2), 'this is a reply', { paste: true })
.expect(getNthComposeReplyInput(2).value).eql('@admin this is a reply')
.click(getNthStatusRelativeDate(2))
.expect(getUrl()).contains('/statuses')
.click(getNthReplyButton(1))
.expect(getNthComposeReplyInput(1).value).eql('@admin this is a reply')
2018-04-08 20:42:31 +00:00
})