Commit 7cb2f43d authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 97ffc613
...@@ -15,6 +15,7 @@ package transaction ...@@ -15,6 +15,7 @@ package transaction
import ( import (
"context" "context"
"sync/atomic"
"testing" "testing"
) )
...@@ -38,12 +39,13 @@ func TestBasic(t *testing.T) { ...@@ -38,12 +39,13 @@ func TestBasic(t *testing.T) {
}() }()
// New
txn, ctx := New(ctx) txn, ctx := New(ctx)
if txn_ := Current(ctx); txn_ != txn { if txn_ := Current(ctx); txn_ != txn {
t.Fatalf("New inconsistent with Current: txn = %#v; txn_ = %#v", txn, txn_) t.Fatalf("New inconsistent with Current: txn = %#v; txn_ = %#v", txn, txn_)
} }
// subtransactions not allowed // New(!ø) -> panic
func () { func () {
defer func() { defer func() {
r := recover() r := recover()
...@@ -59,3 +61,34 @@ func TestBasic(t *testing.T) { ...@@ -59,3 +61,34 @@ func TestBasic(t *testing.T) {
_, _ = New(ctx) _, _ = New(ctx)
}() }()
} }
// DataManager that verifies abort path.
type dmAbortOnly struct {
t *testing.T
txn Transaction
nabort int32
}
func (d *dmAbortOnly) Abort(txn Transaction) {
if txn != d.txn {
d.t.Fatalf("abort: txn is different")
}
atomic.AddInt32(&d.nabort, +1)
}
func (d *dmAbortOnly) bug() { d.t.Fatal("must not be called on abort") }
func (d *dmAbortOnly) TPCBegin(_ Transaction) { d.bug(); panic(0) }
func (d *dmAbortOnly) Commit(_ context.Context, _ Transaction) error { d.bug(); panic(0) }
func (d *dmAbortOnly) TPCVote(_ context.Context, _ Transaction) error { d.bug(); panic(0) }
func (d *dmAbortOnly) TPCFinish(_ context.Context, _ Transaction) error { d.bug(); panic(0) }
func (d *dmAbortOnly) TPCAbort(_ context.Context, _ Transaction) error { d.bug(); panic(0) }
func TestAbort(t *testing.T) {
txn, _ := New(context.Background())
dm := &dmAbortOnly{t: t, txn: txn}
txn.Abort()
if dm.nabort != 1 {
t.Fatalf("abort: nabort=%d; want=1", dm.nabort)
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment