2022-08-13 19:11:38 +03:00
|
|
|
/*
|
|
|
|
2022-05-22
|
|
|
|
|
|
|
|
The author disclaims copyright to this source code. In place of a
|
|
|
|
legal notice, here is a blessing:
|
|
|
|
|
|
|
|
* May you do good and not evil.
|
|
|
|
* May you find forgiveness for yourself and forgive others.
|
|
|
|
* May you share freely, never taking more than you give.
|
|
|
|
|
|
|
|
***********************************************************************
|
|
|
|
|
|
|
|
A basic test script for sqlite3-api.js. This file must be run in
|
|
|
|
main JS thread and sqlite3.js must have been loaded before it.
|
|
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
(function(){
|
|
|
|
const toss = function(...args){throw new Error(args.join(' '))};
|
|
|
|
const log = console.log.bind(console),
|
|
|
|
warn = console.warn.bind(console),
|
|
|
|
error = console.error.bind(console);
|
|
|
|
|
|
|
|
const stdout = log;
|
|
|
|
const stderr = error;
|
|
|
|
|
|
|
|
const test1 = function(db){
|
2022-08-13 19:36:06 +03:00
|
|
|
db.exec("create table if not exists t(a);")
|
2022-08-22 11:55:10 +03:00
|
|
|
.transaction(function(db){
|
2022-08-13 19:11:38 +03:00
|
|
|
db.prepare("insert into t(a) values(?)")
|
|
|
|
.bind(new Date().getTime())
|
|
|
|
.stepFinalize();
|
|
|
|
stdout("Number of values in table t:",
|
|
|
|
db.selectValue("select count(*) from t"));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2022-09-29 16:17:50 +03:00
|
|
|
const runTests = function(sqlite3){
|
|
|
|
const capi = sqlite3.capi,
|
2022-08-13 19:11:38 +03:00
|
|
|
oo = sqlite3.oo1,
|
2022-10-29 10:54:10 +03:00
|
|
|
wasm = sqlite3.wasm;
|
2022-08-13 19:11:38 +03:00
|
|
|
stdout("Loaded sqlite3:",capi.sqlite3_libversion(), capi.sqlite3_sourceid());
|
2022-09-27 16:40:12 +03:00
|
|
|
const persistentDir = capi.sqlite3_wasmfs_opfs_dir();
|
2022-08-13 19:11:38 +03:00
|
|
|
if(persistentDir){
|
|
|
|
stdout("Persistent storage dir:",persistentDir);
|
|
|
|
}else{
|
|
|
|
stderr("No persistent storage available.");
|
|
|
|
}
|
|
|
|
const startTime = performance.now();
|
|
|
|
let db;
|
|
|
|
try {
|
|
|
|
db = new oo.DB(persistentDir+'/foo.db');
|
2022-10-26 14:12:14 +03:00
|
|
|
stdout("DB filename:",db.filename);
|
2022-08-13 19:11:38 +03:00
|
|
|
const banner1 = '>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>',
|
|
|
|
banner2 = '<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<';
|
|
|
|
[
|
|
|
|
test1
|
|
|
|
].forEach((f)=>{
|
|
|
|
const n = performance.now();
|
|
|
|
stdout(banner1,"Running",f.name+"()...");
|
2022-09-29 16:17:50 +03:00
|
|
|
f(db, sqlite3);
|
2022-08-13 19:11:38 +03:00
|
|
|
stdout(banner2,f.name+"() took ",(performance.now() - n),"ms");
|
|
|
|
});
|
|
|
|
}finally{
|
|
|
|
if(db) db.close();
|
|
|
|
}
|
|
|
|
stdout("Total test time:",(performance.now() - startTime),"ms");
|
|
|
|
};
|
|
|
|
|
|
|
|
sqlite3InitModule(self.sqlite3TestModule).then(runTests);
|
|
|
|
})();
|