mirror of
https://github.com/DIYgod/RSSHub.git
synced 2025-12-11 15:47:48 +08:00
test: middleware/template
This commit is contained in:
@@ -10,7 +10,7 @@ afterAll(() => {
|
||||
|
||||
describe('filter', () => {
|
||||
it(`filter`, async () => {
|
||||
const response = await request.get('/test/1?filter=Item4|Title5');
|
||||
const response = await request.get('/test/1?filter=Description4|Title5');
|
||||
const parsed = await parser.parseString(response.text);
|
||||
expect(parsed.items.length).toBe(2);
|
||||
expect(parsed.items[0].title).toBe('Title4');
|
||||
@@ -18,14 +18,14 @@ describe('filter', () => {
|
||||
});
|
||||
|
||||
it(`filter_title`, async () => {
|
||||
const response = await request.get('/test/1?filter_title=Item4|Title5');
|
||||
const response = await request.get('/test/1?filter_title=Description4|Title5');
|
||||
const parsed = await parser.parseString(response.text);
|
||||
expect(parsed.items.length).toBe(1);
|
||||
expect(parsed.items[0].title).toBe('Title5');
|
||||
});
|
||||
|
||||
it(`filter_description`, async () => {
|
||||
const response = await request.get('/test/1?filter_description=Item4|Title5');
|
||||
const response = await request.get('/test/1?filter_description=Description4|Title5');
|
||||
const parsed = await parser.parseString(response.text);
|
||||
expect(parsed.items.length).toBe(1);
|
||||
expect(parsed.items[0].title).toBe('Title4');
|
||||
@@ -40,7 +40,7 @@ describe('filter', () => {
|
||||
});
|
||||
|
||||
it(`filterout`, async () => {
|
||||
const response = await request.get('/test/1?filterout=Item4|Title5');
|
||||
const response = await request.get('/test/1?filterout=Description4|Title5');
|
||||
const parsed = await parser.parseString(response.text);
|
||||
expect(parsed.items.length).toBe(3);
|
||||
expect(parsed.items[0].title).toBe('Title1');
|
||||
@@ -49,7 +49,7 @@ describe('filter', () => {
|
||||
});
|
||||
|
||||
it(`filterout_title`, async () => {
|
||||
const response = await request.get('/test/1?filterout_title=Item4|Title5');
|
||||
const response = await request.get('/test/1?filterout_title=Description4|Title5');
|
||||
const parsed = await parser.parseString(response.text);
|
||||
expect(parsed.items.length).toBe(4);
|
||||
expect(parsed.items[0].title).toBe('Title1');
|
||||
@@ -59,7 +59,7 @@ describe('filter', () => {
|
||||
});
|
||||
|
||||
it(`filterout_description`, async () => {
|
||||
const response = await request.get('/test/1?filterout_description=Item4|Title5');
|
||||
const response = await request.get('/test/1?filterout_description=Description4|Title5');
|
||||
const parsed = await parser.parseString(response.text);
|
||||
expect(parsed.items.length).toBe(4);
|
||||
expect(parsed.items[0].title).toBe('Title1');
|
||||
|
||||
67
test/middleware/template.js
Normal file
67
test/middleware/template.js
Normal file
@@ -0,0 +1,67 @@
|
||||
const supertest = require('supertest');
|
||||
const { server } = require('../../lib/index');
|
||||
const request = supertest(server);
|
||||
const Parser = require('rss-parser');
|
||||
const parser = new Parser();
|
||||
|
||||
afterAll(() => {
|
||||
server.close();
|
||||
});
|
||||
|
||||
describe('template', () => {
|
||||
it(`.rss`, async () => {
|
||||
const response1 = await request.get('/test/1.rss');
|
||||
const parsed1 = await parser.parseString(response1.text);
|
||||
|
||||
expect(parsed1).toEqual(expect.any(Object));
|
||||
expect(parsed1.title).toEqual(expect.any(String));
|
||||
expect(parsed1.description).toEqual(expect.any(String));
|
||||
expect(parsed1.link).toEqual(expect.any(String));
|
||||
expect(parsed1.lastBuildDate).toEqual(expect.any(String));
|
||||
expect(parsed1.ttl).toEqual(expect.any(String));
|
||||
expect(parsed1.items).toEqual(expect.any(Array));
|
||||
|
||||
expect(parsed1.items[0]).toEqual(expect.any(Object));
|
||||
expect(parsed1.items[0].title).toEqual(expect.any(String));
|
||||
expect(parsed1.items[0].link).toEqual(expect.any(String));
|
||||
expect(parsed1.items[0].pubDate).toEqual(expect.any(String));
|
||||
expect(parsed1.items[0].author).toEqual(expect.any(String));
|
||||
expect(parsed1.items[0].content).toEqual(expect.any(String));
|
||||
expect(parsed1.items[0].guid).toEqual(expect.any(String));
|
||||
|
||||
const response2 = await request.get('/test/1');
|
||||
const parsed2 = await parser.parseString(response2.text);
|
||||
expect(parsed2).toMatchObject(parsed1);
|
||||
});
|
||||
|
||||
it(`.atom`, async () => {
|
||||
const response = await request.get('/test/1.atom');
|
||||
const parsed = await parser.parseString(response.text);
|
||||
|
||||
expect(parsed).toEqual(expect.any(Object));
|
||||
expect(parsed.title).toEqual(expect.any(String));
|
||||
expect(parsed.link).toEqual(expect.any(String));
|
||||
expect(parsed.lastBuildDate).toEqual(expect.any(String));
|
||||
expect(parsed.items).toEqual(expect.any(Array));
|
||||
|
||||
expect(parsed.items[0]).toEqual(expect.any(Object));
|
||||
expect(parsed.items[0].title).toEqual(expect.any(String));
|
||||
expect(parsed.items[0].link).toEqual(expect.any(String));
|
||||
expect(parsed.items[0].pubDate).toEqual(expect.any(String));
|
||||
expect(parsed.items[0].author).toEqual(expect.any(String));
|
||||
expect(parsed.items[0].content).toEqual(expect.any(String));
|
||||
expect(parsed.items[0].id).toEqual(expect.any(String));
|
||||
});
|
||||
|
||||
it(`.json`, async () => {
|
||||
const response = await request.get('/test/1.json');
|
||||
expect(response.status).toBe(404);
|
||||
expect(response.text).toMatch(/RSSHub 发生了一些意外: <pre>Error: <b>JSON output had been removed/);
|
||||
});
|
||||
|
||||
it(`long title`, async () => {
|
||||
const response = await request.get('/test/long');
|
||||
const parsed = await parser.parseString(response.text);
|
||||
expect(parsed.items[0].title.length).toBe(103);
|
||||
});
|
||||
});
|
||||
@@ -24,6 +24,7 @@ async function checkRSS(response) {
|
||||
expect(parsed.description).toEqual(expect.any(String));
|
||||
expect(parsed.link).toEqual(expect.any(String));
|
||||
expect(parsed.lastBuildDate).toEqual(expect.any(String));
|
||||
expect(parsed.ttl).toEqual(config.cacheExpire);
|
||||
expect(parsed.items).toEqual(expect.any(Array));
|
||||
checkDate(parsed.lastBuildDate);
|
||||
|
||||
|
||||
@@ -13,5 +13,5 @@ describe('puppeteer', () => {
|
||||
expect(html.length).toBeGreaterThan(0);
|
||||
|
||||
await browser.close();
|
||||
});
|
||||
}, 10000);
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user