Pinafore-Web-Client-Frontend/tests/spec/103-compose.js

41 lines
1.4 KiB
JavaScript
Raw Normal View History

import { loginAsFoobar } from '../roles'
2018-03-10 07:31:26 +01:00
import {
2018-03-30 10:06:17 +02:00
composeInput, getNthComposeReplyButton, getNthComposeReplyInput, getNthReplyButton, getNthStatus, getUrl,
homeNavButton, notificationsNavButton,
2018-03-10 07:31:26 +01:00
postStatusButton
} from '../utils'
fixture`103-compose.js`
.page`http://localhost:4002`
test('statuses show up in home timeline', async t => {
await loginAsFoobar(t)
await t
.typeText(composeInput, 'hello world', { paste: true })
2018-03-10 07:31:26 +01:00
.click(postStatusButton)
.expect(getNthStatus(1).innerText).contains('hello world')
2018-03-10 07:31:26 +01:00
.click(notificationsNavButton)
.expect(getUrl()).contains('/notifications')
.click(homeNavButton)
.expect(getUrl()).eql('http://localhost:4002/')
.expect(getNthStatus(1).innerText).contains('hello world')
2018-03-10 07:31:26 +01:00
.navigateTo('/')
.expect(getNthStatus(1).innerText).contains('hello world')
2018-03-10 07:31:26 +01:00
})
test('statuses in threads show up in right order', async t => {
await loginAsFoobar(t)
await t
2018-03-10 07:31:26 +01:00
.navigateTo('/accounts/5')
.click(getNthStatus(3))
2018-03-10 07:31:26 +01:00
.expect(getUrl()).contains('/statuses')
.click(getNthReplyButton(4))
.typeText(getNthComposeReplyInput(4), 'my reply!', { paste: true })
.click(getNthComposeReplyButton(4))
.expect(getNthComposeReplyInput(4).exists).notOk()
.expect(getNthStatus(6).innerText).contains('@baz my reply!')
2018-03-10 07:31:26 +01:00
.navigateTo('/accounts/5')
.click(getNthStatus(3))
.expect(getNthStatus(6).innerText).contains('@baz my reply!')
2018-03-10 07:31:26 +01:00
})