Add test for auto mute list router
authorChocobozzz <me@florianbigard.com>
Mon, 11 May 2020 08:15:44 +0000 (10:15 +0200)
committerChocobozzz <me@florianbigard.com>
Mon, 11 May 2020 08:15:56 +0000 (10:15 +0200)
server/tests/external-plugins/auto-mute.ts
server/tests/external-plugins/index.ts

index 2f2c9102db184533913f40d904ff822a2b561b94..bfdbee80ad6253da3b68d387bcde339efc5ae69e 100644 (file)
@@ -2,11 +2,16 @@
 
 import 'mocha'
 import { expect } from 'chai'
-import { removeAccountFromServerBlocklist } from '@shared/extra-utils/users/blocklist'
+import {
+  addAccountToServerBlocklist,
+  addServerToAccountBlocklist,
+  removeAccountFromServerBlocklist
+} from '@shared/extra-utils/users/blocklist'
 import {
   doubleFollow,
   getVideosList,
   installPlugin,
+  makeGetRequest,
   MockBlocklist,
   setAccessTokensToServers,
   updatePluginSettings,
@@ -22,6 +27,7 @@ import {
 } from '../../../shared/extra-utils/server/servers'
 
 describe('Official plugin auto-mute', function () {
+  const autoMuteListPath = '/plugins/auto-mute/router/api/v1/mute-list'
   let servers: ServerInfo[]
   let blocklistServer: MockBlocklist
 
@@ -31,11 +37,13 @@ describe('Official plugin auto-mute', function () {
     servers = await flushAndRunMultipleServers(2)
     await setAccessTokensToServers(servers)
 
-    await installPlugin({
-      url: servers[0].url,
-      accessToken: servers[0].accessToken,
-      npmName: 'peertube-plugin-auto-mute'
-    })
+    for (const server of servers) {
+      await installPlugin({
+        url: server.url,
+        accessToken: server.accessToken,
+        npmName: 'peertube-plugin-auto-mute'
+      })
+    }
 
     blocklistServer = new MockBlocklist()
     await blocklistServer.initialize()
@@ -166,6 +174,69 @@ describe('Official plugin auto-mute', function () {
     }
   })
 
+  it('Should not expose the auto mute list', async function () {
+    await makeGetRequest({
+      url: servers[0].url,
+      path: '/plugins/auto-mute/router/api/v1/mute-list',
+      statusCodeExpected: 403
+    })
+  })
+
+  it('Should enable auto mute list', async function () {
+    await updatePluginSettings({
+      url: servers[0].url,
+      accessToken: servers[0].accessToken,
+      npmName: 'peertube-plugin-auto-mute',
+      settings: {
+        'blocklist-urls': '',
+        'check-seconds-interval': 1,
+        'expose-mute-list': true
+      }
+    })
+
+    await makeGetRequest({
+      url: servers[0].url,
+      path: '/plugins/auto-mute/router/api/v1/mute-list',
+      statusCodeExpected: 200
+    })
+  })
+
+  it('Should mute an account on server 1, and server 2 auto mutes it', async function () {
+    this.timeout(20000)
+
+    await updatePluginSettings({
+      url: servers[1].url,
+      accessToken: servers[1].accessToken,
+      npmName: 'peertube-plugin-auto-mute',
+      settings: {
+        'blocklist-urls': 'http://localhost:' + servers[0].port + autoMuteListPath,
+        'check-seconds-interval': 1,
+        'expose-mute-list': false
+      }
+    })
+
+    await addAccountToServerBlocklist(servers[0].url, servers[0].accessToken, 'root@localhost:' + servers[1].port)
+    await addServerToAccountBlocklist(servers[0].url, servers[0].accessToken, 'localhost:' + servers[1].port)
+
+    const res = await makeGetRequest({
+      url: servers[0].url,
+      path: '/plugins/auto-mute/router/api/v1/mute-list',
+      statusCodeExpected: 200
+    })
+
+    const data = res.body.data
+    expect(data).to.have.lengthOf(1)
+    expect(data[0].updatedAt).to.exist
+    expect(data[0].value).to.equal('root@localhost:' + servers[1].port)
+
+    await wait(2000)
+
+    for (const server of servers) {
+      const res = await getVideosList(server.url)
+      expect(res.body.total).to.equal(1)
+    }
+  })
+
   after(async function () {
     await cleanupTests(servers)
   })
index 352d38de90145eaf13195d87b98e18de5185be44..d17894c158027c5475d4adf784c24805392e2518 100644 (file)
@@ -1,2 +1,2 @@
-export * from './auth-ldap'
-export * from './auto-mute'
+import './auth-ldap'
+import './auto-mute'