X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fmisc-endpoints.ts;h=09e5afcf9b4bc6c9fc58eb3032638f3798d520da;hb=8b9a5ce597f8639f4c465f577f465df1656677b2;hp=32b035c9ef63f15ab1d9f7ef160a24c6264a03f6;hpb=2ad9dcda240ee843c5e4a5b98cc94f7b2aab2c89;p=github%2FChocobozzz%2FPeerTube.git
diff --git a/server/tests/misc-endpoints.ts b/server/tests/misc-endpoints.ts
index 32b035c9e..09e5afcf9 100644
--- a/server/tests/misc-endpoints.ts
+++ b/server/tests/misc-endpoints.ts
@@ -13,6 +13,7 @@ import {
uploadVideo
} from '../../shared/extra-utils'
import { VideoPrivacy } from '../../shared/models/videos'
+import { HttpStatusCode } from '@shared/core-utils'
const expect = chai.expect
@@ -32,7 +33,7 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/.well-known/security.txt',
- statusCodeExpected: 200
+ statusCodeExpected: HttpStatusCode.OK_200
})
expect(res.text).to.contain('security issue')
@@ -42,7 +43,7 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/.well-known/nodeinfo',
- statusCodeExpected: 200
+ statusCodeExpected: HttpStatusCode.OK_200
})
expect(res.body.links).to.be.an('array')
@@ -54,7 +55,7 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/.well-known/dnt-policy.txt',
- statusCodeExpected: 200
+ statusCodeExpected: HttpStatusCode.OK_200
})
expect(res.text).to.contain('http://www.w3.org/TR/tracking-dnt')
@@ -64,7 +65,7 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/.well-known/dnt',
- statusCodeExpected: 200
+ statusCodeExpected: HttpStatusCode.OK_200
})
expect(res.body.tracking).to.equal('N')
@@ -74,11 +75,36 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/.well-known/change-password',
- statusCodeExpected: 302
+ 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 () {
@@ -87,7 +113,7 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/robots.txt',
- statusCodeExpected: 200
+ statusCodeExpected: HttpStatusCode.OK_200
})
expect(res.text).to.contain('User-agent')
@@ -97,7 +123,7 @@ describe('Test misc endpoints', function () {
await makeGetRequest({
url: server.url,
path: '/security.txt',
- statusCodeExpected: 301
+ statusCodeExpected: HttpStatusCode.MOVED_PERMANENTLY_301
})
})
@@ -105,10 +131,12 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/nodeinfo/2.0.json',
- statusCodeExpected: 200
+ 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)
})
})
@@ -118,22 +146,22 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/sitemap.xml',
- statusCodeExpected: 200
+ statusCodeExpected: 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('http://localhost:' + server.port + '/about/instance')
})
it('Should get the empty cached sitemap', async function () {
const res = await makeGetRequest({
url: server.url,
path: '/sitemap.xml',
- statusCodeExpected: 200
+ statusCodeExpected: 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('http://localhost:' + server.port + '/about/instance')
})
it('Should add videos, channel and accounts and get sitemap', async function () {
@@ -152,21 +180,21 @@ describe('Test misc endpoints', function () {
const res = await makeGetRequest({
url: server.url,
path: '/sitemap.xml?t=1', // avoid using cache
- statusCodeExpected: 200
+ statusCodeExpected: 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('http://localhost:' + server.port + '/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('http://localhost:9001/video-channels/channel1')
- expect(res.text).to.contain('http://localhost:9001/video-channels/channel2')
+ expect(res.text).to.contain('http://localhost:' + server.port + '/video-channels/channel1')
+ expect(res.text).to.contain('http://localhost:' + server.port + '/video-channels/channel2')
- 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('http://localhost:' + server.port + '/accounts/user1')
+ expect(res.text).to.contain('http://localhost:' + server.port + '/accounts/user2')
})
})