all repos — archive/homestead @ b7bf162e6c3bc834097e65936704e3eac59eb4bd

My future indieweb platform

test/app.test.js (view raw)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
"use strict";

const test = require("ava");
const path = require("path");
const request = require("supertest");
const cheerio = require("cheerio");
const mf = require("microformat-node");

process.chdir(path.resolve(__dirname, "./testsite/"));
const config = require(path.resolve(__dirname, "../src/modules/config.js"));

const app = require("../src/app.js");

const parseResponse = res =>
  cheerio.load(res.text, {
    normalizeWhitespace: true,
    useHtmlParser2: true
  });

const toMicroformatsOptions = node => ({
  node,
  textFormat: "normalised"
});

async function notFound(t, url, bodyRegex) {
  const res = await request(app.listen()).get(url);
  const body = res.text;
  t.is(res.statusCode, 404);
  t.regex(body, bodyRegex);
}
notFound.title = (providedTitle, input, expected) =>
  `${input} = 404 ${expected.toString()}`;

test("homepage", async function(t) {
  const res = await request(app.listen()).get("/");

  t.is(res.statusCode, 200);
  t.is(res.type, "text/html");
  t.is(res.charset, "utf-8");
  t.regex(res.text, /^<!DOCTYPE html>/);

  const $ = parseResponse(res);

  t.is($("head > title").text(), "John Doe", "head title is site author");
  t.is($("h1").text(), "John Doe", "h1 is site author");
  t.is($("main").length, 1, "only one <main> tag");
  t.is(
    $(".h-entry:first-of-type time").text(),
    "Sunday, January 1, 2017",
    "first post date"
  );
  t.is(
    $(".h-entry:first-of-type time").attr("datetime"),
    new Date("2017-01-01").toISOString()
  );

  const options = toMicroformatsOptions($);
  const count = await mf.countAsync(options);

  t.deepEqual(count, {
    "h-card": 1,
    "h-feed": 1,
    "h-entry": 1
  });

  const data = await mf.getAsync(options);

  t.snapshot(data, "should contain relevant microformats data");
});

test("post", async function(t) {
  const res = await request(app.listen()).get("/post/testfile");

  t.is(res.statusCode, 200);
  t.is(res.type, "text/html");
  t.is(res.charset, "utf-8");
  t.regex(res.text, /^<!DOCTYPE html>/);

  const $ = parseResponse(res);

  t.is(
    $("head > title").text(),
    "This is a test · " + "John Doe",
    "head title contains post and site author"
  );

  const options = toMicroformatsOptions($);

  const count = await mf.countAsync(options);

  t.deepEqual(count, {
    "h-card": 1,
    "h-entry": 1
  });

  const data = await mf.getAsync(options);

  t.snapshot(data, "should contain relevant microformats data");
});

test("tags", async function(t) {
  const res = await request(app.listen()).get("/tag/a");

  t.is(res.statusCode, 200);
  t.is(res.type, "text/html");
  t.is(res.charset, "utf-8");
  t.regex(res.text, /^<!DOCTYPE html>/);

  const $ = parseResponse(res);

  t.is(
    $("head > title").text(),
    "A · John Doe",
    "head title contains title-cased tag and site name"
  );
  const options = toMicroformatsOptions($);
  const count = await mf.countAsync(options);

  t.deepEqual(count, {
    "h-card": 1,
    "h-feed": 1,
    "h-entry": 1
  });

  const data = await mf.getAsync(options);

  t.snapshot(data, "should contain relevant microformats data");
});

test(notFound, "/post/non-existent", /Post not found/);
test(notFound, "/tag/non-existent", /tag non-existent not found/);