-
Notifications
You must be signed in to change notification settings - Fork 1.1k
/
Copy pathtest_issue128.js
41 lines (33 loc) · 1.25 KB
/
test_issue128.js
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
exports.test = function(sql, assert) {
// Create a database
var db = new sql.Database();
db.run("CREATE TABLE test (data TEXT);");
db.exec("SELECT * FROM test;");
assert.deepEqual(db.getRowsModified(), 0, "getRowsModified returns 0 at first");
db.exec("INSERT INTO test VALUES ('Hello1');");
db.exec("INSERT INTO test VALUES ('Hello');");
db.exec("INSERT INTO test VALUES ('Hello');");
db.exec("INSERT INTO test VALUES ('World4');");
assert.deepEqual(db.getRowsModified(), 1, "getRowsModified works for inserts");
db.exec("UPDATE test SET data = 'World4' where data = 'Hello';");
assert.deepEqual(db.getRowsModified(), 2, "getRowsModified works for updates");
db.exec("DELETE FROM test;");
assert.deepEqual(db.getRowsModified(), 4, "getRowsModified works for deletes");
db.exec("SELECT * FROM test;");
assert.deepEqual(db.getRowsModified(), 4, "getRowsModified unmodified by queries");
};
if (module == require.main) {
const target_file = process.argv[2];
const sql_loader = require('./load_sql_lib');
sql_loader(target_file).then((sql)=>{
require('test').run({
'test issue 128': function(assert){
exports.test(sql, assert);
}
});
})
.catch((e)=>{
console.error(e);
assert.fail(e);
});
}