1
0
Fork 0
mirror of synced 2024-09-17 09:49:11 +12:00
budibase/packages/server/middleware/routes/neo/tests/couchTestUtils.js

72 lines
1.5 KiB
JavaScript
Raw Normal View History

2020-04-10 03:53:48 +12:00
const couchdb = require("../../../../db");
const CLIENT_DB_ID = "client-testing";
2020-04-10 22:18:15 +12:00
exports.destroyDatabase = couchdb.db.destroy;
2020-04-13 22:47:53 +12:00
exports.createModel = async instanceId => {
const model = {
"name": "TestModel",
"type": "model",
"key": "name",
"fields": [
{
"name": "name",
"type": "string"
}
]
}
const db = couchdb.db.use(instanceId);
const response = await db.insert(model);
const designDoc = await db.get("_design/database");
designDoc.views = {
...designDoc.views,
[`all_${response.id}`]: {
map: function(doc) {
emit([doc.modelId], doc._id);
}
}
};
await db.insert(designDoc, designDoc._id);
2020-04-14 03:46:28 +12:00
return {
...response,
...model
};
2020-04-13 22:47:53 +12:00
}
2020-04-10 03:53:48 +12:00
exports.createClientDatabase = async () => {
await couchdb.db.create(CLIENT_DB_ID);
await couchdb.db.use(CLIENT_DB_ID).insert({
views: {
by_type: {
map: function(doc) {
emit([doc.type], doc._id);
}
}
}
}, '_design/client');
}
exports.createInstanceDatabase = async instanceId => {
await couchdb.db.create(instanceId);
await couchdb.db.use(instanceId).insert({
views: {
by_type: {
map: function(doc) {
emit([doc.type], doc._id);
}
}
}
}, '_design/database');
2020-04-13 22:47:53 +12:00
return instanceId;
2020-04-11 03:37:59 +12:00
}
exports.insertDocument = async (databaseId, document) => {
const { id, ...documentFields } = document;
await couchdb.db.use(databaseId).insert(documentFields, id);
2020-04-10 03:53:48 +12:00
}