This repository was archived by the owner on Jan 7, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 35
Expand file tree
/
Copy pathtestDB.js
More file actions
56 lines (48 loc) · 1.84 KB
/
testDB.js
File metadata and controls
56 lines (48 loc) · 1.84 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
* @license
* Copyright 2017 Cayle Sharrock
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
* an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under the License.
*/
const { Client } = require('pg');
const async = require('async');
const Transaction = require('../models/transaction');
const Book = require('../models/book');
const JournalEntry = require('../models/journal');
process.env.ALE_CONNECTION = process.env.ALE_CONNECTION || 'postgres://postgres@localhost/ale-test';
const masterUri = process.env.MASTER_ALE_CONNECTION || 'postgres://postgres@localhost/postgres';
let sequelize = require('../models/connection');
module.exports.create = (done) => {
create(masterUri, 'ale-test', done);
};
module.exports.destroy = () => {
return sequelize.drop().then(() => {
return sequelize.close();
});
};
module.exports.clear = () => {
return Transaction.truncate().then(() => {
return JournalEntry.truncate({ cascade: true });
}).then(() => {
return Book.truncate({ cascade: true });
})
};
function create(master_uri, db_name, cb) {
const queries = [
`DROP DATABASE IF EXISTS "${db_name}";`,
`CREATE DATABASE "${db_name}";`,
`ALTER DATABASE "${db_name}" SET TIMEZONE TO 'UTC';`
];
const client = new Client({ connectionString: master_uri });
client.connect();
async.eachSeries(queries, function(sql, done) {
client.query(sql, done);
}, cb);
}