56
server/routes/api/middlewares/pagination.test.js
Normal file
56
server/routes/api/middlewares/pagination.test.js
Normal file
@ -0,0 +1,56 @@
|
||||
/* eslint-disable flowtype/require-valid-file-annotation */
|
||||
import TestServer from "fetch-test-server";
|
||||
import webService from "../../../services/web";
|
||||
import { flushdb, seed } from "../../../test/support";
|
||||
const app = webService();
|
||||
const server = new TestServer(app.callback());
|
||||
|
||||
beforeEach(() => flushdb());
|
||||
afterAll(() => server.close());
|
||||
|
||||
describe("#pagination", () => {
|
||||
it("should allow offset and limit", async () => {
|
||||
const { user } = await seed();
|
||||
const res = await server.post("/api/users.list", {
|
||||
body: { token: user.getJwtToken(), limit: 1, offset: 1 },
|
||||
});
|
||||
|
||||
expect(res.status).toEqual(200);
|
||||
});
|
||||
|
||||
it("should not allow negative limit", async () => {
|
||||
const { user } = await seed();
|
||||
const res = await server.post("/api/users.list", {
|
||||
body: { token: user.getJwtToken(), limit: -1 },
|
||||
});
|
||||
|
||||
expect(res.status).toEqual(400);
|
||||
});
|
||||
|
||||
it("should not allow non-integer limit", async () => {
|
||||
const { user } = await seed();
|
||||
const res = await server.post("/api/users.list", {
|
||||
body: { token: user.getJwtToken(), limit: "blah" },
|
||||
});
|
||||
|
||||
expect(res.status).toEqual(400);
|
||||
});
|
||||
|
||||
it("should not allow negative offset", async () => {
|
||||
const { user } = await seed();
|
||||
const res = await server.post("/api/users.list", {
|
||||
body: { token: user.getJwtToken(), offset: -1 },
|
||||
});
|
||||
|
||||
expect(res.status).toEqual(400);
|
||||
});
|
||||
|
||||
it("should not allow non-integer offset", async () => {
|
||||
const { user } = await seed();
|
||||
const res = await server.post("/api/users.list", {
|
||||
body: { token: user.getJwtToken(), offset: "blah" },
|
||||
});
|
||||
|
||||
expect(res.status).toEqual(400);
|
||||
});
|
||||
});
|
Reference in New Issue
Block a user