1
0
Fork 0
peertube/server/tests/api/server/config.ts

610 lines
20 KiB
TypeScript
Raw Normal View History

2020-01-31 15:56:52 +00:00
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
2017-09-04 19:21:47 +00:00
2022-08-17 13:44:32 +00:00
import { expect } from 'chai'
import { parallelTests } from '@shared/core-utils'
import { CustomConfig, HttpStatusCode } from '@shared/models'
2017-09-04 19:21:47 +00:00
import {
2019-04-24 13:10:37 +00:00
cleanupTests,
2021-07-16 07:47:51 +00:00
createSingleServer,
2020-01-31 15:56:52 +00:00
killallServers,
2021-04-12 13:33:54 +00:00
makeGetRequest,
2021-07-16 07:47:51 +00:00
PeerTubeServer,
2021-07-15 08:02:54 +00:00
setAccessTokensToServers
} from '@shared/server-commands'
2017-09-04 19:21:47 +00:00
2021-07-16 07:47:51 +00:00
function checkInitialConfig (server: PeerTubeServer, data: CustomConfig) {
2018-07-12 17:02:00 +00:00
expect(data.instance.name).to.equal('PeerTube')
expect(data.instance.shortDescription).to.equal(
'PeerTube, an ActivityPub-federated video streaming platform using P2P directly in your web browser.'
2018-07-12 17:02:00 +00:00
)
expect(data.instance.description).to.equal('Welcome to this PeerTube instance!')
2019-08-23 13:23:27 +00:00
2018-07-12 17:02:00 +00:00
expect(data.instance.terms).to.equal('No terms for now.')
2019-09-03 07:49:04 +00:00
expect(data.instance.creationReason).to.be.empty
2019-08-23 13:23:27 +00:00
expect(data.instance.codeOfConduct).to.be.empty
expect(data.instance.moderationInformation).to.be.empty
expect(data.instance.administrator).to.be.empty
expect(data.instance.maintenanceLifetime).to.be.empty
expect(data.instance.businessModel).to.be.empty
expect(data.instance.hardwareInformation).to.be.empty
2019-08-23 13:23:27 +00:00
expect(data.instance.languages).to.have.lengthOf(0)
expect(data.instance.categories).to.have.lengthOf(0)
2018-07-12 17:02:00 +00:00
expect(data.instance.defaultClientRoute).to.equal('/videos/trending')
2019-02-20 14:36:43 +00:00
expect(data.instance.isNSFW).to.be.false
2018-07-12 17:02:00 +00:00
expect(data.instance.defaultNSFWPolicy).to.equal('display')
expect(data.instance.customizations.css).to.be.empty
expect(data.instance.customizations.javascript).to.be.empty
2019-01-09 14:14:29 +00:00
2018-07-12 17:02:00 +00:00
expect(data.services.twitter.username).to.equal('@Chocobozzz')
expect(data.services.twitter.whitelisted).to.be.false
2019-01-09 14:14:29 +00:00
expect(data.client.videos.miniature.preferAuthorDisplayName).to.be.false
expect(data.client.menu.login.redirectOnSingleExternalAuth).to.be.false
2018-07-12 17:02:00 +00:00
expect(data.cache.previews.size).to.equal(1)
expect(data.cache.captions.size).to.equal(1)
expect(data.cache.torrents.size).to.equal(1)
2019-01-09 14:14:29 +00:00
2018-07-12 17:02:00 +00:00
expect(data.signup.enabled).to.be.true
expect(data.signup.limit).to.equal(4)
expect(data.signup.minimumAge).to.equal(16)
2023-01-19 08:28:29 +00:00
expect(data.signup.requiresApproval).to.be.false
expect(data.signup.requiresEmailVerification).to.be.false
2019-01-09 14:14:29 +00:00
2019-04-26 06:50:52 +00:00
expect(data.admin.email).to.equal('admin' + server.internalServerNumber + '@example.com')
2019-01-09 14:14:29 +00:00
expect(data.contactForm.enabled).to.be.true
2018-07-12 17:02:00 +00:00
expect(data.user.videoQuota).to.equal(5242880)
2018-08-28 09:32:03 +00:00
expect(data.user.videoQuotaDaily).to.equal(-1)
expect(data.videoChannels.maxPerUser).to.equal(20)
2018-07-12 17:02:00 +00:00
expect(data.transcoding.enabled).to.be.false
2018-12-11 13:52:50 +00:00
expect(data.transcoding.allowAdditionalExtensions).to.be.false
2019-05-16 14:55:34 +00:00
expect(data.transcoding.allowAudioFiles).to.be.false
2018-07-12 17:02:00 +00:00
expect(data.transcoding.threads).to.equal(2)
expect(data.transcoding.concurrency).to.equal(2)
expect(data.transcoding.profile).to.equal('default')
expect(data.transcoding.resolutions['144p']).to.be.false
2018-07-12 17:02:00 +00:00
expect(data.transcoding.resolutions['240p']).to.be.true
expect(data.transcoding.resolutions['360p']).to.be.true
expect(data.transcoding.resolutions['480p']).to.be.true
expect(data.transcoding.resolutions['720p']).to.be.true
expect(data.transcoding.resolutions['1080p']).to.be.true
expect(data.transcoding.resolutions['1440p']).to.be.true
2019-06-12 15:33:29 +00:00
expect(data.transcoding.resolutions['2160p']).to.be.true
expect(data.transcoding.alwaysTranscodeOriginalResolution).to.be.true
expect(data.transcoding.webtorrent.enabled).to.be.true
2019-01-29 07:37:25 +00:00
expect(data.transcoding.hls.enabled).to.be.true
expect(data.live.enabled).to.be.false
2020-11-06 15:43:43 +00:00
expect(data.live.allowReplay).to.be.false
2022-03-04 12:40:02 +00:00
expect(data.live.latencySetting.enabled).to.be.true
2020-12-15 08:23:28 +00:00
expect(data.live.maxDuration).to.equal(-1)
2020-10-28 14:24:40 +00:00
expect(data.live.maxInstanceLives).to.equal(20)
expect(data.live.maxUserLives).to.equal(3)
expect(data.live.transcoding.enabled).to.be.false
expect(data.live.transcoding.threads).to.equal(2)
expect(data.live.transcoding.profile).to.equal('default')
expect(data.live.transcoding.resolutions['144p']).to.be.false
expect(data.live.transcoding.resolutions['240p']).to.be.false
expect(data.live.transcoding.resolutions['360p']).to.be.false
expect(data.live.transcoding.resolutions['480p']).to.be.false
expect(data.live.transcoding.resolutions['720p']).to.be.false
expect(data.live.transcoding.resolutions['1080p']).to.be.false
expect(data.live.transcoding.resolutions['1440p']).to.be.false
expect(data.live.transcoding.resolutions['2160p']).to.be.false
expect(data.live.transcoding.alwaysTranscodeOriginalResolution).to.be.true
2022-03-22 15:58:49 +00:00
expect(data.videoStudio.enabled).to.be.false
2022-02-11 09:51:33 +00:00
expect(data.import.videos.concurrency).to.equal(2)
2018-08-03 09:10:31 +00:00
expect(data.import.videos.http.enabled).to.be.true
2018-08-07 08:07:53 +00:00
expect(data.import.videos.torrent.enabled).to.be.true
expect(data.autoBlacklist.videos.ofUsers.enabled).to.be.false
2019-04-08 12:04:57 +00:00
expect(data.followers.instance.enabled).to.be.true
expect(data.followers.instance.manualApproval).to.be.false
expect(data.followings.instance.autoFollowBack.enabled).to.be.false
expect(data.followings.instance.autoFollowIndex.enabled).to.be.false
2020-05-11 11:43:56 +00:00
expect(data.followings.instance.autoFollowIndex.indexUrl).to.equal('')
2020-05-28 09:15:38 +00:00
expect(data.broadcastMessage.enabled).to.be.false
expect(data.broadcastMessage.level).to.equal('info')
expect(data.broadcastMessage.message).to.equal('')
expect(data.broadcastMessage.dismissable).to.be.false
2018-07-12 17:02:00 +00:00
}
function checkUpdatedConfig (data: CustomConfig) {
expect(data.instance.name).to.equal('PeerTube updated')
expect(data.instance.shortDescription).to.equal('my short description')
expect(data.instance.description).to.equal('my super description')
2019-08-23 13:23:27 +00:00
2018-07-12 17:02:00 +00:00
expect(data.instance.terms).to.equal('my super terms')
2019-09-03 07:49:04 +00:00
expect(data.instance.creationReason).to.equal('my super creation reason')
2019-08-23 13:23:27 +00:00
expect(data.instance.codeOfConduct).to.equal('my super coc')
expect(data.instance.moderationInformation).to.equal('my super moderation information')
expect(data.instance.administrator).to.equal('Kuja')
expect(data.instance.maintenanceLifetime).to.equal('forever')
expect(data.instance.businessModel).to.equal('my super business model')
expect(data.instance.hardwareInformation).to.equal('2vCore 3GB RAM')
2019-08-23 13:23:27 +00:00
expect(data.instance.languages).to.deep.equal([ 'en', 'es' ])
expect(data.instance.categories).to.deep.equal([ 1, 2 ])
2018-07-12 17:02:00 +00:00
expect(data.instance.defaultClientRoute).to.equal('/videos/recently-added')
2019-02-20 14:36:43 +00:00
expect(data.instance.isNSFW).to.be.true
2018-07-12 17:02:00 +00:00
expect(data.instance.defaultNSFWPolicy).to.equal('blur')
expect(data.instance.customizations.javascript).to.equal('alert("coucou")')
expect(data.instance.customizations.css).to.equal('body { background-color: red; }')
2019-01-09 14:14:29 +00:00
2018-07-12 17:02:00 +00:00
expect(data.services.twitter.username).to.equal('@Kuja')
expect(data.services.twitter.whitelisted).to.be.true
2019-01-09 14:14:29 +00:00
expect(data.client.videos.miniature.preferAuthorDisplayName).to.be.true
expect(data.client.menu.login.redirectOnSingleExternalAuth).to.be.true
2018-07-12 17:02:00 +00:00
expect(data.cache.previews.size).to.equal(2)
expect(data.cache.captions.size).to.equal(3)
expect(data.cache.torrents.size).to.equal(4)
2019-01-09 14:14:29 +00:00
2018-07-12 17:02:00 +00:00
expect(data.signup.enabled).to.be.false
expect(data.signup.limit).to.equal(5)
2023-01-19 08:28:29 +00:00
expect(data.signup.requiresApproval).to.be.false
expect(data.signup.requiresEmailVerification).to.be.false
expect(data.signup.minimumAge).to.equal(10)
2019-01-09 14:14:29 +00:00
2019-04-26 06:50:52 +00:00
// We override admin email in parallel tests, so skip this exception
if (parallelTests() === false) {
expect(data.admin.email).to.equal('superadmin1@example.com')
}
2019-01-09 14:14:29 +00:00
expect(data.contactForm.enabled).to.be.false
2018-07-12 17:02:00 +00:00
expect(data.user.videoQuota).to.equal(5242881)
expect(data.user.videoQuotaDaily).to.equal(318742)
2019-01-09 14:14:29 +00:00
expect(data.videoChannels.maxPerUser).to.equal(24)
2018-07-12 17:02:00 +00:00
expect(data.transcoding.enabled).to.be.true
expect(data.transcoding.threads).to.equal(1)
expect(data.transcoding.concurrency).to.equal(3)
2018-12-11 13:52:50 +00:00
expect(data.transcoding.allowAdditionalExtensions).to.be.true
2019-05-16 14:55:34 +00:00
expect(data.transcoding.allowAudioFiles).to.be.true
expect(data.transcoding.profile).to.equal('vod_profile')
expect(data.transcoding.resolutions['144p']).to.be.false
2018-07-12 17:02:00 +00:00
expect(data.transcoding.resolutions['240p']).to.be.false
expect(data.transcoding.resolutions['360p']).to.be.true
expect(data.transcoding.resolutions['480p']).to.be.true
expect(data.transcoding.resolutions['720p']).to.be.false
expect(data.transcoding.resolutions['1080p']).to.be.false
2019-06-12 15:33:29 +00:00
expect(data.transcoding.resolutions['2160p']).to.be.false
expect(data.transcoding.alwaysTranscodeOriginalResolution).to.be.false
2019-01-29 07:37:25 +00:00
expect(data.transcoding.hls.enabled).to.be.false
expect(data.transcoding.webtorrent.enabled).to.be.true
2019-01-09 14:14:29 +00:00
expect(data.live.enabled).to.be.true
2020-11-06 15:43:43 +00:00
expect(data.live.allowReplay).to.be.true
2022-03-04 12:40:02 +00:00
expect(data.live.latencySetting.enabled).to.be.false
2020-09-25 14:19:35 +00:00
expect(data.live.maxDuration).to.equal(5000)
2020-10-28 14:24:40 +00:00
expect(data.live.maxInstanceLives).to.equal(-1)
expect(data.live.maxUserLives).to.equal(10)
expect(data.live.transcoding.enabled).to.be.true
expect(data.live.transcoding.threads).to.equal(4)
expect(data.live.transcoding.profile).to.equal('live_profile')
expect(data.live.transcoding.resolutions['144p']).to.be.true
expect(data.live.transcoding.resolutions['240p']).to.be.true
expect(data.live.transcoding.resolutions['360p']).to.be.true
expect(data.live.transcoding.resolutions['480p']).to.be.true
expect(data.live.transcoding.resolutions['720p']).to.be.true
expect(data.live.transcoding.resolutions['1080p']).to.be.true
expect(data.live.transcoding.resolutions['2160p']).to.be.true
expect(data.live.transcoding.alwaysTranscodeOriginalResolution).to.be.false
2022-03-22 15:58:49 +00:00
expect(data.videoStudio.enabled).to.be.true
2022-02-11 09:51:33 +00:00
expect(data.import.videos.concurrency).to.equal(4)
2018-08-03 09:10:31 +00:00
expect(data.import.videos.http.enabled).to.be.false
2018-08-07 08:07:53 +00:00
expect(data.import.videos.torrent.enabled).to.be.false
expect(data.autoBlacklist.videos.ofUsers.enabled).to.be.true
2019-04-08 12:04:57 +00:00
expect(data.followers.instance.enabled).to.be.false
expect(data.followers.instance.manualApproval).to.be.true
expect(data.followings.instance.autoFollowBack.enabled).to.be.true
expect(data.followings.instance.autoFollowIndex.enabled).to.be.true
expect(data.followings.instance.autoFollowIndex.indexUrl).to.equal('https://updated.example.com')
2020-05-28 09:15:38 +00:00
expect(data.broadcastMessage.enabled).to.be.true
expect(data.broadcastMessage.level).to.equal('error')
expect(data.broadcastMessage.message).to.equal('super bad message')
expect(data.broadcastMessage.dismissable).to.be.true
2018-07-12 17:02:00 +00:00
}
const newCustomConfig: CustomConfig = {
instance: {
name: 'PeerTube updated',
shortDescription: 'my short description',
description: 'my super description',
terms: 'my super terms',
codeOfConduct: 'my super coc',
creationReason: 'my super creation reason',
moderationInformation: 'my super moderation information',
administrator: 'Kuja',
maintenanceLifetime: 'forever',
businessModel: 'my super business model',
hardwareInformation: '2vCore 3GB RAM',
languages: [ 'en', 'es' ],
categories: [ 1, 2 ],
isNSFW: true,
defaultNSFWPolicy: 'blur' as 'blur',
defaultClientRoute: '/videos/recently-added',
customizations: {
javascript: 'alert("coucou")',
css: 'body { background-color: red; }'
}
},
theme: {
default: 'default'
},
services: {
twitter: {
username: '@Kuja',
whitelisted: true
}
},
client: {
videos: {
miniature: {
preferAuthorDisplayName: true
}
},
menu: {
login: {
redirectOnSingleExternalAuth: true
}
}
},
cache: {
previews: {
size: 2
},
captions: {
size: 3
},
torrents: {
size: 4
}
},
signup: {
enabled: false,
limit: 5,
2023-01-19 08:28:29 +00:00
requiresApproval: false,
requiresEmailVerification: false,
minimumAge: 10
},
admin: {
email: 'superadmin1@example.com'
},
contactForm: {
enabled: false
},
user: {
videoQuota: 5242881,
videoQuotaDaily: 318742
},
videoChannels: {
maxPerUser: 24
},
transcoding: {
enabled: true,
allowAdditionalExtensions: true,
allowAudioFiles: true,
threads: 1,
concurrency: 3,
profile: 'vod_profile',
resolutions: {
'0p': false,
'144p': false,
'240p': false,
'360p': true,
'480p': true,
'720p': false,
'1080p': false,
'1440p': false,
'2160p': false
},
alwaysTranscodeOriginalResolution: false,
webtorrent: {
enabled: true
},
hls: {
enabled: false
}
},
live: {
enabled: true,
allowReplay: true,
2022-03-04 12:40:02 +00:00
latencySetting: {
enabled: false
},
maxDuration: 5000,
maxInstanceLives: -1,
maxUserLives: 10,
transcoding: {
enabled: true,
threads: 4,
profile: 'live_profile',
resolutions: {
'144p': true,
'240p': true,
'360p': true,
'480p': true,
'720p': true,
'1080p': true,
'1440p': true,
'2160p': true
},
alwaysTranscodeOriginalResolution: false
}
},
2022-03-22 15:58:49 +00:00
videoStudio: {
2022-02-11 09:51:33 +00:00
enabled: true
},
import: {
videos: {
concurrency: 4,
http: {
enabled: false
},
torrent: {
enabled: false
}
Channel sync (#5135) * Add external channel URL for channel update / creation (#754) * Disallow synchronisation if user has no video quota (#754) * More constraints serverside (#754) * Disable sync if server configuration does not allow HTTP import (#754) * Working version synchronizing videos with a job (#754) TODO: refactoring, too much code duplication * More logs and try/catch (#754) * Fix eslint error (#754) * WIP: support synchronization time change (#754) * New frontend #754 * WIP: Create sync front (#754) * Enhance UI, sync creation form (#754) * Warning message when HTTP upload is disallowed * More consistent names (#754) * Binding Front with API (#754) * Add a /me API (#754) * Improve list UI (#754) * Implement creation and deletion routes (#754) * Lint (#754) * Lint again (#754) * WIP: UI for triggering import existing videos (#754) * Implement jobs for syncing and importing channels * Don't sync videos before sync creation + avoid concurrency issue (#754) * Cleanup (#754) * Cleanup: OpenAPI + API rework (#754) * Remove dead code (#754) * Eslint (#754) * Revert the mess with whitespaces in constants.ts (#754) * Some fixes after rebase (#754) * Several fixes after PR remarks (#754) * Front + API: Rename video-channels-sync to video-channel-syncs (#754) * Allow enabling channel sync through UI (#754) * getChannelInfo (#754) * Minor fixes: openapi + model + sql (#754) * Simplified API validators (#754) * Rename MChannelSync to MChannelSyncChannel (#754) * Add command for VideoChannelSync (#754) * Use synchronization.enabled config (#754) * Check parameters test + some fixes (#754) * Fix conflict mistake (#754) * Restrict access to video channel sync list API (#754) * Start adding unit test for synchronization (#754) * Continue testing (#754) * Tests finished + convertion of job to scheduler (#754) * Add lastSyncAt field (#754) * Fix externalRemoteUrl sort + creation date not well formatted (#754) * Small fix (#754) * Factorize addYoutubeDLImport and buildVideo (#754) * Check duplicates on channel not on users (#754) * factorize thumbnail generation (#754) * Fetch error should return status 400 (#754) * Separate video-channel-import and video-channel-sync-latest (#754) * Bump DB migration version after rebase (#754) * Prettier states in UI table (#754) * Add DefaultScope in VideoChannelSyncModel (#754) * Fix audit logs (#754) * Ensure user can upload when importing channel + minor fixes (#754) * Mark synchronization as failed on exception + typos (#754) * Change REST API for importing videos into channel (#754) * Add option for fully synchronize a chnanel (#754) * Return a whole sync object on creation to avoid tricks in Front (#754) * Various remarks (#754) * Single quotes by default (#754) * Rename synchronization to video_channel_synchronization * Add check.latest_videos_count and max_per_user options (#754) * Better channel rendering in list #754 * Allow sorting with channel name and state (#754) * Add missing tests for channel imports (#754) * Prefer using a parent job for channel sync * Styling * Client styling Co-authored-by: Chocobozzz <me@florianbigard.com>
2022-08-10 07:53:39 +00:00
},
videoChannelSynchronization: {
enabled: false,
maxPerUser: 10
}
},
trending: {
videos: {
algorithms: {
enabled: [ 'hot', 'most-viewed', 'most-liked' ],
default: 'hot'
}
}
},
autoBlacklist: {
videos: {
ofUsers: {
enabled: true
}
}
},
followers: {
instance: {
enabled: false,
manualApproval: true
}
},
followings: {
instance: {
autoFollowBack: {
enabled: true
},
autoFollowIndex: {
enabled: true,
indexUrl: 'https://updated.example.com'
}
}
},
broadcastMessage: {
enabled: true,
level: 'error',
message: 'super bad message',
dismissable: true
},
search: {
remoteUri: {
anonymous: true,
users: true
},
searchIndex: {
enabled: true,
url: 'https://search.joinpeertube.org',
disableLocalSearch: true,
isDefaultSearch: true
}
}
}
describe('Test static config', function () {
let server: PeerTubeServer = null
before(async function () {
this.timeout(30000)
2021-10-14 09:35:43 +00:00
server = await createSingleServer(1, { webadmin: { configuration: { edition: { allowed: false } } } })
await setAccessTokensToServers([ server ])
})
it('Should tell the client that edits are not allowed', async function () {
const data = await server.config.getConfig()
2021-10-14 09:35:43 +00:00
expect(data.webadmin.configuration.edition.allowed).to.be.false
})
it('Should error when client tries to update', async function () {
await server.config.updateCustomConfig({ newCustomConfig, expectedStatus: 405 })
})
2021-10-13 09:52:42 +00:00
after(async function () {
await cleanupTests([ server ])
})
})
2017-09-04 19:21:47 +00:00
describe('Test config', function () {
2021-07-16 07:47:51 +00:00
let server: PeerTubeServer = null
2017-09-04 19:21:47 +00:00
before(async function () {
2018-01-18 17:10:45 +00:00
this.timeout(30000)
2019-04-26 06:50:52 +00:00
2021-07-16 07:47:51 +00:00
server = await createSingleServer(1)
await setAccessTokensToServers([ server ])
2017-09-04 19:21:47 +00:00
})
it('Should have a correct config on a server with registration enabled', async function () {
2021-07-16 07:04:35 +00:00
const data = await server.config.getConfig()
2017-09-04 19:21:47 +00:00
expect(data.signup.allowed).to.be.true
})
it('Should have a correct config on a server with registration enabled and a users limit', async function () {
2017-11-24 13:39:14 +00:00
this.timeout(5000)
2017-11-16 17:40:50 +00:00
await Promise.all([
2023-01-19 08:28:29 +00:00
server.registrations.register({ username: 'user1' }),
server.registrations.register({ username: 'user2' }),
server.registrations.register({ username: 'user3' })
2017-11-16 17:40:50 +00:00
])
2017-09-04 19:21:47 +00:00
2021-07-16 07:04:35 +00:00
const data = await server.config.getConfig()
2017-09-04 19:21:47 +00:00
expect(data.signup.allowed).to.be.false
})
2018-12-11 13:52:50 +00:00
it('Should have the correct video allowed extensions', async function () {
2021-07-16 07:04:35 +00:00
const data = await server.config.getConfig()
2018-12-11 13:52:50 +00:00
expect(data.video.file.extensions).to.have.lengthOf(3)
expect(data.video.file.extensions).to.contain('.mp4')
expect(data.video.file.extensions).to.contain('.webm')
expect(data.video.file.extensions).to.contain('.ogv')
2019-01-09 14:14:29 +00:00
2021-07-16 07:04:35 +00:00
await server.videos.upload({ attributes: { fixture: 'video_short.mkv' }, expectedStatus: HttpStatusCode.UNSUPPORTED_MEDIA_TYPE_415 })
await server.videos.upload({ attributes: { fixture: 'sample.ogg' }, expectedStatus: HttpStatusCode.UNSUPPORTED_MEDIA_TYPE_415 })
2019-05-17 09:56:12 +00:00
2019-01-09 14:14:29 +00:00
expect(data.contactForm.enabled).to.be.true
2018-12-11 13:52:50 +00:00
})
it('Should get the customized configuration', async function () {
2021-07-16 07:04:35 +00:00
const data = await server.config.getCustomConfig()
2019-04-26 06:50:52 +00:00
checkInitialConfig(server, data)
})
it('Should update the customized configuration', async function () {
2021-07-16 07:04:35 +00:00
await server.config.updateCustomConfig({ newCustomConfig })
2021-07-16 07:04:35 +00:00
const data = await server.config.getCustomConfig()
2018-07-12 17:02:00 +00:00
checkUpdatedConfig(data)
})
2018-12-11 13:52:50 +00:00
it('Should have the correct updated video allowed extensions', async function () {
2022-09-12 06:29:01 +00:00
this.timeout(30000)
2021-07-16 07:04:35 +00:00
const data = await server.config.getConfig()
2018-12-11 13:52:50 +00:00
expect(data.video.file.extensions).to.have.length.above(4)
2018-12-11 13:52:50 +00:00
expect(data.video.file.extensions).to.contain('.mp4')
expect(data.video.file.extensions).to.contain('.webm')
expect(data.video.file.extensions).to.contain('.ogv')
expect(data.video.file.extensions).to.contain('.flv')
expect(data.video.file.extensions).to.contain('.wmv')
2018-12-11 13:52:50 +00:00
expect(data.video.file.extensions).to.contain('.mkv')
2019-05-17 09:56:12 +00:00
expect(data.video.file.extensions).to.contain('.mp3')
expect(data.video.file.extensions).to.contain('.ogg')
expect(data.video.file.extensions).to.contain('.flac')
2021-07-16 07:04:35 +00:00
await server.videos.upload({ attributes: { fixture: 'video_short.mkv' }, expectedStatus: HttpStatusCode.OK_200 })
await server.videos.upload({ attributes: { fixture: 'sample.ogg' }, expectedStatus: HttpStatusCode.OK_200 })
2018-12-11 13:52:50 +00:00
})
it('Should have the configuration updated after a restart', async function () {
2021-09-07 06:33:58 +00:00
this.timeout(30000)
2018-01-19 12:58:13 +00:00
2021-07-09 13:37:43 +00:00
await killallServers([ server ])
2021-07-16 07:47:51 +00:00
await server.run()
2021-07-16 07:04:35 +00:00
const data = await server.config.getCustomConfig()
2018-07-12 17:02:00 +00:00
checkUpdatedConfig(data)
})
2018-01-31 16:47:36 +00:00
it('Should fetch the about information', async function () {
2021-07-16 07:04:35 +00:00
const data = await server.config.getAbout()
2018-01-31 16:47:36 +00:00
expect(data.instance.name).to.equal('PeerTube updated')
2018-03-15 13:31:08 +00:00
expect(data.instance.shortDescription).to.equal('my short description')
2018-01-31 16:47:36 +00:00
expect(data.instance.description).to.equal('my super description')
expect(data.instance.terms).to.equal('my super terms')
expect(data.instance.codeOfConduct).to.equal('my super coc')
expect(data.instance.creationReason).to.equal('my super creation reason')
expect(data.instance.moderationInformation).to.equal('my super moderation information')
expect(data.instance.administrator).to.equal('Kuja')
expect(data.instance.maintenanceLifetime).to.equal('forever')
expect(data.instance.businessModel).to.equal('my super business model')
expect(data.instance.hardwareInformation).to.equal('2vCore 3GB RAM')
expect(data.instance.languages).to.deep.equal([ 'en', 'es' ])
expect(data.instance.categories).to.deep.equal([ 1, 2 ])
2018-01-31 16:47:36 +00:00
})
it('Should remove the custom configuration', async function () {
2021-07-16 07:04:35 +00:00
await server.config.deleteCustomConfig()
2021-07-16 07:04:35 +00:00
const data = await server.config.getCustomConfig()
2019-04-26 06:50:52 +00:00
checkInitialConfig(server, data)
})
2023-02-27 08:22:59 +00:00
it('Should enable/disable security headers', async function () {
2021-04-12 13:33:54 +00:00
this.timeout(25000)
{
const res = await makeGetRequest({
url: server.url,
path: '/api/v1/config',
2021-07-16 08:42:24 +00:00
expectedStatus: 200
2021-04-12 13:33:54 +00:00
})
expect(res.headers['x-frame-options']).to.exist
2023-02-27 08:22:59 +00:00
expect(res.headers['x-powered-by']).to.equal('PeerTube')
2021-04-12 13:33:54 +00:00
}
2021-07-09 13:37:43 +00:00
await killallServers([ server ])
2021-04-12 13:33:54 +00:00
const config = {
security: {
2023-02-27 08:22:59 +00:00
frameguard: { enabled: false },
powered_by_header: { enabled: false }
2021-04-12 13:33:54 +00:00
}
}
2021-07-16 07:47:51 +00:00
await server.run(config)
2021-04-12 13:33:54 +00:00
{
const res = await makeGetRequest({
url: server.url,
path: '/api/v1/config',
2021-07-16 08:42:24 +00:00
expectedStatus: 200
2021-04-12 13:33:54 +00:00
})
expect(res.headers['x-frame-options']).to.not.exist
2023-02-27 08:22:59 +00:00
expect(res.headers['x-powered-by']).to.not.exist
2021-04-12 13:33:54 +00:00
}
})
2019-04-24 13:10:37 +00:00
after(async function () {
await cleanupTests([ server ])
2017-09-04 19:21:47 +00:00
})
})