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";
|
2020-04-20 17:17:11 +02:00
|
|
|
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",
|
2020-04-20 17:17:11 +02:00
|
|
|
"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);
|
2020-04-13 18:04:51 +02:00
|
|
|
|
|
|
|
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-13 18:04:51 +02:00
|
|
|
}
|
|
|
|
};
|
2020-04-24 19:02:51 +02:00
|
|
|
await db.put(designDoc);
|
2020-04-13 18:04:51 +02:00
|
|
|
|
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-20 17:17:11 +02:00
|
|
|
|
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-20 17:17:11 +02:00
|
|
|
|
2020-04-24 19:02:51 +02:00
|
|
|
exports.createInstanceDatabase = async instanceId => {
|
|
|
|
const db = new CouchDB(instanceId);
|
|
|
|
|
|
|
|
await db.put({
|
|
|
|
_id: "_design/database",
|
2020-04-20 17:17:11 +02:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|