summaryrefslogtreecommitdiff
path: root/test/fetch-resource.ts
diff options
context:
space:
mode:
authorMeiMei <30769358+mei23@users.noreply.github.com>2021-03-12 23:10:15 +0900
committerGitHub <noreply@github.com>2021-03-12 23:10:15 +0900
commit936fcfb1c7cee448b8e5036205aaf8843f8d8171 (patch)
tree5e8f7cb15f3064c60b2755b884e81f2226d6e5f2 /test/fetch-resource.ts
parentMerge pull request #7324 from syuilo/dependabot/npm_and_yarn/types/koa-2.13.1 (diff)
downloadsharkey-936fcfb1c7cee448b8e5036205aaf8843f8d8171.tar.gz
sharkey-936fcfb1c7cee448b8e5036205aaf8843f8d8171.tar.bz2
sharkey-936fcfb1c7cee448b8e5036205aaf8843f8d8171.zip
リソースが取得できるかどうかのテストなど (#7316)
* Tests for Fetch resource * Remove unnecessary copy * Update koa-views, pug
Diffstat (limited to 'test/fetch-resource.ts')
-rw-r--r--test/fetch-resource.ts170
1 files changed, 170 insertions, 0 deletions
diff --git a/test/fetch-resource.ts b/test/fetch-resource.ts
new file mode 100644
index 0000000000..72ef133ef8
--- /dev/null
+++ b/test/fetch-resource.ts
@@ -0,0 +1,170 @@
+/*
+ * Tests for Fetch resource
+ *
+ * How to run the tests:
+ * > TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true npx mocha test/fetch-resource.ts --require ts-node/register
+ *
+ * To specify test:
+ * > TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true npx mocha test/fetch-resource.ts --require ts-node/register -g 'test name'
+ */
+
+process.env.NODE_ENV = 'test';
+
+import * as assert from 'assert';
+import * as childProcess from 'child_process';
+import { async, launchServer, signup, post, request, simpleGet } from './utils';
+
+// Request Accept
+const ONLY_AP = 'application/activity+json';
+const PREFER_AP = 'application/activity+json, */*';
+const PREFER_HTML = 'text/html, */*';
+const UNSPECIFIED = '*/*';
+
+// Response Contet-Type
+const AP = 'application/activity+json; charset=utf-8';
+const HTML = 'text/html; charset=utf-8';
+
+describe('Fetch resource', () => {
+ let p: childProcess.ChildProcess;
+
+ let alice: any;
+ let alicesPost: any;
+
+ before(launchServer(g => p = g, async () => {
+ alice = await signup({ username: 'alice' });
+ alicesPost = await post(alice, {
+ text: 'test'
+ });
+ }));
+
+ after(() => {
+ p.kill();
+ });
+
+ describe('Common', () => {
+ it('meta', async(async () => {
+ const res = await request('/meta', {
+ });
+
+ assert.strictEqual(res.status, 200);
+ }));
+
+ it('GET root', async(async () => {
+ const res = await simpleGet('/', 'text/html');
+ assert.strictEqual(res.status, 200);
+ }));
+
+ it('GET docs', async(async () => {
+ const res = await simpleGet('/docs/ja-JP/about', 'text/html');
+ assert.strictEqual(res.status, 200);
+ }));
+
+ it('GET api-doc', async(async () => {
+ const res = await simpleGet('/api-doc', 'text/html');
+ assert.strictEqual(res.status, 200);
+ }));
+
+ it('GET api.json', async(async () => {
+ const res = await simpleGet('/api.json', 'application/json');
+ assert.strictEqual(res.status, 200);
+ }));
+ });
+
+ describe('/@:username', () => {
+ it('Only AP => AP', async(async () => {
+ const res = await simpleGet(`/@${alice.username}`, ONLY_AP);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, AP);
+ }));
+
+ it('Prefer AP => AP', async(async () => {
+ const res = await simpleGet(`/@${alice.username}`, PREFER_AP);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, AP);
+ }));
+
+ it('Prefer HTML => HTML', async(async () => {
+ const res = await simpleGet(`/@${alice.username}`, PREFER_HTML);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, HTML);
+ }));
+
+ it('Unspecified => HTML', async(async () => {
+ const res = await simpleGet(`/@${alice.username}`, UNSPECIFIED);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, HTML);
+ }));
+ });
+
+ describe('/users/:id', () => {
+ it('Only AP => AP', async(async () => {
+ const res = await simpleGet(`/users/${alice.id}`, ONLY_AP);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, AP);
+ }));
+
+ it('Prefer AP => AP', async(async () => {
+ const res = await simpleGet(`/users/${alice.id}`, PREFER_AP);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, AP);
+ }));
+
+ it('Prefer HTML => Redirect to /@:username', async(async () => {
+ const res = await simpleGet(`/users/${alice.id}`, PREFER_HTML);
+ assert.strictEqual(res.status, 302);
+ assert.strictEqual(res.location, `/@${alice.username}`);
+ }));
+
+ it('Undecided => HTML', async(async () => {
+ const res = await simpleGet(`/users/${alice.id}`, UNSPECIFIED);
+ assert.strictEqual(res.status, 302);
+ assert.strictEqual(res.location, `/@${alice.username}`);
+ }));
+ });
+
+ describe('/notes/:id', () => {
+ it('Only AP => AP', async(async () => {
+ const res = await simpleGet(`/notes/${alicesPost.id}`, ONLY_AP);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, AP);
+ }));
+
+ it('Prefer AP => AP', async(async () => {
+ const res = await simpleGet(`/notes/${alicesPost.id}`, PREFER_AP);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, AP);
+ }));
+
+ it('Prefer HTML => HTML', async(async () => {
+ const res = await simpleGet(`/notes/${alicesPost.id}`, PREFER_HTML);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, HTML);
+ }));
+
+ it('Unspecified => HTML', async(async () => {
+ const res = await simpleGet(`/notes/${alicesPost.id}`, UNSPECIFIED);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, HTML);
+ }));
+ });
+
+ describe('Feeds', () => {
+ it('RSS', async(async () => {
+ const res = await simpleGet(`/@${alice.username}.rss`, UNSPECIFIED);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, 'application/rss+xml; charset=utf-8');
+ }));
+
+ it('ATOM', async(async () => {
+ const res = await simpleGet(`/@${alice.username}.atom`, UNSPECIFIED);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, 'application/atom+xml; charset=utf-8');
+ }));
+
+ it('JSON', async(async () => {
+ const res = await simpleGet(`/@${alice.username}.json`, UNSPECIFIED);
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(res.type, 'application/json; charset=utf-8');
+ }));
+ });
+});