plugin.test.ts: Switch to testutil.HttpServer
This commit is contained in:
parent
ea1949e440
commit
8acb2aec11
@ -1,11 +1,12 @@
|
|||||||
import { logger } from "@coder/logger"
|
import { logger } from "@coder/logger"
|
||||||
|
import * as assert from "assert"
|
||||||
import * as express from "express"
|
import * as express from "express"
|
||||||
import * as fs from "fs"
|
import * as fs from "fs"
|
||||||
import { describe } from "mocha"
|
import { describe } from "mocha"
|
||||||
import * as path from "path"
|
import * as path from "path"
|
||||||
import * as supertest from "supertest"
|
|
||||||
import { PluginAPI } from "../src/node/plugin"
|
import { PluginAPI } from "../src/node/plugin"
|
||||||
import * as apps from "../src/node/routes/apps"
|
import * as apps from "../src/node/routes/apps"
|
||||||
|
import * as testutil from "./testutil"
|
||||||
const fsp = fs.promises
|
const fsp = fs.promises
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -13,23 +14,30 @@ const fsp = fs.promises
|
|||||||
*/
|
*/
|
||||||
describe("plugin", () => {
|
describe("plugin", () => {
|
||||||
let papi: PluginAPI
|
let papi: PluginAPI
|
||||||
let app: express.Application
|
let s: testutil.HttpServer
|
||||||
let agent: supertest.SuperAgentTest
|
|
||||||
|
|
||||||
before(async () => {
|
before(async () => {
|
||||||
papi = new PluginAPI(logger, path.resolve(__dirname, "test-plugin") + ":meow")
|
papi = new PluginAPI(logger, `${path.resolve(__dirname, "test-plugin")}:meow`)
|
||||||
await papi.loadPlugins()
|
await papi.loadPlugins()
|
||||||
|
|
||||||
app = express.default()
|
const app = express.default()
|
||||||
papi.mount(app)
|
papi.mount(app)
|
||||||
|
|
||||||
app.use("/api/applications", apps.router(papi))
|
app.use("/api/applications", apps.router(papi))
|
||||||
|
|
||||||
agent = supertest.agent(app)
|
s = new testutil.HttpServer()
|
||||||
|
await s.listen(app)
|
||||||
|
})
|
||||||
|
|
||||||
|
after(async () => {
|
||||||
|
await s.close()
|
||||||
})
|
})
|
||||||
|
|
||||||
it("/api/applications", async () => {
|
it("/api/applications", async () => {
|
||||||
await agent.get("/api/applications").expect(200, [
|
const resp = await s.fetch("/api/applications")
|
||||||
|
assert.equal(200, resp.status)
|
||||||
|
const body = await resp.json()
|
||||||
|
logger.debug(`${JSON.stringify(body)}`)
|
||||||
|
assert.deepEqual(body, [
|
||||||
{
|
{
|
||||||
name: "Test App",
|
name: "Test App",
|
||||||
version: "4.0.0",
|
version: "4.0.0",
|
||||||
@ -57,6 +65,9 @@ describe("plugin", () => {
|
|||||||
const indexHTML = await fsp.readFile(path.join(__dirname, "test-plugin/public/index.html"), {
|
const indexHTML = await fsp.readFile(path.join(__dirname, "test-plugin/public/index.html"), {
|
||||||
encoding: "utf8",
|
encoding: "utf8",
|
||||||
})
|
})
|
||||||
await agent.get("/test-plugin/test-app").expect(200, indexHTML)
|
const resp = await s.fetch("/test-plugin/test-app")
|
||||||
|
assert.equal(200, resp.status)
|
||||||
|
const body = await resp.text()
|
||||||
|
assert.equal(body, indexHTML)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
Reference in New Issue
Block a user