]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/tests/api/videos/videos-views-cleaner.ts
Add support for saving video files to object storage (#4290)
[github/Chocobozzz/PeerTube.git] / server / tests / api / videos / videos-views-cleaner.ts
CommitLineData
a1587156 1/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
cda03765 2
cda03765 3import 'mocha'
9293139f 4import * as chai from 'chai'
cda03765 5import {
a1587156 6 cleanupTests,
254d3579 7 createMultipleServers,
4c7e60bc 8 doubleFollow,
cda03765 9 killallServers,
254d3579 10 PeerTubeServer,
cda03765 11 setAccessTokensToServers,
a1587156
C
12 wait,
13 waitJobs
94565d52 14} from '../../../../shared/extra-utils'
cda03765
C
15
16const expect = chai.expect
17
18describe('Test video views cleaner', function () {
254d3579 19 let servers: PeerTubeServer[]
cda03765
C
20
21 let videoIdServer1: string
22 let videoIdServer2: string
23
24 before(async function () {
59fd824c 25 this.timeout(120000)
cda03765 26
254d3579 27 servers = await createMultipleServers(2)
cda03765
C
28 await setAccessTokensToServers(servers)
29
30 await doubleFollow(servers[0], servers[1])
31
89d241a7
C
32 videoIdServer1 = (await servers[0].videos.quickUpload({ name: 'video server 1' })).uuid
33 videoIdServer2 = (await servers[1].videos.quickUpload({ name: 'video server 2' })).uuid
cda03765
C
34
35 await waitJobs(servers)
36
89d241a7
C
37 await servers[0].videos.view({ id: videoIdServer1 })
38 await servers[1].videos.view({ id: videoIdServer1 })
39 await servers[0].videos.view({ id: videoIdServer2 })
40 await servers[1].videos.view({ id: videoIdServer2 })
cda03765
C
41
42 await waitJobs(servers)
43 })
44
45 it('Should not clean old video views', async function () {
46 this.timeout(50000)
47
9293139f 48 await killallServers([ servers[0] ])
cda03765 49
254d3579 50 await servers[0].run({ views: { videos: { remote: { max_age: '10 days' } } } })
cda03765
C
51
52 await wait(6000)
53
54 // Should still have views
55
56 {
57 for (const server of servers) {
89d241a7 58 const total = await server.sql.countVideoViewsOf(videoIdServer1)
c655c9ef 59 expect(total).to.equal(2, 'Server ' + server.serverNumber + ' does not have the correct amount of views')
cda03765
C
60 }
61 }
62
63 {
64 for (const server of servers) {
89d241a7 65 const total = await server.sql.countVideoViewsOf(videoIdServer2)
c655c9ef 66 expect(total).to.equal(2, 'Server ' + server.serverNumber + ' does not have the correct amount of views')
cda03765
C
67 }
68 }
69 })
70
71 it('Should clean old video views', async function () {
72 this.timeout(50000)
73
9293139f 74 await killallServers([ servers[0] ])
cda03765 75
254d3579 76 await servers[0].run({ views: { videos: { remote: { max_age: '5 seconds' } } } })
cda03765
C
77
78 await wait(6000)
79
80 // Should still have views
81
82 {
83 for (const server of servers) {
89d241a7 84 const total = await server.sql.countVideoViewsOf(videoIdServer1)
cda03765
C
85 expect(total).to.equal(2)
86 }
87 }
88
89 {
89d241a7 90 const totalServer1 = await servers[0].sql.countVideoViewsOf(videoIdServer2)
cda03765
C
91 expect(totalServer1).to.equal(0)
92
89d241a7 93 const totalServer2 = await servers[1].sql.countVideoViewsOf(videoIdServer2)
cda03765
C
94 expect(totalServer2).to.equal(2)
95 }
96 })
97
7c3b7976
C
98 after(async function () {
99 await cleanupTests(servers)
cda03765
C
100 })
101})