1
0
mirror of https://github.com/nolanlawson/pinafore synced 2025-01-23 18:35:27 +01:00
Pinafore-Web-Client-Frontend/tests/spec/105-deletes.js

68 lines
2.9 KiB
JavaScript
Raw Normal View History

import { loginAsFoobar } from '../roles'
import {
clickToNotificationsAndBackHome, forceOffline, forceOnline, getNthStatus, getUrl, homeNavButton,
2018-03-21 01:41:39 +01:00
notificationsNavButton
} from '../utils'
2018-03-16 18:06:02 +01:00
import { deleteAs, postAs, postReplyAs } from '../serverActions'
2018-03-11 01:21:10 +01:00
fixture`105-deletes.js`
.page`http://localhost:4002`
test('deleted statuses are removed from the timeline', async t => {
2019-08-03 22:49:37 +02:00
const timeout = 20000
await loginAsFoobar(t)
await t
.hover(getNthStatus(1))
2019-08-03 22:49:37 +02:00
const status = await postAs('admin', "I'm gonna delete this")
await t.expect(getNthStatus(1).innerText).contains("I'm gonna delete this", { timeout })
2018-03-16 18:06:02 +01:00
await deleteAs('admin', status.id)
await t.expect(getNthStatus(1).innerText).notContains("I'm gonna delete this", { timeout })
await clickToNotificationsAndBackHome(t)
await t.expect(getNthStatus(1).innerText).notContains("I'm gonna delete this", { timeout })
await t.navigateTo('/notifications')
await forceOffline()
await t.click(homeNavButton)
await t.expect(getNthStatus(1).innerText).notContains("I'm gonna delete this", { timeout })
await forceOnline()
await t
.navigateTo('/')
.expect(getNthStatus(1).innerText).notContains("I'm gonna delete this", { timeout })
})
test('deleted statuses are removed from threads', async t => {
2019-08-03 22:49:37 +02:00
const timeout = 20000
await loginAsFoobar(t)
await t
.hover(getNthStatus(1))
2019-08-03 22:49:37 +02:00
const status = await postAs('admin', "I won't delete this")
const reply = await postReplyAs('admin', 'But I will delete this', status.id)
await t.expect(getNthStatus(1).innerText).contains('But I will delete this', { timeout })
.expect(getNthStatus(2).innerText).contains("I won't delete this", { timeout })
.click(getNthStatus(2))
.expect(getUrl()).contains('/statuses')
.expect(getNthStatus(1).innerText).contains("I won't delete this", { timeout })
.expect(getNthStatus(2).innerText).contains('But I will delete this', { timeout })
2018-03-16 18:06:02 +01:00
await deleteAs('admin', reply.id)
await t.expect(getNthStatus(2).exists).notOk()
.expect(getNthStatus(1).innerText).contains("I won't delete this", { timeout })
await t.navigateTo('/')
await forceOffline()
await t.click(getNthStatus(1))
.expect(getUrl()).contains('/statuses')
.expect(getNthStatus(2).exists).notOk()
.expect(getNthStatus(1).innerText).contains("I won't delete this", { timeout })
await forceOnline()
2018-03-11 01:21:10 +01:00
})
test('deleted statuses result in deleted notifications', async t => {
2019-08-03 22:49:37 +02:00
const timeout = 20000
await loginAsFoobar(t)
await t
.hover(getNthStatus(1))
.expect(notificationsNavButton.getAttribute('aria-label')).eql('Notifications')
2019-08-03 22:49:37 +02:00
const status = await postAs('admin', "@foobar yo yo foobar what's up")
await t.expect(notificationsNavButton.getAttribute('aria-label')).eql('Notifications (1 notification)', { timeout })
2018-03-16 18:06:02 +01:00
await deleteAs('admin', status.id)
await t.expect(notificationsNavButton.getAttribute('aria-label')).eql('Notifications', { timeout })
})