aboutsummaryrefslogtreecommitdiffhomepage
path: root/server/tests/utils/server
diff options
context:
space:
mode:
Diffstat (limited to 'server/tests/utils/server')
-rw-r--r--server/tests/utils/server/activitypub.ts15
-rw-r--r--server/tests/utils/server/clients.ts17
-rw-r--r--server/tests/utils/server/config.ts17
-rw-r--r--server/tests/utils/server/follows.ts77
-rw-r--r--server/tests/utils/server/jobs.ts33
-rw-r--r--server/tests/utils/server/servers.ts162
6 files changed, 321 insertions, 0 deletions
diff --git a/server/tests/utils/server/activitypub.ts b/server/tests/utils/server/activitypub.ts
new file mode 100644
index 000000000..cf3c1c3b3
--- /dev/null
+++ b/server/tests/utils/server/activitypub.ts
@@ -0,0 +1,15 @@
1import * as request from 'supertest'
2
3function makeActivityPubGetRequest (url: string, path: string) {
4 return request(url)
5 .get(path)
6 .set('Accept', 'application/activity+json,text/html;q=0.9,\\*/\\*;q=0.8')
7 .expect(200)
8 .expect('Content-Type', /json/)
9}
10
11// ---------------------------------------------------------------------------
12
13export {
14 makeActivityPubGetRequest
15}
diff --git a/server/tests/utils/server/clients.ts b/server/tests/utils/server/clients.ts
new file mode 100644
index 000000000..a8c5b51c5
--- /dev/null
+++ b/server/tests/utils/server/clients.ts
@@ -0,0 +1,17 @@
1import * as request from 'supertest'
2
3function getClient (url: string) {
4 const path = '/api/v1/oauth-clients/local'
5
6 return request(url)
7 .get(path)
8 .set('Accept', 'application/json')
9 .expect(200)
10 .expect('Content-Type', /json/)
11}
12
13// ---------------------------------------------------------------------------
14
15export {
16 getClient
17}
diff --git a/server/tests/utils/server/config.ts b/server/tests/utils/server/config.ts
new file mode 100644
index 000000000..d09c19c60
--- /dev/null
+++ b/server/tests/utils/server/config.ts
@@ -0,0 +1,17 @@
1import * as request from 'supertest'
2
3function getConfig (url: string) {
4 const path = '/api/v1/config'
5
6 return request(url)
7 .get(path)
8 .set('Accept', 'application/json')
9 .expect(200)
10 .expect('Content-Type', /json/)
11}
12
13// ---------------------------------------------------------------------------
14
15export {
16 getConfig
17}
diff --git a/server/tests/utils/server/follows.ts b/server/tests/utils/server/follows.ts
new file mode 100644
index 000000000..82e89175c
--- /dev/null
+++ b/server/tests/utils/server/follows.ts
@@ -0,0 +1,77 @@
1import * as request from 'supertest'
2import { wait } from '../miscs/miscs'
3import { ServerInfo } from './servers'
4
5function getFollowersListPaginationAndSort (url: string, start: number, count: number, sort: string) {
6 const path = '/api/v1/server/followers'
7
8 return request(url)
9 .get(path)
10 .query({ start })
11 .query({ count })
12 .query({ sort })
13 .set('Accept', 'application/json')
14 .expect(200)
15 .expect('Content-Type', /json/)
16}
17
18function getFollowingListPaginationAndSort (url: string, start: number, count: number, sort: string) {
19 const path = '/api/v1/server/following'
20
21 return request(url)
22 .get(path)
23 .query({ start })
24 .query({ count })
25 .query({ sort })
26 .set('Accept', 'application/json')
27 .expect(200)
28 .expect('Content-Type', /json/)
29}
30
31async function follow (follower: string, following: string[], accessToken: string, expectedStatus = 204) {
32 const path = '/api/v1/server/following'
33
34 const followingHosts = following.map(f => f.replace(/^http:\/\//, ''))
35 const res = await request(follower)
36 .post(path)
37 .set('Accept', 'application/json')
38 .set('Authorization', 'Bearer ' + accessToken)
39 .send({ 'hosts': followingHosts })
40 .expect(expectedStatus)
41
42 return res
43}
44
45async function unfollow (url: string, accessToken: string, target: ServerInfo, expectedStatus = 204) {
46 const path = '/api/v1/server/following/' + target.host
47
48 const res = await request(url)
49 .delete(path)
50 .set('Accept', 'application/json')
51 .set('Authorization', 'Bearer ' + accessToken)
52 .expect(expectedStatus)
53
54 return res
55}
56
57async function doubleFollow (server1: ServerInfo, server2: ServerInfo) {
58 await Promise.all([
59 follow(server1.url, [ server2.url ], server1.accessToken),
60 follow(server2.url, [ server1.url ], server2.accessToken)
61 ])
62
63 // Wait request propagation
64 await wait(10000)
65
66 return true
67}
68
69// ---------------------------------------------------------------------------
70
71export {
72 getFollowersListPaginationAndSort,
73 getFollowingListPaginationAndSort,
74 unfollow,
75 follow,
76 doubleFollow
77}
diff --git a/server/tests/utils/server/jobs.ts b/server/tests/utils/server/jobs.ts
new file mode 100644
index 000000000..0a8c51575
--- /dev/null
+++ b/server/tests/utils/server/jobs.ts
@@ -0,0 +1,33 @@
1import * as request from 'supertest'
2
3function getJobsList (url: string, accessToken: string) {
4 const path = '/api/v1/jobs'
5
6 return request(url)
7 .get(path)
8 .set('Accept', 'application/json')
9 .set('Authorization', 'Bearer ' + accessToken)
10 .expect(200)
11 .expect('Content-Type', /json/)
12}
13
14function getJobsListPaginationAndSort (url: string, accessToken: string, start: number, count: number, sort: string) {
15 const path = '/api/v1/jobs'
16
17 return request(url)
18 .get(path)
19 .query({ start })
20 .query({ count })
21 .query({ sort })
22 .set('Accept', 'application/json')
23 .set('Authorization', 'Bearer ' + accessToken)
24 .expect(200)
25 .expect('Content-Type', /json/)
26}
27
28// ---------------------------------------------------------------------------
29
30export {
31 getJobsList,
32 getJobsListPaginationAndSort
33}
diff --git a/server/tests/utils/server/servers.ts b/server/tests/utils/server/servers.ts
new file mode 100644
index 000000000..8340fbc18
--- /dev/null
+++ b/server/tests/utils/server/servers.ts
@@ -0,0 +1,162 @@
1import { ChildProcess, exec, fork } from 'child_process'
2import { join } from 'path'
3
4interface ServerInfo {
5 app: ChildProcess,
6 url: string
7 host: string
8 serverNumber: number
9
10 client: {
11 id: string,
12 secret: string
13 }
14
15 user: {
16 username: string,
17 password: string,
18 email?: string
19 }
20
21 accessToken?: string
22
23 video?: {
24 id: number
25 uuid: string
26 name: string
27 accountName: string
28 }
29
30 remoteVideo?: {
31 id: number
32 uuid: string
33 }
34}
35
36function flushAndRunMultipleServers (totalServers) {
37 let apps = []
38 let i = 0
39
40 return new Promise<ServerInfo[]>(res => {
41 function anotherServerDone (serverNumber, app) {
42 apps[serverNumber - 1] = app
43 i++
44 if (i === totalServers) {
45 return res(apps)
46 }
47 }
48
49 flushTests()
50 .then(() => {
51 for (let j = 1; j <= totalServers; j++) {
52 // For the virtual buffer
53 setTimeout(() => {
54 runServer(j).then(app => anotherServerDone(j, app))
55 }, 1000 * (j - 1))
56 }
57 })
58 })
59}
60
61function flushTests () {
62 return new Promise<void>((res, rej) => {
63 return exec('npm run clean:server:test', err => {
64 if (err) return rej(err)
65
66 return res()
67 })
68 })
69}
70
71function runServer (serverNumber: number, configOverride?: Object) {
72 const server: ServerInfo = {
73 app: null,
74 serverNumber: serverNumber,
75 url: `http://localhost:${9000 + serverNumber}`,
76 host: `localhost:${9000 + serverNumber}`,
77 client: {
78 id: null,
79 secret: null
80 },
81 user: {
82 username: null,
83 password: null
84 }
85 }
86
87 // These actions are async so we need to be sure that they have both been done
88 const serverRunString = {
89 'Server listening on port': false
90 }
91 const key = 'Database peertube_test' + serverNumber + ' is ready'
92 serverRunString[key] = false
93
94 const regexps = {
95 client_id: 'Client id: (.+)',
96 client_secret: 'Client secret: (.+)',
97 user_username: 'Username: (.+)',
98 user_password: 'User password: (.+)'
99 }
100
101 // Share the environment
102 const env = Object.create(process.env)
103 env['NODE_ENV'] = 'test'
104 env['NODE_APP_INSTANCE'] = serverNumber.toString()
105
106 if (configOverride !== undefined) {
107 env['NODE_CONFIG'] = JSON.stringify(configOverride)
108 }
109
110 const options = {
111 silent: true,
112 env: env,
113 detached: true
114 }
115
116 return new Promise<ServerInfo>(res => {
117 server.app = fork(join(__dirname, '..', '..', '..', 'dist', 'server.js'), [], options)
118 server.app.stdout.on('data', function onStdout (data) {
119 let dontContinue = false
120
121 // Capture things if we want to
122 for (const key of Object.keys(regexps)) {
123 const regexp = regexps[key]
124 const matches = data.toString().match(regexp)
125 if (matches !== null) {
126 if (key === 'client_id') server.client.id = matches[1]
127 else if (key === 'client_secret') server.client.secret = matches[1]
128 else if (key === 'user_username') server.user.username = matches[1]
129 else if (key === 'user_password') server.user.password = matches[1]
130 }
131 }
132
133 // Check if all required sentences are here
134 for (const key of Object.keys(serverRunString)) {
135 if (data.toString().indexOf(key) !== -1) serverRunString[key] = true
136 if (serverRunString[key] === false) dontContinue = true
137 }
138
139 // If no, there is maybe one thing not already initialized (client/user credentials generation...)
140 if (dontContinue === true) return
141
142 server.app.stdout.removeListener('data', onStdout)
143 res(server)
144 })
145 })
146}
147
148function killallServers (servers: ServerInfo[]) {
149 for (const server of servers) {
150 process.kill(-server.app.pid)
151 }
152}
153
154// ---------------------------------------------------------------------------
155
156export {
157 ServerInfo,
158 flushAndRunMultipleServers,
159 flushTests,
160 runServer,
161 killallServers
162}