From 966eb053131b052e7fc3b3b3adaf2d27ff05d7a3 Mon Sep 17 00:00:00 2001 From: Rigel Kent Date: Wed, 18 Apr 2018 16:08:36 +0200 Subject: feature: initial syndication feeds tests for instance-wide feeds --- server/tests/api/feeds/instance-feed.ts | 91 +++++++++++++++++++++++++++++++++ server/tests/api/index-slow.ts | 1 + server/tests/utils/feeds/feeds.ts | 30 +++++++++++ server/tests/utils/index.ts | 1 + 4 files changed, 123 insertions(+) create mode 100644 server/tests/api/feeds/instance-feed.ts create mode 100644 server/tests/utils/feeds/feeds.ts (limited to 'server/tests') diff --git a/server/tests/api/feeds/instance-feed.ts b/server/tests/api/feeds/instance-feed.ts new file mode 100644 index 000000000..e834e1db1 --- /dev/null +++ b/server/tests/api/feeds/instance-feed.ts @@ -0,0 +1,91 @@ +/* tslint:disable:no-unused-expression */ + +import * as chai from 'chai' +import 'mocha' +import { + getOEmbed, + getXMLfeed, + getJSONfeed, + flushTests, + killallServers, + ServerInfo, + setAccessTokensToServers, + uploadVideo, + flushAndRunMultipleServers, + wait +} from '../../utils' +import { runServer } from '../../utils/server/servers' +import { join } from 'path' +import * as libxmljs from 'libxmljs' + +chai.use(require('chai-xml')) +chai.use(require('chai-json-schema')) +chai.config.includeStack = true +const expect = chai.expect + +describe('Test instance-wide syndication feeds', () => { + let servers: ServerInfo[] = [] + + before(async function () { + this.timeout(30000) + + // Run servers + servers = await flushAndRunMultipleServers(2) + + await setAccessTokensToServers(servers) + + this.timeout(60000) + + const videoAttributes = { + name: 'my super name for server 1', + description: 'my super description for server 1', + fixture: 'video_short.webm' + } + await uploadVideo(servers[0].url, servers[0].accessToken, videoAttributes) + + await wait(10000) + }) + + it('should be well formed XML (covers RSS 2.0 and ATOM 1.0 endpoints)', async function () { + const rss = await getXMLfeed(servers[0].url) + expect(rss.text).xml.to.be.valid() + + const atom = await getXMLfeed(servers[0].url, 'atom') + expect(atom.text).xml.to.be.valid() + }) + + it('should be well formed JSON (covers JSON feed 1.0 endpoint)', async function () { + const json = await getJSONfeed(servers[0].url) + expect(JSON.parse(json.text)).to.be.jsonSchema({ 'type': 'object' }) + }) + + it('should contain a valid enclosure (covers RSS 2.0 endpoint)', async function () { + const rss = await getXMLfeed(servers[0].url) + const xmlDoc = libxmljs.parseXmlString(rss.text) + const xmlEnclosure = xmlDoc.get('/rss/channel/item/enclosure') + expect(xmlEnclosure).to.exist + expect(xmlEnclosure.attr('type').value()).to.be.equal('application/x-bittorrent') + expect(xmlEnclosure.attr('length').value()).to.be.equal('218910') + expect(xmlEnclosure.attr('url').value()).to.contain('720.torrent') + }) + + it('should contain a valid \'attachments\' object (covers JSON feed 1.0 endpoint)', async function () { + const json = await getJSONfeed(servers[0].url) + const jsonObj = JSON.parse(json.text) + expect(jsonObj.items.length).to.be.equal(1) + expect(jsonObj.items[0].attachments).to.exist + expect(jsonObj.items[0].attachments.length).to.be.eq(1) + expect(jsonObj.items[0].attachments[0].mime_type).to.be.eq('application/x-bittorrent') + expect(jsonObj.items[0].attachments[0].size_in_bytes).to.be.eq(218910) + expect(jsonObj.items[0].attachments[0].url).to.contain('720.torrent') + }) + + after(async function () { + killallServers(servers) + + // Keep the logs if the test failed + if (this['ok']) { + await flushTests() + } + }) +}) diff --git a/server/tests/api/index-slow.ts b/server/tests/api/index-slow.ts index cde546856..5f2f26095 100644 --- a/server/tests/api/index-slow.ts +++ b/server/tests/api/index-slow.ts @@ -1,5 +1,6 @@ // Order of the tests we want to execute import './videos/video-transcoder' +import './feeds/instance-feed' import './videos/multiple-servers' import './server/follows' import './server/jobs' diff --git a/server/tests/utils/feeds/feeds.ts b/server/tests/utils/feeds/feeds.ts new file mode 100644 index 000000000..20e68cf3d --- /dev/null +++ b/server/tests/utils/feeds/feeds.ts @@ -0,0 +1,30 @@ +import * as request from 'supertest' +import { readFileBufferPromise } from '../../../helpers/core-utils' + +function getXMLfeed (url: string, format?: string) { + const path = '/feeds/videos.xml' + + return request(url) + .get(path) + .query((format) ? { format: format } : {}) + .set('Accept', 'application/xml') + .expect(200) + .expect('Content-Type', /xml/) +} + +function getJSONfeed (url: string) { + const path = '/feeds/videos.json' + + return request(url) + .get(path) + .set('Accept', 'application/json') + .expect(200) + .expect('Content-Type', /json/) +} + +// --------------------------------------------------------------------------- + +export { + getXMLfeed, + getJSONfeed +} diff --git a/server/tests/utils/index.ts b/server/tests/utils/index.ts index d7789e517..5b560ca39 100644 --- a/server/tests/utils/index.ts +++ b/server/tests/utils/index.ts @@ -13,3 +13,4 @@ export * from './videos/video-abuses' export * from './videos/video-blacklist' export * from './videos/video-channels' export * from './videos/videos' +export * from './feeds/feeds' -- cgit v1.2.3