d0800f7661
* client: remove unused file * refactor(client/my-actor-avatar): size from input Read size from component input instead of scss, to make it possible to use smaller avatar images when implemented. * implement avatar miniatures close #4560 * fix(test): max file size * fix(search-index): normalize res acc to avatarMini * refactor avatars to an array * client/search: resize channel avatar to 120 * refactor(client/videos): remove unused function * client(actor-avatar): set default size * fix tests and avatars full result When findOne is used only an array containting one avatar is returned. * update migration version and version notations * server/search: harmonize normalizing * Cleanup avatar miniature PR Co-authored-by: Chocobozzz <me@florianbigard.com>
209 lines
6.8 KiB
TypeScript
209 lines
6.8 KiB
TypeScript
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
|
|
|
|
import 'mocha'
|
|
import * as chai from 'chai'
|
|
import {
|
|
CheckerBaseParams,
|
|
checkNewVideoFromSubscription,
|
|
getAllNotificationsSettings,
|
|
MockSmtpServer,
|
|
prepareNotificationsTest
|
|
} from '@server/tests/shared'
|
|
import { UserNotification, UserNotificationSettingValue } from '@shared/models'
|
|
import { cleanupTests, PeerTubeServer, waitJobs } from '@shared/server-commands'
|
|
|
|
const expect = chai.expect
|
|
|
|
describe('Test notifications API', function () {
|
|
let server: PeerTubeServer
|
|
let userNotifications: UserNotification[] = []
|
|
let userToken: string
|
|
let emails: object[] = []
|
|
|
|
before(async function () {
|
|
this.timeout(120000)
|
|
|
|
const res = await prepareNotificationsTest(1)
|
|
emails = res.emails
|
|
userToken = res.userAccessToken
|
|
userNotifications = res.userNotifications
|
|
server = res.servers[0]
|
|
|
|
await server.subscriptions.add({ token: userToken, targetUri: 'root_channel@localhost:' + server.port })
|
|
|
|
for (let i = 0; i < 10; i++) {
|
|
await server.videos.randomUpload({ wait: false })
|
|
}
|
|
|
|
await waitJobs([ server ])
|
|
})
|
|
|
|
describe('Notification list & count', function () {
|
|
|
|
it('Should correctly list notifications', async function () {
|
|
const { data, total } = await server.notifications.list({ token: userToken, start: 0, count: 2 })
|
|
|
|
expect(data).to.have.lengthOf(2)
|
|
expect(total).to.equal(10)
|
|
})
|
|
})
|
|
|
|
describe('Mark as read', function () {
|
|
|
|
it('Should mark as read some notifications', async function () {
|
|
const { data } = await server.notifications.list({ token: userToken, start: 2, count: 3 })
|
|
const ids = data.map(n => n.id)
|
|
|
|
await server.notifications.markAsRead({ token: userToken, ids })
|
|
})
|
|
|
|
it('Should have the notifications marked as read', async function () {
|
|
const { data } = await server.notifications.list({ token: userToken, start: 0, count: 10 })
|
|
|
|
expect(data[0].read).to.be.false
|
|
expect(data[1].read).to.be.false
|
|
expect(data[2].read).to.be.true
|
|
expect(data[3].read).to.be.true
|
|
expect(data[4].read).to.be.true
|
|
expect(data[5].read).to.be.false
|
|
})
|
|
|
|
it('Should only list read notifications', async function () {
|
|
const { data } = await server.notifications.list({ token: userToken, start: 0, count: 10, unread: false })
|
|
|
|
for (const notification of data) {
|
|
expect(notification.read).to.be.true
|
|
}
|
|
})
|
|
|
|
it('Should only list unread notifications', async function () {
|
|
const { data } = await server.notifications.list({ token: userToken, start: 0, count: 10, unread: true })
|
|
|
|
for (const notification of data) {
|
|
expect(notification.read).to.be.false
|
|
}
|
|
})
|
|
|
|
it('Should mark as read all notifications', async function () {
|
|
await server.notifications.markAsReadAll({ token: userToken })
|
|
|
|
const body = await server.notifications.list({ token: userToken, start: 0, count: 10, unread: true })
|
|
|
|
expect(body.total).to.equal(0)
|
|
expect(body.data).to.have.lengthOf(0)
|
|
})
|
|
})
|
|
|
|
describe('Notification settings', function () {
|
|
let baseParams: CheckerBaseParams
|
|
|
|
before(() => {
|
|
baseParams = {
|
|
server: server,
|
|
emails,
|
|
socketNotifications: userNotifications,
|
|
token: userToken
|
|
}
|
|
})
|
|
|
|
it('Should not have notifications', async function () {
|
|
this.timeout(20000)
|
|
|
|
await server.notifications.updateMySettings({
|
|
token: userToken,
|
|
settings: { ...getAllNotificationsSettings(), newVideoFromSubscription: UserNotificationSettingValue.NONE }
|
|
})
|
|
|
|
{
|
|
const info = await server.users.getMyInfo({ token: userToken })
|
|
expect(info.notificationSettings.newVideoFromSubscription).to.equal(UserNotificationSettingValue.NONE)
|
|
}
|
|
|
|
const { name, shortUUID } = await server.videos.randomUpload()
|
|
|
|
const check = { web: true, mail: true }
|
|
await checkNewVideoFromSubscription({ ...baseParams, check, videoName: name, shortUUID, checkType: 'absence' })
|
|
})
|
|
|
|
it('Should only have web notifications', async function () {
|
|
this.timeout(20000)
|
|
|
|
await server.notifications.updateMySettings({
|
|
token: userToken,
|
|
settings: { ...getAllNotificationsSettings(), newVideoFromSubscription: UserNotificationSettingValue.WEB }
|
|
})
|
|
|
|
{
|
|
const info = await server.users.getMyInfo({ token: userToken })
|
|
expect(info.notificationSettings.newVideoFromSubscription).to.equal(UserNotificationSettingValue.WEB)
|
|
}
|
|
|
|
const { name, shortUUID } = await server.videos.randomUpload()
|
|
|
|
{
|
|
const check = { mail: true, web: false }
|
|
await checkNewVideoFromSubscription({ ...baseParams, check, videoName: name, shortUUID, checkType: 'absence' })
|
|
}
|
|
|
|
{
|
|
const check = { mail: false, web: true }
|
|
await checkNewVideoFromSubscription({ ...baseParams, check, videoName: name, shortUUID, checkType: 'presence' })
|
|
}
|
|
})
|
|
|
|
it('Should only have mail notifications', async function () {
|
|
this.timeout(20000)
|
|
|
|
await server.notifications.updateMySettings({
|
|
token: userToken,
|
|
settings: { ...getAllNotificationsSettings(), newVideoFromSubscription: UserNotificationSettingValue.EMAIL }
|
|
})
|
|
|
|
{
|
|
const info = await server.users.getMyInfo({ token: userToken })
|
|
expect(info.notificationSettings.newVideoFromSubscription).to.equal(UserNotificationSettingValue.EMAIL)
|
|
}
|
|
|
|
const { name, shortUUID } = await server.videos.randomUpload()
|
|
|
|
{
|
|
const check = { mail: false, web: true }
|
|
await checkNewVideoFromSubscription({ ...baseParams, check, videoName: name, shortUUID, checkType: 'absence' })
|
|
}
|
|
|
|
{
|
|
const check = { mail: true, web: false }
|
|
await checkNewVideoFromSubscription({ ...baseParams, check, videoName: name, shortUUID, checkType: 'presence' })
|
|
}
|
|
})
|
|
|
|
it('Should have email and web notifications', async function () {
|
|
this.timeout(20000)
|
|
|
|
await server.notifications.updateMySettings({
|
|
token: userToken,
|
|
settings: {
|
|
...getAllNotificationsSettings(),
|
|
newVideoFromSubscription: UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL
|
|
}
|
|
})
|
|
|
|
{
|
|
const info = await server.users.getMyInfo({ token: userToken })
|
|
expect(info.notificationSettings.newVideoFromSubscription).to.equal(
|
|
UserNotificationSettingValue.WEB | UserNotificationSettingValue.EMAIL
|
|
)
|
|
}
|
|
|
|
const { name, shortUUID } = await server.videos.randomUpload()
|
|
|
|
await checkNewVideoFromSubscription({ ...baseParams, videoName: name, shortUUID, checkType: 'presence' })
|
|
})
|
|
})
|
|
|
|
after(async function () {
|
|
MockSmtpServer.Instance.kill()
|
|
|
|
await cleanupTests([ server ])
|
|
})
|
|
})
|