X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fmisc-endpoints.ts;h=f9cf2b717cd6ec974aee35331e0fb9774154fbc1;hb=2401ab9817b664be5dfc73c4d950e563e3ab3dfb;hp=d78b62d60c35186fb4e8f86b03a5fc8b030075a6;hpb=94565d52bb2883e09f16d1363170ac9c0dccb7a1;p=github%2FChocobozzz%2FPeerTube.git
diff --git a/server/tests/misc-endpoints.ts b/server/tests/misc-endpoints.ts
index d78b62d60..f9cf2b717 100644
--- a/server/tests/misc-endpoints.ts
+++ b/server/tests/misc-endpoints.ts
@@ -1,32 +1,24 @@
-/* tslint:disable:no-unused-expression */
-
-import 'mocha'
-import * as chai from 'chai'
-import {
- addVideoChannel,
- createUser,
- flushTests,
- killallServers,
- makeGetRequest,
- runServer,
- ServerInfo,
- setAccessTokensToServers,
- uploadVideo
-} from '../../shared/extra-utils'
-import { VideoPrivacy } from '../../shared/models/videos'
-
-const expect = chai.expect
+/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
+
+import { expect } from 'chai'
+import { writeJson } from 'fs-extra'
+import { join } from 'path'
+import { HttpStatusCode, VideoPrivacy } from '@shared/models'
+import { cleanupTests, createSingleServer, makeGetRequest, PeerTubeServer, setAccessTokensToServers } from '@shared/server-commands'
+import { expectLogDoesNotContain } from './shared'
describe('Test misc endpoints', function () {
- let server: ServerInfo
+ let server: PeerTubeServer
+ let wellKnownPath: string
before(async function () {
this.timeout(120000)
- await flushTests()
+ server = await createSingleServer(1)
- server = await runServer(1)
await setAccessTokensToServers([ server ])
+
+ wellKnownPath = server.getDirectoryPath('well-known')
})
describe('Test a well known endpoints', function () {
@@ -35,7 +27,7 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/.well-known/security.txt',
- statusCodeExpected: 200
+ expectedStatus: HttpStatusCode.OK_200
})
expect(res.text).to.contain('security issue')
@@ -45,7 +37,7 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/.well-known/nodeinfo',
- statusCodeExpected: 200
+ expectedStatus: HttpStatusCode.OK_200
})
expect(res.body.links).to.be.an('array')
@@ -57,7 +49,7 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/.well-known/dnt-policy.txt',
- statusCodeExpected: 200
+ expectedStatus: HttpStatusCode.OK_200
})
expect(res.text).to.contain('http://www.w3.org/TR/tracking-dnt')
@@ -67,7 +59,7 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/.well-known/dnt',
- statusCodeExpected: 200
+ expectedStatus: HttpStatusCode.OK_200
})
expect(res.body.tracking).to.equal('N')
@@ -77,11 +69,58 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/.well-known/change-password',
- statusCodeExpected: 302
+ expectedStatus: 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,
+ expectedStatus: 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}')
+ })
+
+ it('Should return 404 for non-existing files in /.well-known', async function () {
+ await makeGetRequest({
+ url: server.url,
+ path: '/.well-known/non-existing-file',
+ expectedStatus: HttpStatusCode.NOT_FOUND_404
+ })
+ })
+
+ it('Should return custom file from /.well-known', async function () {
+ const filename = 'existing-file.json'
+
+ await writeJson(join(wellKnownPath, filename), { iThink: 'therefore I am' })
+
+ const { body } = await makeGetRequest({
+ url: server.url,
+ path: '/.well-known/' + filename,
+ expectedStatus: HttpStatusCode.OK_200
+ })
+
+ expect(body.iThink).to.equal('therefore I am')
+ })
})
describe('Test classic static endpoints', function () {
@@ -90,7 +129,7 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/robots.txt',
- statusCodeExpected: 200
+ expectedStatus: HttpStatusCode.OK_200
})
expect(res.text).to.contain('User-agent')
@@ -100,7 +139,7 @@ describe('Test misc endpoints', function () {
await makeGetRequest({
url: server.url,
path: '/security.txt',
- statusCodeExpected: 301
+ expectedStatus: HttpStatusCode.MOVED_PERMANENTLY_301
})
})
@@ -108,10 +147,12 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/nodeinfo/2.0.json',
- statusCodeExpected: 200
+ expectedStatus: 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)
})
})
@@ -121,59 +162,76 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/sitemap.xml',
- statusCodeExpected: 200
+ expectedStatus: HttpStatusCode.OK_200
})
expect(res.text).to.contain('xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"')
- expect(res.text).to.contain('http://localhost:9001/about/instance')
+ expect(res.text).to.contain('' + server.url + '/about/instance')
})
it('Should get the empty cached sitemap', async function () {
const res = await makeGetRequest({
url: server.url,
path: '/sitemap.xml',
- statusCodeExpected: 200
+ expectedStatus: HttpStatusCode.OK_200
})
expect(res.text).to.contain('xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"')
- expect(res.text).to.contain('http://localhost:9001/about/instance')
+ expect(res.text).to.contain('' + server.url + '/about/instance')
})
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 server.videos.upload({ attributes: { name: 'video 1', nsfw: false } })
+ await server.videos.upload({ attributes: { name: 'video 2', nsfw: false } })
+ await server.videos.upload({ attributes: { 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 server.channels.create({ attributes: { name: 'channel1', displayName: 'channel 1' } })
+ await server.channels.create({ attributes: { 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' })
+ await server.users.create({ username: 'user1', password: 'password' })
+ await server.users.create({ username: 'user2', password: 'password' })
const res = await makeGetRequest({
url: server.url,
path: '/sitemap.xml?t=1', // avoid using cache
- statusCodeExpected: 200
+ expectedStatus: HttpStatusCode.OK_200
})
expect(res.text).to.contain('xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"')
- expect(res.text).to.contain('http://localhost:9001/about/instance')
+ expect(res.text).to.contain('' + server.url + '/about/instance')
+
+ expect(res.text).to.contain('video 1')
+ expect(res.text).to.contain('video 2')
+ expect(res.text).to.not.contain('video 3')
- expect(res.text).to.contain('')
- expect(res.text).to.contain('')
- expect(res.text).to.not.contain('')
+ expect(res.text).to.contain('' + server.url + '/video-channels/channel1')
+ expect(res.text).to.contain('' + server.url + '/video-channels/channel2')
+
+ expect(res.text).to.contain('' + server.url + '/accounts/user1')
+ expect(res.text).to.contain('' + server.url + '/accounts/user2')
+ })
+
+ it('Should not fail with big title/description videos', async function () {
+ const name = 'v'.repeat(115)
+
+ await server.videos.upload({ attributes: { name, description: 'd'.repeat(2500), nsfw: false } })
+
+ const res = await makeGetRequest({
+ url: server.url,
+ path: '/sitemap.xml?t=2', // avoid using cache
+ expectedStatus: HttpStatusCode.OK_200
+ })
- expect(res.text).to.contain('http://localhost:9001/video-channels/channel1')
- expect(res.text).to.contain('http://localhost:9001/video-channels/channel2')
+ await expectLogDoesNotContain(server, 'Warning in sitemap generation')
+ await expectLogDoesNotContain(server, 'Error in sitemap generation')
- expect(res.text).to.contain('http://localhost:9001/accounts/user1')
- expect(res.text).to.contain('http://localhost:9001/accounts/user2')
+ expect(res.text).to.contain(`${'v'.repeat(97)}...`)
})
})
after(async function () {
- killallServers([ server ])
+ await cleanupTests([ server ])
})
})