+
+ it('Should delete the video channel avatar', async function () {
+ this.timeout(15000)
+ await servers[0].channels.deleteImage({ channelName: 'second_video_channel', type: 'avatar' })
+
+ await waitJobs(servers)
+
+ for (const server of servers) {
+ const videoChannel = await findChannel(server, secondVideoChannelId)
+ await testFileExistsOrNot(server, 'avatars', basename(avatarPaths[server.port]), false)
+
+ expect(videoChannel.avatars).to.be.empty
+ }
+ })
+
+ it('Should delete the video channel banner', async function () {
+ this.timeout(15000)
+
+ await servers[0].channels.deleteImage({ channelName: 'second_video_channel', type: 'banner' })
+
+ await waitJobs(servers)
+
+ for (const server of servers) {
+ const videoChannel = await findChannel(server, secondVideoChannelId)
+ await testFileExistsOrNot(server, 'avatars', basename(bannerPaths[server.port]), false)
+
+ expect(videoChannel.banners).to.be.empty
+ }
+ })
+
+ it('Should list the second video channel videos', async function () {
+ this.timeout(10000)
+
+ for (const server of servers) {
+ const channelURI = 'second_video_channel@localhost:' + servers[0].port
+ const { total, data } = await server.videos.listByChannel({ handle: channelURI })
+
+ expect(total).to.equal(1)
+ expect(data).to.be.an('array')
+ expect(data).to.have.lengthOf(1)
+ expect(data[0].name).to.equal('my video name')
+ }
+ })
+
+ it('Should change the video channel of a video', async function () {
+ this.timeout(10000)
+
+ await servers[0].videos.update({ id: videoUUID, attributes: { channelId: servers[0].store.channel.id } })
+
+ await waitJobs(servers)
+ })
+
+ it('Should list the first video channel videos', async function () {
+ this.timeout(10000)
+
+ for (const server of servers) {
+ {
+ const secondChannelURI = 'second_video_channel@localhost:' + servers[0].port
+ const { total } = await server.videos.listByChannel({ handle: secondChannelURI })
+ expect(total).to.equal(0)
+ }
+
+ {
+ const channelURI = 'root_channel@localhost:' + servers[0].port
+ const { total, data } = await server.videos.listByChannel({ handle: channelURI })
+ expect(total).to.equal(1)
+
+ expect(data).to.be.an('array')
+ expect(data).to.have.lengthOf(1)
+ expect(data[0].name).to.equal('my video name')
+ }
+ }
+ })
+
+ it('Should delete video channel', async function () {
+ await servers[0].channels.delete({ channelName: 'second_video_channel' })
+ })
+
+ it('Should have video channel deleted', async function () {
+ const body = await servers[0].channels.list({ start: 0, count: 10, sort: 'createdAt' })
+
+ expect(body.total).to.equal(2)
+ expect(body.data).to.be.an('array')
+ expect(body.data).to.have.lengthOf(2)
+ expect(body.data[0].displayName).to.equal('Main root channel')
+ expect(body.data[1].displayName).to.equal('video channel updated')
+ })
+
+ it('Should create the main channel with an uuid if there is a conflict', async function () {
+ {
+ const videoChannel = { name: 'toto_channel', displayName: 'My toto channel' }
+ const created = await servers[0].channels.create({ attributes: videoChannel })
+ totoChannel = created.id
+ }
+
+ {
+ await servers[0].users.create({ username: 'toto', password: 'password' })
+ const accessToken = await servers[0].login.getAccessToken({ username: 'toto', password: 'password' })
+
+ const { videoChannels } = await servers[0].users.getMyInfo({ token: accessToken })
+ const videoChannel = videoChannels[0]
+ expect(videoChannel.name).to.match(/[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/)
+ }
+ })
+
+ it('Should report correct channel views per days', async function () {
+ this.timeout(10000)
+
+ {
+ const { data } = await servers[0].channels.listByAccount({ accountName, withStats: true })
+
+ for (const channel of data) {
+ expect(channel).to.haveOwnProperty('viewsPerDay')
+ expect(channel.viewsPerDay).to.have.length(30 + 1) // daysPrior + today
+
+ for (const v of channel.viewsPerDay) {
+ expect(v.date).to.be.an('string')
+ expect(v.views).to.equal(0)
+ }
+ }
+ }
+
+ {
+ // video has been posted on channel servers[0].store.videoChannel.id since last update
+ await servers[0].views.simulateView({ id: videoUUID, xForwardedFor: '0.0.0.1,127.0.0.1' })
+ await servers[0].views.simulateView({ id: videoUUID, xForwardedFor: '0.0.0.2,127.0.0.1' })
+
+ // Wait the repeatable job
+ await wait(8000)
+
+ const { data } = await servers[0].channels.listByAccount({ accountName, withStats: true })
+ const channelWithView = data.find(channel => channel.id === servers[0].store.channel.id)
+ expect(channelWithView.viewsPerDay.slice(-1)[0].views).to.equal(2)
+ }
+ })
+
+ it('Should report correct videos count', async function () {
+ const { data } = await servers[0].channels.listByAccount({ accountName, withStats: true })
+
+ const totoChannel = data.find(c => c.name === 'toto_channel')
+ const rootChannel = data.find(c => c.name === 'root_channel')
+
+ expect(rootChannel.videosCount).to.equal(1)
+ expect(totoChannel.videosCount).to.equal(0)
+ })
+
+ it('Should search among account video channels', async function () {
+ {
+ const body = await servers[0].channels.listByAccount({ accountName, search: 'root' })
+ expect(body.total).to.equal(1)
+
+ const channels = body.data
+ expect(channels).to.have.lengthOf(1)
+ }
+
+ {
+ const body = await servers[0].channels.listByAccount({ accountName, search: 'does not exist' })
+ expect(body.total).to.equal(0)
+
+ const channels = body.data
+ expect(channels).to.have.lengthOf(0)
+ }
+ })
+
+ it('Should list channels by updatedAt desc if a video has been uploaded', async function () {
+ this.timeout(30000)
+
+ await servers[0].videos.upload({ attributes: { channelId: totoChannel } })
+ await waitJobs(servers)
+
+ for (const server of servers) {
+ const { data } = await server.channels.listByAccount({ accountName, sort: '-updatedAt' })
+
+ expect(data[0].name).to.equal('toto_channel')
+ expect(data[1].name).to.equal('root_channel')
+ }
+
+ await servers[0].videos.upload({ attributes: { channelId: servers[0].store.channel.id } })
+ await waitJobs(servers)
+
+ for (const server of servers) {
+ const { data } = await server.channels.listByAccount({ accountName, sort: '-updatedAt' })
+
+ expect(data[0].name).to.equal('root_channel')
+ expect(data[1].name).to.equal('toto_channel')
+ }
+ })
+
+ after(async function () {
+ await cleanupTests(servers)
+ })