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