budibase/packages/server/api/routes/tests/couchTestUtils.js

95 lines
2.0 KiB
JavaScript
Raw Normal View History

2020-05-04 18:13:57 +02:00
const CouchDB = require("../../../db");
2020-04-24 19:02:51 +02:00
const CLIENT_DB_ID = "client-testing";
const TEST_APP_ID = "test-app";
2020-04-09 17:53:48 +02:00
2020-04-22 17:35:20 +02:00
exports.createModel = async (instanceId, model) => {
model = model || {
2020-04-13 12:47:53 +02:00
"name": "TestModel",
"type": "model",
"key": "name",
"schema": {
"name": { "type": "string" }
}
2020-04-13 12:47:53 +02:00
}
2020-04-24 19:02:51 +02:00
const db = new CouchDB(instanceId);
const response = await db.post(model);
const designDoc = await db.get("_design/database");
designDoc.views = {
...designDoc.views,
[`all_${response.id}`]: {
2020-04-22 17:35:20 +02:00
map: `function(doc) {
if (doc.modelId === "${response.id}") {
emit(doc[doc.key], doc._id);
}
}`
}
};
2020-04-24 19:02:51 +02:00
await db.put(designDoc);
2020-04-13 17:46:28 +02:00
return {
...response,
...model
};
2020-04-13 12:47:53 +02:00
}
2020-04-24 19:02:51 +02:00
exports.createClientDatabase = async () => {
const db = new CouchDB(CLIENT_DB_ID);
2020-04-09 17:53:48 +02:00
2020-04-24 19:02:51 +02:00
await db.put({
_id: "_design/client",
views: {
by_type: {
map: function(doc) {
emit([doc.type], doc._id);
}
}.toString()
}
});
2020-04-24 19:02:51 +02:00
await db.put({
_id: TEST_APP_ID,
type: "app",
instances: []
});
return db;
}
2020-04-09 17:53:48 +02:00
2020-04-24 19:02:51 +02:00
exports.destroyClientDatabase = async () => new CouchDB(CLIENT_DB_ID).destroy();
2020-04-24 19:02:51 +02:00
exports.createInstanceDatabase = async instanceId => {
const db = new CouchDB(instanceId);
await db.put({
_id: "_design/database",
metadata: {
clientId: CLIENT_DB_ID,
applicationId: TEST_APP_ID
},
2020-04-09 17:53:48 +02:00
views: {
by_type: {
map: function(doc) {
emit([doc.type], doc._id);
2020-04-24 19:02:51 +02:00
}.toString()
2020-04-09 17:53:48 +02:00
}
}
2020-04-24 19:02:51 +02:00
});
2020-04-13 12:47:53 +02:00
2020-04-24 19:02:51 +02:00
return db;
2020-04-10 17:37:59 +02:00
}
exports.insertDocument = async (databaseId, document) => {
const { id, ...documentFields } = document;
2020-04-24 19:02:51 +02:00
await new CouchDB(databaseId).put({ _id: id, ...documentFields });
2020-04-22 17:35:20 +02:00
}
exports.createSchema = async (request, instanceId, schema) => {
for (let model of schema.models) {
await request.post(`/api/${instanceId}/models`).send(model)
}
for (let view of schema.views) {
await request.post(`/api/${instanceId}/views`).send(view)
}
}