123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204 |
- /* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
- import 'mocha'
- import * as chai from 'chai'
- import {
- addVideoChannel,
- cleanupTests,
- createUser,
- flushAndRunServer,
- makeGetRequest,
- ServerInfo,
- setAccessTokensToServers,
- uploadVideo
- } from '../../shared/extra-utils'
- import { VideoPrivacy } from '../../shared/models/videos'
- import { HttpStatusCode } from '@shared/core-utils'
- const expect = chai.expect
- describe('Test misc endpoints', function () {
- let server: ServerInfo
- before(async function () {
- this.timeout(120000)
- server = await flushAndRunServer(1)
- await setAccessTokensToServers([ server ])
- })
- describe('Test a well known endpoints', function () {
- it('Should get security.txt', async function () {
- const res = await makeGetRequest({
- url: server.url,
- path: '/.well-known/security.txt',
- statusCodeExpected: HttpStatusCode.OK_200
- })
- expect(res.text).to.contain('security issue')
- })
- it('Should get nodeinfo', async function () {
- const res = await makeGetRequest({
- url: server.url,
- path: '/.well-known/nodeinfo',
- statusCodeExpected: HttpStatusCode.OK_200
- })
- expect(res.body.links).to.be.an('array')
- expect(res.body.links).to.have.lengthOf(1)
- expect(res.body.links[0].rel).to.equal('http://nodeinfo.diaspora.software/ns/schema/2.0')
- })
- it('Should get dnt policy text', async function () {
- const res = await makeGetRequest({
- url: server.url,
- path: '/.well-known/dnt-policy.txt',
- statusCodeExpected: HttpStatusCode.OK_200
- })
- expect(res.text).to.contain('http://www.w3.org/TR/tracking-dnt')
- })
- it('Should get dnt policy', async function () {
- const res = await makeGetRequest({
- url: server.url,
- path: '/.well-known/dnt',
- statusCodeExpected: HttpStatusCode.OK_200
- })
- expect(res.body.tracking).to.equal('N')
- })
- it('Should get change-password location', async function () {
- const res = await makeGetRequest({
- url: server.url,
- path: '/.well-known/change-password',
- statusCodeExpected: HttpStatusCode.FOUND_302
- })
- expect(res.header.location).to.equal('/my-account/settings')
- })
- it('Should test webfinger', async function () {
- const resource = 'acct:peertube@' + server.host
- const accountUrl = server.url + '/accounts/peertube'
- const res = await makeGetRequest({
- url: server.url,
- path: '/.well-known/webfinger?resource=' + resource,
- statusCodeExpected: HttpStatusCode.OK_200
- })
- const data = res.body
- expect(data.subject).to.equal(resource)
- expect(data.aliases).to.contain(accountUrl)
- const self = data.links.find(l => l.rel === 'self')
- expect(self).to.exist
- expect(self.type).to.equal('application/activity+json')
- expect(self.href).to.equal(accountUrl)
- const remoteInteract = data.links.find(l => l.rel === 'http://ostatus.org/schema/1.0/subscribe')
- expect(remoteInteract).to.exist
- expect(remoteInteract.template).to.equal(server.url + '/remote-interaction?uri={uri}')
- })
- })
- describe('Test classic static endpoints', function () {
- it('Should get robots.txt', async function () {
- const res = await makeGetRequest({
- url: server.url,
- path: '/robots.txt',
- statusCodeExpected: HttpStatusCode.OK_200
- })
- expect(res.text).to.contain('User-agent')
- })
- it('Should get security.txt', async function () {
- await makeGetRequest({
- url: server.url,
- path: '/security.txt',
- statusCodeExpected: HttpStatusCode.MOVED_PERMANENTLY_301
- })
- })
- it('Should get nodeinfo', async function () {
- const res = await makeGetRequest({
- url: server.url,
- path: '/nodeinfo/2.0.json',
- statusCodeExpected: HttpStatusCode.OK_200
- })
- expect(res.body.software.name).to.equal('peertube')
- expect(res.body.usage.users.activeMonth).to.equal(1)
- expect(res.body.usage.users.activeHalfyear).to.equal(1)
- })
- })
- describe('Test bots endpoints', function () {
- it('Should get the empty sitemap', async function () {
- const res = await makeGetRequest({
- url: server.url,
- path: '/sitemap.xml',
- statusCodeExpected: HttpStatusCode.OK_200
- })
- expect(res.text).to.contain('xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"')
- expect(res.text).to.contain('<url><loc>http://localhost:' + server.port + '/about/instance</loc></url>')
- })
- it('Should get the empty cached sitemap', async function () {
- const res = await makeGetRequest({
- url: server.url,
- path: '/sitemap.xml',
- statusCodeExpected: HttpStatusCode.OK_200
- })
- expect(res.text).to.contain('xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"')
- expect(res.text).to.contain('<url><loc>http://localhost:' + server.port + '/about/instance</loc></url>')
- })
- it('Should add videos, channel and accounts and get sitemap', async function () {
- this.timeout(35000)
- await uploadVideo(server.url, server.accessToken, { name: 'video 1', nsfw: false })
- await uploadVideo(server.url, server.accessToken, { name: 'video 2', nsfw: false })
- await uploadVideo(server.url, server.accessToken, { name: 'video 3', privacy: VideoPrivacy.PRIVATE })
- await addVideoChannel(server.url, server.accessToken, { name: 'channel1', displayName: 'channel 1' })
- await addVideoChannel(server.url, server.accessToken, { name: 'channel2', displayName: 'channel 2' })
- await createUser({ url: server.url, accessToken: server.accessToken, username: 'user1', password: 'password' })
- await createUser({ url: server.url, accessToken: server.accessToken, username: 'user2', password: 'password' })
- const res = await makeGetRequest({
- url: server.url,
- path: '/sitemap.xml?t=1', // avoid using cache
- statusCodeExpected: HttpStatusCode.OK_200
- })
- expect(res.text).to.contain('xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"')
- expect(res.text).to.contain('<url><loc>http://localhost:' + server.port + '/about/instance</loc></url>')
- expect(res.text).to.contain('<video:title>video 1</video:title>')
- expect(res.text).to.contain('<video:title>video 2</video:title>')
- expect(res.text).to.not.contain('<video:title>video 3</video:title>')
- expect(res.text).to.contain('<url><loc>http://localhost:' + server.port + '/video-channels/channel1</loc></url>')
- expect(res.text).to.contain('<url><loc>http://localhost:' + server.port + '/video-channels/channel2</loc></url>')
- expect(res.text).to.contain('<url><loc>http://localhost:' + server.port + '/accounts/user1</loc></url>')
- expect(res.text).to.contain('<url><loc>http://localhost:' + server.port + '/accounts/user2</loc></url>')
- })
- })
- after(async function () {
- await cleanupTests([ server ])
- })
- })
|