]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/tests/api/videos/videos-history.ts
emit more specific status codes on video upload (#3423)
[github/Chocobozzz/PeerTube.git] / server / tests / api / videos / videos-history.ts
CommitLineData
a1587156 1/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
6e46de09
C
2
3import * as chai from 'chai'
4import 'mocha'
5import {
7c3b7976 6 cleanupTests,
8b9a525a 7 createUser,
7c3b7976 8 flushAndRunServer,
6e46de09
C
9 getVideosListWithToken,
10 getVideoWithToken,
7c3b7976
C
11 killallServers,
12 reRunServer,
8b9a525a 13 searchVideoWithToken,
6e46de09
C
14 ServerInfo,
15 setAccessTokensToServers,
8b9a525a
C
16 updateMyUser,
17 uploadVideo,
8f0bc73d
C
18 userLogin,
19 wait
94565d52 20} from '../../../../shared/extra-utils'
6e46de09 21import { Video, VideoDetails } from '../../../../shared/models/videos'
94565d52 22import { listMyVideosHistory, removeMyVideosHistory, userWatchVideo } from '../../../../shared/extra-utils/videos/video-history'
f2eb23cd 23import { HttpStatusCode } from '../../../../shared/core-utils/miscs/http-error-codes'
6e46de09
C
24
25const expect = chai.expect
26
27describe('Test videos history', function () {
28 let server: ServerInfo = null
29 let video1UUID: string
30 let video2UUID: string
31 let video3UUID: string
8b9a525a
C
32 let video3WatchedDate: Date
33 let userAccessToken: string
6e46de09
C
34
35 before(async function () {
36 this.timeout(30000)
37
210feb6c 38 server = await flushAndRunServer(1)
6e46de09
C
39
40 await setAccessTokensToServers([ server ])
41
42 {
43 const res = await uploadVideo(server.url, server.accessToken, { name: 'video 1' })
44 video1UUID = res.body.video.uuid
45 }
46
47 {
48 const res = await uploadVideo(server.url, server.accessToken, { name: 'video 2' })
49 video2UUID = res.body.video.uuid
50 }
51
52 {
53 const res = await uploadVideo(server.url, server.accessToken, { name: 'video 3' })
54 video3UUID = res.body.video.uuid
55 }
8b9a525a
C
56
57 const user = {
58 username: 'user_1',
59 password: 'super password'
60 }
1eddc9a7 61 await createUser({ url: server.url, accessToken: server.accessToken, username: user.username, password: user.password })
8b9a525a 62 userAccessToken = await userLogin(server, user)
6e46de09
C
63 })
64
65 it('Should get videos, without watching history', async function () {
66 const res = await getVideosListWithToken(server.url, server.accessToken)
67 const videos: Video[] = res.body.data
68
69 for (const video of videos) {
70 const resDetail = await getVideoWithToken(server.url, server.accessToken, video.id)
71 const videoDetails: VideoDetails = resDetail.body
72
73 expect(video.userHistory).to.be.undefined
74 expect(videoDetails.userHistory).to.be.undefined
75 }
76 })
77
78 it('Should watch the first and second video', async function () {
6e46de09 79 await userWatchVideo(server.url, server.accessToken, video2UUID, 8)
8b9a525a 80 await userWatchVideo(server.url, server.accessToken, video1UUID, 3)
6e46de09
C
81 })
82
83 it('Should return the correct history when listing, searching and getting videos', async function () {
84 const videosOfVideos: Video[][] = []
85
86 {
87 const res = await getVideosListWithToken(server.url, server.accessToken)
88 videosOfVideos.push(res.body.data)
89 }
90
91 {
92 const res = await searchVideoWithToken(server.url, 'video', server.accessToken)
93 videosOfVideos.push(res.body.data)
94 }
95
96 for (const videos of videosOfVideos) {
97 const video1 = videos.find(v => v.uuid === video1UUID)
98 const video2 = videos.find(v => v.uuid === video2UUID)
99 const video3 = videos.find(v => v.uuid === video3UUID)
100
101 expect(video1.userHistory).to.not.be.undefined
102 expect(video1.userHistory.currentTime).to.equal(3)
103
104 expect(video2.userHistory).to.not.be.undefined
105 expect(video2.userHistory.currentTime).to.equal(8)
106
107 expect(video3.userHistory).to.be.undefined
108 }
109
110 {
111 const resDetail = await getVideoWithToken(server.url, server.accessToken, video1UUID)
112 const videoDetails: VideoDetails = resDetail.body
113
114 expect(videoDetails.userHistory).to.not.be.undefined
115 expect(videoDetails.userHistory.currentTime).to.equal(3)
116 }
117
118 {
119 const resDetail = await getVideoWithToken(server.url, server.accessToken, video2UUID)
120 const videoDetails: VideoDetails = resDetail.body
121
122 expect(videoDetails.userHistory).to.not.be.undefined
123 expect(videoDetails.userHistory.currentTime).to.equal(8)
124 }
125
126 {
127 const resDetail = await getVideoWithToken(server.url, server.accessToken, video3UUID)
128 const videoDetails: VideoDetails = resDetail.body
129
130 expect(videoDetails.userHistory).to.be.undefined
131 }
132 })
133
8b9a525a
C
134 it('Should have these videos when listing my history', async function () {
135 video3WatchedDate = new Date()
136 await userWatchVideo(server.url, server.accessToken, video3UUID, 2)
137
138 const res = await listMyVideosHistory(server.url, server.accessToken)
139
140 expect(res.body.total).to.equal(3)
141
142 const videos: Video[] = res.body.data
143 expect(videos[0].name).to.equal('video 3')
144 expect(videos[1].name).to.equal('video 1')
145 expect(videos[2].name).to.equal('video 2')
146 })
147
148 it('Should not have videos history on another user', async function () {
149 const res = await listMyVideosHistory(server.url, userAccessToken)
150
151 expect(res.body.total).to.equal(0)
152 expect(res.body.data).to.have.lengthOf(0)
153 })
154
155 it('Should clear my history', async function () {
156 await removeMyVideosHistory(server.url, server.accessToken, video3WatchedDate.toISOString())
157 })
158
159 it('Should have my history cleared', async function () {
160 const res = await listMyVideosHistory(server.url, server.accessToken)
161
162 expect(res.body.total).to.equal(1)
163
164 const videos: Video[] = res.body.data
165 expect(videos[0].name).to.equal('video 3')
166 })
167
168 it('Should disable videos history', async function () {
169 await updateMyUser({
170 url: server.url,
171 accessToken: server.accessToken,
172 videosHistoryEnabled: false
173 })
174
f2eb23cd 175 await userWatchVideo(server.url, server.accessToken, video2UUID, 8, HttpStatusCode.CONFLICT_409)
8b9a525a
C
176 })
177
178 it('Should re-enable videos history', async function () {
179 await updateMyUser({
180 url: server.url,
181 accessToken: server.accessToken,
182 videosHistoryEnabled: true
183 })
184
185 await userWatchVideo(server.url, server.accessToken, video1UUID, 8)
186
187 const res = await listMyVideosHistory(server.url, server.accessToken)
188
189 expect(res.body.total).to.equal(2)
190
191 const videos: Video[] = res.body.data
192 expect(videos[0].name).to.equal('video 1')
193 expect(videos[1].name).to.equal('video 3')
194 })
195
8f0bc73d
C
196 it('Should not clean old history', async function () {
197 this.timeout(50000)
198
199 killallServers([ server ])
200
201 await reRunServer(server, { history: { videos: { max_age: '10 days' } } })
202
203 await wait(6000)
204
205 // Should still have history
206
207 const res = await listMyVideosHistory(server.url, server.accessToken)
208
209 expect(res.body.total).to.equal(2)
210 })
211
212 it('Should clean old history', async function () {
213 this.timeout(50000)
214
215 killallServers([ server ])
216
217 await reRunServer(server, { history: { videos: { max_age: '5 seconds' } } })
218
219 await wait(6000)
220
221 const res = await listMyVideosHistory(server.url, server.accessToken)
222 expect(res.body.total).to.equal(0)
223 })
224
7c3b7976
C
225 after(async function () {
226 await cleanupTests([ server ])
6e46de09
C
227 })
228})