1
0
Fork 0
mirror of synced 2024-07-09 08:16:34 +12:00

Tests WIP

This commit is contained in:
Rory Powell 2021-12-01 10:51:21 +00:00
parent 3923fd6831
commit 6f254d3a3b
12 changed files with 101 additions and 71 deletions

View file

@ -1,71 +0,0 @@
// const Airtable = require("airtable")
// const AirtableIntegration = require("../airtable")
jest.mock("airtable")
// class TestConfiguration {
// constructor(config = {}) {
// this.integration = new AirtableIntegration.integration(config)
// this.client = {
// create: jest.fn(),
// select: jest.fn(),
// update: jest.fn(),
// destroy: jest.fn(),
// }
// this.integration.client = () => this.client
// }
// }
describe("Airtable Integration", () => {
let config
beforeEach(() => {
config = new TestConfiguration()
})
it("calls the create method with the correct params", async () => {
const response = await config.integration.create({
table: "test",
json: {}
})
expect(config.client.create).toHaveBeenCalledWith([
{
fields: {}
}
])
})
it("calls the read method with the correct params", async () => {
const response = await config.integration.read({
table: "test",
view: "Grid view"
})
expect(config.client.select).toHaveBeenCalledWith({
maxRecords: 10, view: "Grid view"
})
})
it("calls the update method with the correct params", async () => {
const response = await config.integration.update({
table: "test",
id: "123",
json: {
name: "test"
}
})
expect(config.client.update).toHaveBeenCalledWith([
{
id: "123",
fields: { name: "test" }
}
])
})
it("calls the delete method with the correct params", async () => {
const ids = [1,2,3,4]
const response = await config.integration.delete({
ids
})
expect(config.client.destroy).toHaveBeenCalledWith(ids)
})
})

View file

@ -0,0 +1,88 @@
// const Airtable = require("airtable")
// const AirtableIntegration = require("../airtable")
const { Curl } = require("../../curl")
const fs = require("fs")
const path = require('path')
jest.mock("airtable")
// class TestConfiguration {
// constructor(config = {}) {
// this.integration = new AirtableIntegration.integration(config)
// this.client = {
// create: jest.fn(),
// select: jest.fn(),
// update: jest.fn(),
// destroy: jest.fn(),
// }
// this.integration.client = () => this.client
// }
// }
const getData = (file) => {
return fs.readFileSync(path.join(__dirname, `./data/${file}.txt`), "utf8")
}
describe("Curl Import", () => {
let curl
beforeEach(() => {
curl = new Curl()
})
it("validates unsupported data", async () => {
let data
let supported
// JSON
data = "{}"
supported = await curl.isSupported(data)
expect(supported).toBe(false)
// Empty
data = ""
supported = await curl.isSupported(data)
expect(supported).toBe(false)
})
it("returns import info", async () => {
const data = getData()
await curl.isSupported(data)
const info = await curl.getInfo()
expect(info.url).toBe("http://example.com")
expect(info.name).toBe("example.com")
})
describe("Returns queries", () => {
describe("populates verb", () => {
const testVerb = async (file, verb) => {
const data = getData(file)
await curl.isSupported(data)
const queries = await curl.getQueries(data)
expect(queries.length).toBe(1)
expect(queries[0].verb).toBe(verb)
}
it("populates verb", async () => {
await testVerb("get", "read")
await testVerb("post", "create")
await testVerb("put", "update")
await testVerb("delete", "delete")
await testVerb("patch", "patch")
})
})
it("populates path", async () => {
})
it("populates headers", async () => {
})
it("populates query", async () => {
})
it("populates body", async () => {
})
})
})

View file

@ -0,0 +1 @@
curl -X DELETE 'http://example.com'

View file

@ -0,0 +1 @@
curl 'http://example.com'

View file

@ -0,0 +1,3 @@
curl 'http://example.com' \
-H 'x-bb-header-1: 123' \
-H 'x-bb-header-2: 1456'

View file

@ -0,0 +1,2 @@
curl -X PATCH 'http://example.com/paths/abc' \
--data-raw '{ "key" : "val" }'

View file

@ -0,0 +1 @@
curl 'http://example.com/paths/abc'

View file

@ -0,0 +1,2 @@
curl -X POST 'http://example.com' \
--data-raw '{ "key" : "val" }'

View file

@ -0,0 +1,2 @@
curl -X PUT 'http://example.com/paths/abc' \
--data-raw '{ "key" : "val" }'

View file

@ -0,0 +1 @@
curl 'http://example.com/paths/abc?q1=v1&q1=v2'