transaction fixes

This commit is contained in:
Florian Dold 2021-06-10 10:37:49 +02:00
parent 67e5d68b93
commit 7b7e3b4565
No known key found for this signature in database
GPG Key ID: D2E4F00F29D02A4B
6 changed files with 60 additions and 28 deletions

View File

@ -1201,19 +1201,26 @@ export class BridgeIDBIndex implements IDBIndex {
private _confirmIndexExists() { private _confirmIndexExists() {
const storeSchema = this._schema.objectStores[this._objectStore._name]; const storeSchema = this._schema.objectStores[this._objectStore._name];
if (!storeSchema) { if (!storeSchema) {
throw new InvalidStateError(); throw new InvalidStateError(
`no schema for object store '${this._objectStore._name}'`,
);
} }
if (!storeSchema.indexes[this._name]) { if (!storeSchema.indexes[this._name]) {
throw new InvalidStateError(); throw new InvalidStateError(
`no schema for index '${this._name}' of object store '${this._objectStore._name}'`,
);
} }
} }
get(key: BridgeIDBKeyRange | IDBValidKey) { get(key: BridgeIDBKeyRange | IDBValidKey) {
this._confirmIndexExists();
this._confirmActiveTransaction();
if (this._deleted) { if (this._deleted) {
throw new InvalidStateError(); throw new InvalidStateError();
} }
if (this._objectStore._deleted) {
throw new InvalidStateError();
}
this._confirmActiveTransaction();
this._confirmIndexExists();
if (!(key instanceof BridgeIDBKeyRange)) { if (!(key instanceof BridgeIDBKeyRange)) {
key = BridgeIDBKeyRange._valueToKeyRange(key); key = BridgeIDBKeyRange._valueToKeyRange(key);
@ -1595,10 +1602,10 @@ export class BridgeIDBObjectStore implements IDBObjectStore {
*/ */
_confirmActiveTransaction(): void { _confirmActiveTransaction(): void {
if (!this._transaction._active) { if (!this._transaction._active) {
throw new TransactionInactiveError(); throw new TransactionInactiveError("transaction is not active");
} }
if (this._transaction._aborted) { if (this._transaction._aborted) {
throw new TransactionInactiveError(); throw new TransactionInactiveError("transaction has been aborted");
} }
} }

View File

@ -82,18 +82,18 @@ async function setupTest(
await merchant.start(); await merchant.start();
await merchant.pingUntilAvailable(); await merchant.pingUntilAvailable();
await merchant.addInstance({
id: "minst1",
name: "minst1",
paytoUris: ["payto://x-taler-bank/minst1"],
});
await merchant.addInstance({ await merchant.addInstance({
id: "default", id: "default",
name: "Default Instance", name: "Default Instance",
paytoUris: [`payto://x-taler-bank/merchant-default`], paytoUris: [`payto://x-taler-bank/merchant-default`],
}); });
await merchant.addInstance({
id: "minst1",
name: "minst1",
paytoUris: ["payto://x-taler-bank/minst1"],
});
console.log("setup done!"); console.log("setup done!");
return { return {

View File

@ -117,18 +117,18 @@ async function createTestEnvironment(
await merchant.start(); await merchant.start();
await merchant.pingUntilAvailable(); await merchant.pingUntilAvailable();
await merchant.addInstance({
id: "minst1",
name: "minst1",
paytoUris: ["payto://x-taler-bank/minst1"],
});
await merchant.addInstance({ await merchant.addInstance({
id: "default", id: "default",
name: "Default Instance", name: "Default Instance",
paytoUris: [`payto://x-taler-bank/merchant-default`], paytoUris: [`payto://x-taler-bank/merchant-default`],
}); });
await merchant.addInstance({
id: "minst1",
name: "minst1",
paytoUris: ["payto://x-taler-bank/minst1"],
});
console.log("setup done!"); console.log("setup done!");
const wallet = new WalletCli(t); const wallet = new WalletCli(t);

View File

@ -114,18 +114,18 @@ export async function runTimetravelAutorefreshTest(t: GlobalTestState) {
await merchant.start(); await merchant.start();
await merchant.pingUntilAvailable(); await merchant.pingUntilAvailable();
await merchant.addInstance({
id: "minst1",
name: "minst1",
paytoUris: ["payto://x-taler-bank/minst1"],
});
await merchant.addInstance({ await merchant.addInstance({
id: "default", id: "default",
name: "Default Instance", name: "Default Instance",
paytoUris: [`payto://x-taler-bank/merchant-default`], paytoUris: [`payto://x-taler-bank/merchant-default`],
}); });
await merchant.addInstance({
id: "minst1",
name: "minst1",
paytoUris: ["payto://x-taler-bank/minst1"],
});
console.log("setup done!"); console.log("setup done!");
const wallet = new WalletCli(t); const wallet = new WalletCli(t);

View File

@ -1,3 +1,22 @@
/*
This file is part of GNU Taler
(C) 2021 Taler Systems S.A.
GNU Taler 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, or (at your option) any later version.
GNU Taler 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
GNU Taler; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
*/
/**
* Imports.
*/
import { import {
openDatabase, openDatabase,
describeStore, describeStore,

View File

@ -454,8 +454,11 @@ function makeReadContext(
const indexes: { [s: string]: IndexReadOnlyAccessor<any> } = {}; const indexes: { [s: string]: IndexReadOnlyAccessor<any> } = {};
const swi = storePick[storeAlias]; const swi = storePick[storeAlias];
const storeName = swi.store.name; const storeName = swi.store.name;
for (const indexName in storePick[storeAlias].indexMap) { for (const indexAlias in storePick[storeAlias].indexMap) {
indexes[indexName] = { const indexDescriptor: IndexDescriptor =
storePick[storeAlias].indexMap[indexAlias];
const indexName = indexDescriptor.name;
indexes[indexAlias] = {
get(key) { get(key) {
const req = tx.objectStore(storeName).index(indexName).get(key); const req = tx.objectStore(storeName).index(indexName).get(key);
return requestToPromise(req); return requestToPromise(req);
@ -493,8 +496,11 @@ function makeWriteContext(
const indexes: { [s: string]: IndexReadWriteAccessor<any> } = {}; const indexes: { [s: string]: IndexReadWriteAccessor<any> } = {};
const swi = storePick[storeAlias]; const swi = storePick[storeAlias];
const storeName = swi.store.name; const storeName = swi.store.name;
for (const indexName in storePick[storeAlias].indexMap) { for (const indexAlias in storePick[storeAlias].indexMap) {
indexes[indexName] = { const indexDescriptor: IndexDescriptor =
storePick[storeAlias].indexMap[indexAlias];
const indexName = indexDescriptor.name;
indexes[indexAlias] = {
get(key) { get(key) {
const req = tx.objectStore(storeName).index(indexName).get(key); const req = tx.objectStore(storeName).index(indexName).get(key);
return requestToPromise(req); return requestToPromise(req);