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/); |