Pinafore-Web-Client-Frontend/tests/spec/009-threads.js

87 lines
2.7 KiB
JavaScript
Raw Permalink Normal View History

2018-02-21 06:08:26 +01:00
import { Selector as $ } from 'testcafe'
2018-03-09 03:08:14 +01:00
import {
2018-11-22 07:08:37 +01:00
getNthStatus, getUrl, validateTimeline, getFirstVisibleStatus,
goBack, forceOffline, forceOnline, searchNavButton, searchInput, getNthSearchResult, scrollToStatus
2018-03-09 03:08:14 +01:00
} from '../utils'
import { loginAsFoobar } from '../roles'
2018-03-09 03:08:14 +01:00
import { bazThreadRelativeTo2, bazThreadRelativeTo2b, bazThreadRelativeTo2B2, quuxThread } from '../fixtures'
2018-02-21 06:08:26 +01:00
2018-03-07 06:32:51 +01:00
fixture`009-threads.js`
2018-02-21 06:08:26 +01:00
.page`http://localhost:4002`
2018-03-09 03:09:11 +01:00
2018-02-21 06:08:26 +01:00
test('Shows a thread', async t => {
await loginAsFoobar(t)
await t
2018-02-21 06:08:26 +01:00
.click($('a').withText('quux'))
await scrollToStatus(t, 27)
2018-02-21 06:08:26 +01:00
await t
.hover(getNthStatus(27))
.click(getNthStatus(27))
2018-03-06 07:36:54 +01:00
.expect(getUrl()).contains('/statuses/')
2018-02-21 06:08:26 +01:00
await validateTimeline(t, quuxThread)
await t.expect(getNthStatus(25).getAttribute('aria-setsize')).eql('25')
2018-02-21 06:08:26 +01:00
})
test('Scrolls to proper point in thread', async t => {
await loginAsFoobar(t)
await t
2018-02-21 06:08:26 +01:00
.click($('a').withText('quux'))
.hover(getNthStatus(1))
.hover(getNthStatus(3))
.hover(getNthStatus(5))
.hover(getNthStatus(7))
.hover(getNthStatus(9))
.hover(getNthStatus(11))
.click(getNthStatus(11))
2018-03-06 07:36:54 +01:00
.expect(getUrl()).contains('/statuses/')
.expect(getNthStatus(17).innerText).contains('unlisted thread 17')
.expect(Math.round(getNthStatus(17).boundingClientRect.top))
.eql(Math.round($('.main-content').boundingClientRect.top))
2018-02-21 06:30:16 +01:00
})
2018-03-09 03:08:14 +01:00
2018-03-09 03:09:35 +01:00
async function navigateToBazAccount (t) {
2018-03-09 03:08:14 +01:00
await t.click(searchNavButton)
.expect(getUrl()).contains('/search')
.typeText(searchInput, 'baz', { paste: true })
2018-03-09 03:08:14 +01:00
.pressKey('enter')
.click(getNthSearchResult(1))
.expect(getUrl()).contains('/accounts/5')
}
2018-03-09 03:09:35 +01:00
async function validateForkedThread (t) {
await t.hover(getNthStatus(2))
.click(getNthStatus(3))
2018-03-09 03:08:14 +01:00
.expect(getUrl()).contains('/statuses')
await validateTimeline(t, bazThreadRelativeTo2B2)
await goBack()
await t.hover(getNthStatus(4))
.hover(getNthStatus(6))
.hover(getNthStatus(8))
.hover(getNthStatus(10))
.click(getNthStatus(10))
2018-03-09 03:08:14 +01:00
.expect(getUrl()).contains('/statuses')
await validateTimeline(t, bazThreadRelativeTo2b)
await goBack()
await t.hover(getNthStatus(12))
.click(getNthStatus(12))
2018-03-09 03:08:14 +01:00
.expect(getUrl()).contains('/statuses')
await validateTimeline(t, bazThreadRelativeTo2)
}
test('Forked threads look correct online and offline', async t => {
await loginAsFoobar(t)
await t
2018-03-09 03:08:14 +01:00
.hover(getFirstVisibleStatus())
await navigateToBazAccount(t)
await validateForkedThread(t)
2018-03-09 03:37:32 +01:00
await t.navigateTo('/') // clears in-memory cache while still preserving IDB cache
2018-03-09 03:08:14 +01:00
.hover(getFirstVisibleStatus())
await navigateToBazAccount(t)
await forceOffline()
await validateForkedThread(t)
await forceOnline()
2018-03-09 03:09:35 +01:00
})