+
+ it('Should send a notification to moderators on local comment abuse', async function () {
+ this.timeout(20000)
+
+ const name = 'video for abuse ' + buildUUID()
+ const video = await servers[0].videos.upload({ token: userAccessToken, attributes: { name } })
+ const comment = await servers[0].comments.createThread({
+ token: userAccessToken,
+ videoId: video.id,
+ text: 'comment abuse ' + buildUUID()
+ })
+
+ await waitJobs(servers)
+
+ await servers[0].abuses.report({ commentId: comment.id, reason: 'super reason' })
+
+ await waitJobs(servers)
+ await checkNewCommentAbuseForModerators(baseParams, video.uuid, name, 'presence')
+ })
+
+ it('Should send a notification to moderators on remote comment abuse', async function () {
+ this.timeout(20000)
+
+ const name = 'video for abuse ' + buildUUID()
+ const video = await servers[0].videos.upload({ token: userAccessToken, attributes: { name } })
+
+ await servers[0].comments.createThread({
+ token: userAccessToken,
+ videoId: video.id,
+ text: 'comment abuse ' + buildUUID()
+ })
+
+ await waitJobs(servers)
+
+ const { data } = await servers[1].comments.listThreads({ videoId: video.uuid })
+ const commentId = data[0].id
+ await servers[1].abuses.report({ commentId, reason: 'super reason' })
+
+ await waitJobs(servers)
+ await checkNewCommentAbuseForModerators(baseParams, video.uuid, name, 'presence')
+ })
+
+ it('Should send a notification to moderators on local account abuse', async function () {
+ this.timeout(20000)
+
+ const username = 'user' + new Date().getTime()
+ const { account } = await servers[0].users.create({ username, password: 'donald' })
+ const accountId = account.id
+
+ await servers[0].abuses.report({ accountId, reason: 'super reason' })
+
+ await waitJobs(servers)
+ await checkNewAccountAbuseForModerators(baseParams, username, 'presence')
+ })
+
+ it('Should send a notification to moderators on remote account abuse', async function () {
+ this.timeout(20000)
+
+ const username = 'user' + new Date().getTime()
+ 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, username, '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, AbuseState.ACCEPTED, '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, AbuseState.REJECTED, '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, 'user_1@example.com', '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)
+
+ await checkNewAbuseMessage(baseParamsAdmin, abuseId, message, 'admin' + servers[0].internalServerNumber + '@example.com', 'absence')
+ })
+
+ it('Should send a notification to moderators', async function () {
+ this.timeout(10000)
+
+ const message = 'my super message to moderators'
+ await servers[0].abuses.addMessage({ token: userAccessToken, abuseId: abuseId2, message })
+ await waitJobs(servers)
+
+ await checkNewAbuseMessage(baseParamsAdmin, abuseId2, message, 'admin' + servers[0].internalServerNumber + '@example.com', 'presence')
+ })
+
+ it('Should not send a notification to reporter if sent by the reporter', async function () {
+ this.timeout(10000)
+
+ const message = 'my super message that should not be sent to reporter'
+ await servers[0].abuses.addMessage({ token: userAccessToken, abuseId: abuseId2, message })
+ await waitJobs(servers)
+
+ await checkNewAbuseMessage(baseParamsUser, abuseId2, message, 'user_1@example.com', 'absence')
+ })