mirror of
https://github.com/iSoron/uhabits.git
synced 2025-12-06 09:08:52 -06:00
Implement JsDatabase using sql.js
This commit is contained in:
@@ -47,7 +47,7 @@ interface Database {
|
||||
fun close()
|
||||
}
|
||||
|
||||
fun Database.runInBackground(sql: String) {
|
||||
fun Database.run(sql: String) {
|
||||
val stmt = prepareStatement(sql)
|
||||
stmt.step()
|
||||
stmt.finalize()
|
||||
@@ -72,13 +72,13 @@ fun Database.nextId(tableName: String): Int {
|
||||
}
|
||||
}
|
||||
|
||||
fun Database.begin() = runInBackground("begin")
|
||||
fun Database.begin() = run("begin")
|
||||
|
||||
fun Database.commit() = runInBackground("commit")
|
||||
fun Database.commit() = run("commit")
|
||||
|
||||
fun Database.getVersion() = queryInt("pragma user_version")
|
||||
|
||||
fun Database.setVersion(v: Int) = runInBackground("pragma user_version = $v")
|
||||
fun Database.setVersion(v: Int) = run("pragma user_version = $v")
|
||||
|
||||
fun Database.migrateTo(newVersion: Int, fileOpener: FileOpener, log: Log) {
|
||||
val currentVersion = getVersion()
|
||||
@@ -96,7 +96,7 @@ fun Database.migrateTo(newVersion: Int, fileOpener: FileOpener, log: Log) {
|
||||
val migrationFile = fileOpener.openResourceFile(filename)
|
||||
for (line in migrationFile.readLines()) {
|
||||
if (line.isEmpty()) continue
|
||||
runInBackground(line)
|
||||
run(line)
|
||||
}
|
||||
setVersion(v)
|
||||
}
|
||||
|
||||
@@ -0,0 +1,60 @@
|
||||
/*
|
||||
* Copyright (C) 2016-2019 Álinson Santos Xavier <isoron@gmail.com>
|
||||
*
|
||||
* This file is part of Loop Habit Tracker.
|
||||
*
|
||||
* Loop Habit Tracker is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by the
|
||||
* Free Software Foundation, either version 3 of the License, or (at your
|
||||
* option) any later version.
|
||||
*
|
||||
* Loop Habit Tracker is distributed in the hope that it will be useful, but
|
||||
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||
* more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
package org.isoron.platform.io
|
||||
|
||||
import kotlin.test.assertEquals
|
||||
|
||||
class DatabaseTest(val db: Database) {
|
||||
fun testUsage() {
|
||||
db.setVersion(0)
|
||||
assertEquals(0, db.getVersion())
|
||||
|
||||
db.setVersion(23)
|
||||
assertEquals(23, db.getVersion())
|
||||
|
||||
var stmt = db.prepareStatement("drop table if exists demo")
|
||||
stmt.step()
|
||||
stmt.finalize()
|
||||
|
||||
stmt = db.prepareStatement("create table if not exists demo(key int, value text)")
|
||||
stmt.step()
|
||||
stmt.finalize()
|
||||
|
||||
stmt = db.prepareStatement("insert into demo(key, value) values (?, ?)")
|
||||
stmt.bindInt(0, 42)
|
||||
stmt.bindText(1, "Hello World")
|
||||
stmt.step()
|
||||
stmt.finalize()
|
||||
|
||||
stmt = db.prepareStatement("select * from demo where key > ?")
|
||||
stmt.bindInt(0, 10)
|
||||
|
||||
var result = stmt.step()
|
||||
assertEquals(StepResult.ROW, result)
|
||||
assertEquals(42, stmt.getInt(0))
|
||||
assertEquals("Hello World", stmt.getText(1))
|
||||
|
||||
result = stmt.step()
|
||||
assertEquals(StepResult.DONE, result)
|
||||
|
||||
stmt.finalize()
|
||||
db.close()
|
||||
}
|
||||
}
|
||||
80
core/src/jsMain/kotlin/org/isoron/platform/io/JsDatabase.kt
Normal file
80
core/src/jsMain/kotlin/org/isoron/platform/io/JsDatabase.kt
Normal file
@@ -0,0 +1,80 @@
|
||||
/*
|
||||
* Copyright (C) 2016-2019 Álinson Santos Xavier <isoron@gmail.com>
|
||||
*
|
||||
* This file is part of Loop Habit Tracker.
|
||||
*
|
||||
* Loop Habit Tracker is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by the
|
||||
* Free Software Foundation, either version 3 of the License, or (at your
|
||||
* option) any later version.
|
||||
*
|
||||
* Loop Habit Tracker is distributed in the hope that it will be useful, but
|
||||
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||
* more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
package org.isoron.platform.io
|
||||
|
||||
external fun require(module: String): dynamic
|
||||
|
||||
class JsPreparedStatement(val stmt: dynamic) : PreparedStatement {
|
||||
|
||||
override fun step(): StepResult {
|
||||
val isRowAvailable = stmt.step() as Boolean
|
||||
return if(isRowAvailable) StepResult.ROW else StepResult.DONE
|
||||
}
|
||||
|
||||
override fun finalize() {
|
||||
}
|
||||
|
||||
override fun getInt(index: Int): Int {
|
||||
return (stmt.getNumber(index) as Double).toInt()
|
||||
}
|
||||
|
||||
override fun getLong(index: Int): Long {
|
||||
return (stmt.getNumber(index) as Double).toLong()
|
||||
}
|
||||
|
||||
override fun getText(index: Int): String {
|
||||
return stmt.getString(index) as String
|
||||
}
|
||||
|
||||
override fun getReal(index: Int): Double {
|
||||
return stmt.getNumber(index) as Double
|
||||
}
|
||||
|
||||
override fun bindInt(index: Int, value: Int) {
|
||||
stmt.bindNumber(value, index + 1)
|
||||
}
|
||||
|
||||
override fun bindLong(index: Int, value: Long) {
|
||||
stmt.bindNumber(value, index + 1)
|
||||
}
|
||||
|
||||
override fun bindText(index: Int, value: String) {
|
||||
stmt.bindString(value, index + 1)
|
||||
}
|
||||
|
||||
override fun bindReal(index: Int, value: Double) {
|
||||
stmt.bindNumber(value, index + 1)
|
||||
}
|
||||
|
||||
override fun reset() {
|
||||
stmt.reset()
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
class JsDatabase(val db: dynamic) : Database {
|
||||
override fun prepareStatement(sql: String): PreparedStatement {
|
||||
println(sql)
|
||||
return JsPreparedStatement(db.prepare(sql))
|
||||
}
|
||||
|
||||
override fun close() {
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,30 @@
|
||||
/*
|
||||
* Copyright (C) 2016-2019 Álinson Santos Xavier <isoron@gmail.com>
|
||||
*
|
||||
* This file is part of Loop Habit Tracker.
|
||||
*
|
||||
* Loop Habit Tracker is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by the
|
||||
* Free Software Foundation, either version 3 of the License, or (at your
|
||||
* option) any later version.
|
||||
*
|
||||
* Loop Habit Tracker is distributed in the hope that it will be useful, but
|
||||
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||
* more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
package org.isoron.platform.io
|
||||
|
||||
import kotlin.test.*
|
||||
|
||||
class JsDatabaseTest {
|
||||
@Test
|
||||
fun testUsage() {
|
||||
val db = eval("new SQL.Database()")
|
||||
DatabaseTest(JsDatabase(db)).testUsage()
|
||||
}
|
||||
}
|
||||
@@ -27,38 +27,6 @@ import kotlin.test.assertEquals
|
||||
class JavaDatabaseTest : BaseTest() {
|
||||
@Test
|
||||
fun testUsage() {
|
||||
db.setVersion(0)
|
||||
assertEquals(db.getVersion(), 0)
|
||||
|
||||
db.setVersion(23)
|
||||
assertEquals(db.getVersion(), 23)
|
||||
|
||||
var stmt = db.prepareStatement("drop table if exists demo")
|
||||
stmt.step()
|
||||
stmt.finalize()
|
||||
|
||||
stmt = db.prepareStatement("create table if not exists demo(key int, value text)")
|
||||
stmt.step()
|
||||
stmt.finalize()
|
||||
|
||||
stmt = db.prepareStatement("insert into demo(key, value) values (?, ?)")
|
||||
stmt.bindInt(0, 42)
|
||||
stmt.bindText(1, "Hello World")
|
||||
stmt.step()
|
||||
stmt.finalize()
|
||||
|
||||
stmt = db.prepareStatement("select * from demo where key > ?")
|
||||
stmt.bindInt(0, 10)
|
||||
|
||||
var result = stmt.step()
|
||||
assertEquals(result, StepResult.ROW)
|
||||
assertEquals(stmt.getInt(0), 42)
|
||||
assertEquals(stmt.getText(1), "Hello World")
|
||||
|
||||
result = stmt.step()
|
||||
assertEquals(result, StepResult.DONE)
|
||||
|
||||
stmt.finalize()
|
||||
db.close()
|
||||
DatabaseTest(db).testUsage()
|
||||
}
|
||||
}
|
||||
@@ -10,7 +10,7 @@ core:
|
||||
|
||||
$(test_bundle): test/index.js core
|
||||
mkdir -p build/bundles
|
||||
npx webpack $< --silent --mode development --target web --output $@
|
||||
npx webpack $< --mode development --target web --output $@
|
||||
|
||||
test: $(test_bundle) $(node_modules)
|
||||
open test/index.html
|
||||
|
||||
10
web/package-lock.json
generated
10
web/package-lock.json
generated
@@ -2231,11 +2231,6 @@
|
||||
"readable-stream": "^2.3.6"
|
||||
}
|
||||
},
|
||||
"fontawesome": {
|
||||
"version": "5.6.3",
|
||||
"resolved": "https://registry.npmjs.org/fontawesome/-/fontawesome-5.6.3.tgz",
|
||||
"integrity": "sha512-FCc+CawwsJWWprVEg9X14yI7zI+l9YVAyhzgu70qwGeDn0tLLDH/dVfqgij72g4BBGgLGfK2qnvFGAmYUkhaWg=="
|
||||
},
|
||||
"for-in": {
|
||||
"version": "1.0.2",
|
||||
"resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz",
|
||||
@@ -4719,6 +4714,11 @@
|
||||
"integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=",
|
||||
"dev": true
|
||||
},
|
||||
"sql.js": {
|
||||
"version": "0.5.0",
|
||||
"resolved": "https://registry.npmjs.org/sql.js/-/sql.js-0.5.0.tgz",
|
||||
"integrity": "sha1-+IDeoYKAqEDkHfIgnclnQi36jYE="
|
||||
},
|
||||
"ssri": {
|
||||
"version": "6.0.1",
|
||||
"resolved": "https://registry.npmjs.org/ssri/-/ssri-6.0.1.tgz",
|
||||
|
||||
@@ -19,7 +19,8 @@
|
||||
"babel-preset-env": "^1.7.0",
|
||||
"babel-preset-react": "^6.24.1",
|
||||
"kotlin": "^1.3.21",
|
||||
"kotlin-test": "^1.3.21"
|
||||
"kotlin-test": "^1.3.21",
|
||||
"sql.js": "^0.5.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"babel-loader": "^7.1.5",
|
||||
|
||||
@@ -3,11 +3,11 @@
|
||||
<head>
|
||||
<title>Mocha Tests</title>
|
||||
<link rel="stylesheet" href="../node_modules/mocha/mocha.css">
|
||||
<script src="../node_modules/sql.js/js/sql.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
<div id="mocha"></div>
|
||||
<script src="../node_modules/mocha/mocha.js"></script>
|
||||
<script src="../node_modules/chai/chai.js"></script>
|
||||
<script>mocha.setup('bdd')</script>
|
||||
<script src="../build/bundles/test.js"></script>
|
||||
<script>mocha.run();</script>
|
||||
|
||||
@@ -1,3 +1,3 @@
|
||||
var assert = require('assert');
|
||||
var coreTest = require('core_test');
|
||||
document.coreTest = coreTest
|
||||
let assert = require('assert');
|
||||
let coreTest = require('core_test');
|
||||
document.coreTest = coreTest;
|
||||
Reference in New Issue
Block a user