audio-only.ts 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. /* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
  2. import 'mocha'
  3. import * as chai from 'chai'
  4. import { getAudioStream, getVideoStreamDimensionsInfo } from '@server/helpers/ffmpeg'
  5. import {
  6. cleanupTests,
  7. createMultipleServers,
  8. doubleFollow,
  9. PeerTubeServer,
  10. setAccessTokensToServers,
  11. waitJobs
  12. } from '@shared/server-commands'
  13. const expect = chai.expect
  14. describe('Test audio only video transcoding', function () {
  15. let servers: PeerTubeServer[] = []
  16. let videoUUID: string
  17. let webtorrentAudioFileUrl: string
  18. let fragmentedAudioFileUrl: string
  19. before(async function () {
  20. this.timeout(120000)
  21. const configOverride = {
  22. transcoding: {
  23. enabled: true,
  24. resolutions: {
  25. '0p': true,
  26. '144p': false,
  27. '240p': true,
  28. '360p': false,
  29. '480p': false,
  30. '720p': false,
  31. '1080p': false,
  32. '1440p': false,
  33. '2160p': false
  34. },
  35. hls: {
  36. enabled: true
  37. },
  38. webtorrent: {
  39. enabled: true
  40. }
  41. }
  42. }
  43. servers = await createMultipleServers(2, configOverride)
  44. // Get the access tokens
  45. await setAccessTokensToServers(servers)
  46. // Server 1 and server 2 follow each other
  47. await doubleFollow(servers[0], servers[1])
  48. })
  49. it('Should upload a video and transcode it', async function () {
  50. this.timeout(120000)
  51. const { uuid } = await servers[0].videos.upload({ attributes: { name: 'audio only' } })
  52. videoUUID = uuid
  53. await waitJobs(servers)
  54. for (const server of servers) {
  55. const video = await server.videos.get({ id: videoUUID })
  56. expect(video.streamingPlaylists).to.have.lengthOf(1)
  57. for (const files of [ video.files, video.streamingPlaylists[0].files ]) {
  58. expect(files).to.have.lengthOf(3)
  59. expect(files[0].resolution.id).to.equal(720)
  60. expect(files[1].resolution.id).to.equal(240)
  61. expect(files[2].resolution.id).to.equal(0)
  62. }
  63. if (server.serverNumber === 1) {
  64. webtorrentAudioFileUrl = video.files[2].fileUrl
  65. fragmentedAudioFileUrl = video.streamingPlaylists[0].files[2].fileUrl
  66. }
  67. }
  68. })
  69. it('0p transcoded video should not have video', async function () {
  70. const paths = [
  71. servers[0].servers.buildWebTorrentFilePath(webtorrentAudioFileUrl),
  72. servers[0].servers.buildFragmentedFilePath(videoUUID, fragmentedAudioFileUrl)
  73. ]
  74. for (const path of paths) {
  75. const { audioStream } = await getAudioStream(path)
  76. expect(audioStream['codec_name']).to.be.equal('aac')
  77. expect(audioStream['bit_rate']).to.be.at.most(384 * 8000)
  78. const size = await getVideoStreamDimensionsInfo(path)
  79. expect(size).to.not.exist
  80. }
  81. })
  82. after(async function () {
  83. await cleanupTests(servers)
  84. })
  85. })