+ const tmpToken = await servers[0].users.generateUserAndToken(username)
+ await servers[0].videos.upload({ token: tmpToken, attributes: { name: 'super video' } })
+
+ await waitJobs(servers)
+
+ const account = await servers[1].accounts.get({ accountName: username + '@' + servers[0].host })
+ await servers[1].abuses.report({ accountId: account.id, reason: 'super reason' })
+
+ await waitJobs(servers)
+ await checkNewAccountAbuseForModerators({ ...baseParams, displayName: username, checkType: 'presence' })
+ })
+ })
+
+ describe('Abuse state change notification', function () {
+ let baseParams: CheckerBaseParams
+ let abuseId: number
+
+ before(async function () {
+ baseParams = {
+ server: servers[0],
+ emails,
+ socketNotifications: userNotifications,
+ token: userAccessToken
+ }
+
+ const name = 'abuse ' + buildUUID()
+ const video = await servers[0].videos.upload({ token: userAccessToken, attributes: { name } })
+
+ const body = await servers[0].abuses.report({ token: userAccessToken, videoId: video.id, reason: 'super reason' })
+ abuseId = body.abuse.id
+ })
+
+ it('Should send a notification to reporter if the abuse has been accepted', async function () {
+ this.timeout(10000)
+
+ await servers[0].abuses.update({ abuseId, body: { state: AbuseState.ACCEPTED } })
+ await waitJobs(servers)
+
+ await checkAbuseStateChange({ ...baseParams, abuseId, state: AbuseState.ACCEPTED, checkType: 'presence' })
+ })
+
+ it('Should send a notification to reporter if the abuse has been rejected', async function () {
+ this.timeout(10000)
+
+ await servers[0].abuses.update({ abuseId, body: { state: AbuseState.REJECTED } })
+ await waitJobs(servers)
+
+ await checkAbuseStateChange({ ...baseParams, abuseId, state: AbuseState.REJECTED, checkType: 'presence' })
+ })
+ })
+
+ describe('New abuse message notification', function () {
+ let baseParamsUser: CheckerBaseParams
+ let baseParamsAdmin: CheckerBaseParams
+ let abuseId: number
+ let abuseId2: number
+
+ before(async function () {
+ baseParamsUser = {
+ server: servers[0],
+ emails,
+ socketNotifications: userNotifications,
+ token: userAccessToken
+ }
+
+ baseParamsAdmin = {
+ server: servers[0],
+ emails,
+ socketNotifications: adminNotifications,
+ token: servers[0].accessToken
+ }
+
+ const name = 'abuse ' + buildUUID()
+ const video = await servers[0].videos.upload({ token: userAccessToken, attributes: { name } })
+
+ {
+ const body = await servers[0].abuses.report({ token: userAccessToken, videoId: video.id, reason: 'super reason' })
+ abuseId = body.abuse.id
+ }
+
+ {
+ const body = await servers[0].abuses.report({ token: userAccessToken, videoId: video.id, reason: 'super reason 2' })
+ abuseId2 = body.abuse.id
+ }
+ })
+
+ it('Should send a notification to reporter on new message', async function () {
+ this.timeout(10000)
+
+ const message = 'my super message to users'
+ await servers[0].abuses.addMessage({ abuseId, message })
+ await waitJobs(servers)
+
+ await checkNewAbuseMessage({ ...baseParamsUser, abuseId, message, toEmail: 'user_1@example.com', checkType: 'presence' })
+ })
+
+ it('Should not send a notification to the admin if sent by the admin', async function () {
+ this.timeout(10000)
+
+ const message = 'my super message that should not be sent to the admin'
+ await servers[0].abuses.addMessage({ abuseId, message })
+ await waitJobs(servers)
+
+ const toEmail = 'admin' + servers[0].internalServerNumber + '@example.com'
+ await checkNewAbuseMessage({ ...baseParamsAdmin, abuseId, message, toEmail, checkType: 'absence' })
+ })
+
+ it('Should send a notification to moderators', async function () {
+ this.timeout(10000)