1
0
Fork 0

Test_TransactionsConstraintViolation now passing

master
Philip O'Toole 9 years ago
parent 801158fa83
commit 226938c0d1

@ -196,27 +196,39 @@ func Test_SimpleTransactions(t *testing.T) {
}
}
// func Test_TransactionsConstraintViolation(t *testing.T) {
// dir, err := ioutil.TempDir("", "rqlite-test-")
// defer os.RemoveAll(dir)
// db := New(path.Join(dir, "test_db"))
// defer db.Close()
// err = db.Execute("create table foo (id integer not null primary key, name text)")
// c.Assert(err, IsNil)
func Test_TransactionsConstraintViolation(t *testing.T) {
db, path := mustOpenDatabase()
defer db.Close()
defer os.Remove(path)
var err error
// err = db.StartTransaction()
// c.Assert(err, IsNil)
// err = db.Execute("INSERT INTO foo(id, name) VALUES(1, \"fiona\")")
// c.Assert(err, IsNil)
// err = db.Execute("INSERT INTO foo(id, name) VALUES(1, \"fiona\")")
// c.Assert(err, NotNil)
// err = db.RollbackTransaction()
// c.Assert(err, IsNil)
if err = db.Execute("create table foo (id integer not null primary key, name text)"); err != nil {
t.Fatalf("failed to create table: %s", err.Error())
}
// r, err := db.Query("SELECT * FROM foo")
// c.Assert(len(r), Equals, 0)
// }
if err = db.StartTransaction(); err != nil {
t.Fatalf("failed to start transaction: %s", err.Error())
}
if err = db.Execute(`INSERT INTO foo(id, name) VALUES(11, "fiona")`); err != nil {
t.Fatalf("failed to insert record: %s", err.Error())
}
if err = db.Execute(`INSERT INTO foo(id, name) VALUES(11, "fiona")`); err == nil {
t.Fatal("duplicated record inserted OK")
}
if err.Error() != "UNIQUE constraint failed: foo.id" {
t.Fatal("unexpected error returned")
}
if err := db.RollbackTransaction(); err != nil {
t.Fatalf("failed to rollback transaction: %s", err.Error())
}
r, err := db.Query("SELECT name FROM foo")
if err != nil {
t.Fatalf("failed to query after commited transaction: %s", err.Error())
}
if len(r) != 0 {
t.Fatalf("incorrect number of results returned: %d", len(r))
}
}
// func Test_TransactionsHardFail(t *testing.T) {
// dir, err := ioutil.TempDir("", "rqlite-test-")

Loading…
Cancel
Save