aboutsummaryrefslogtreecommitdiffhomepage
path: root/server/tests/api
diff options
context:
space:
mode:
authorsmilekison <24309222+smilekison@users.noreply.github.com>2021-08-25 06:08:37 -0700
committerGitHub <noreply@github.com>2021-08-25 15:08:37 +0200
commit8729a87024fc837f7dd6f13afeec90cf6dda1c06 (patch)
tree0f6f34966cf7b08d3024a08def4aa547d3aec459 /server/tests/api
parentfdec51e3846d50e3375612a6820ed3ab0b5fcd25 (diff)
downloadPeerTube-8729a87024fc837f7dd6f13afeec90cf6dda1c06.tar.gz
PeerTube-8729a87024fc837f7dd6f13afeec90cf6dda1c06.tar.zst
PeerTube-8729a87024fc837f7dd6f13afeec90cf6dda1c06.zip
Support proxies for PeerTube (#4346)
* Updated with latest code * Updated Support proxies for PeerTube * Support Proxies for PeerTube (Updated with change request) * Cleanup proxy PR Co-authored-by: Chocobozzz <me@florianbigard.com>
Diffstat (limited to 'server/tests/api')
-rw-r--r--server/tests/api/server/index.ts1
-rw-r--r--server/tests/api/server/proxy.ts72
2 files changed, 73 insertions, 0 deletions
diff --git a/server/tests/api/server/index.ts b/server/tests/api/server/index.ts
index 56e6eb5da..b16a22ee7 100644
--- a/server/tests/api/server/index.ts
+++ b/server/tests/api/server/index.ts
@@ -15,3 +15,4 @@ import './stats'
15import './tracker' 15import './tracker'
16import './no-client' 16import './no-client'
17import './plugins' 17import './plugins'
18import './proxy'
diff --git a/server/tests/api/server/proxy.ts b/server/tests/api/server/proxy.ts
new file mode 100644
index 000000000..d5042ef27
--- /dev/null
+++ b/server/tests/api/server/proxy.ts
@@ -0,0 +1,72 @@
1/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
2
3import 'mocha'
4import * as chai from 'chai'
5import { cleanupTests, createMultipleServers, doubleFollow, PeerTubeServer, setAccessTokensToServers, waitJobs } from '@shared/extra-utils'
6import { MockProxy } from '@shared/extra-utils/mock-servers/mock-proxy'
7
8const expect = chai.expect
9
10describe('Test proxy', function () {
11 let servers: PeerTubeServer[] = []
12 let proxy: MockProxy
13
14 const goodEnv = { HTTP_PROXY: '' }
15 const badEnv = { HTTP_PROXY: 'http://localhost:9000' }
16
17 before(async function () {
18 this.timeout(120000)
19
20 proxy = new MockProxy()
21
22 const proxyPort = await proxy.initialize()
23 servers = await createMultipleServers(2)
24
25 goodEnv.HTTP_PROXY = 'http://localhost:' + proxyPort
26
27 await setAccessTokensToServers(servers)
28 await doubleFollow(servers[0], servers[1])
29 })
30
31 it('Should succeed federation with the appropriate proxy config', async function () {
32 await servers[0].kill()
33 await servers[0].run({}, { env: goodEnv })
34
35 await servers[0].videos.quickUpload({ name: 'video 1' })
36
37 await waitJobs(servers)
38
39 for (const server of servers) {
40 const { total, data } = await server.videos.list()
41 expect(total).to.equal(1)
42 expect(data).to.have.lengthOf(1)
43 }
44 })
45
46 it('Should fail federation with a wrong proxy config', async function () {
47 await servers[0].kill()
48 await servers[0].run({}, { env: badEnv })
49
50 await servers[0].videos.quickUpload({ name: 'video 2' })
51
52 await waitJobs(servers)
53
54 {
55 const { total, data } = await servers[0].videos.list()
56 expect(total).to.equal(2)
57 expect(data).to.have.lengthOf(2)
58 }
59
60 {
61 const { total, data } = await servers[1].videos.list()
62 expect(total).to.equal(1)
63 expect(data).to.have.lengthOf(1)
64 }
65 })
66
67 after(async function () {
68 proxy.terminate()
69
70 await cleanupTests(servers)
71 })
72})