add spec for transactions and nested transactions (#12)

This commit is contained in:
Brian J. Cardiff 2016-12-14 12:27:43 -03:00 committed by GitHub
parent c39220e3f0
commit 46709eab00
2 changed files with 83 additions and 0 deletions

View file

@ -242,4 +242,57 @@ describe Driver do
File.delete(DB_FILENAME) File.delete(DB_FILENAME)
end end
end end
describe "transactions" do
it "can read inside transaction and rollback after" do
with_db do |db|
db.exec "create table person (name varchar(25))"
db.transaction do |tx|
tx.connection.scalar("select count(*) from person").should eq(0)
tx.connection.exec "insert into person (name) values (?)", "John Doe"
tx.connection.scalar("select count(*) from person").should eq(1)
tx.rollback
end
db.scalar("select count(*) from person").should eq(0)
end
end
it "can read inside transaction or after commit" do
with_db do |db|
db.exec "create table person (name varchar(25))"
db.transaction do |tx|
tx.connection.scalar("select count(*) from person").should eq(0)
tx.connection.exec "insert into person (name) values (?)", "John Doe"
tx.connection.scalar("select count(*) from person").should eq(1)
# using other connection
db.scalar("select count(*) from person").should eq(0)
end
db.scalar("select count(*) from person").should eq(1)
end
end
end
describe "nested transactions" do
it "can read inside transaction and rollback after" do
with_db do |db|
db.exec "create table person (name varchar(25))"
db.transaction do |tx_0|
tx_0.connection.scalar("select count(*) from person").should eq(0)
tx_0.connection.exec "insert into person (name) values (?)", "John Doe"
tx_0.transaction do |tx_1|
tx_1.connection.exec "insert into person (name) values (?)", "Sarah"
tx_1.connection.scalar("select count(*) from person").should eq(2)
tx_1.transaction do |tx_2|
tx_2.connection.exec "insert into person (name) values (?)", "Jimmy"
tx_2.connection.scalar("select count(*) from person").should eq(3)
tx_2.rollback
end
end
tx_0.connection.scalar("select count(*) from person").should eq(2)
tx_0.rollback
end
db.scalar("select count(*) from person").should eq(0)
end
end
end
end end

View file

@ -33,6 +33,36 @@ class SQLite3::Connection < DB::Connection
LibSQLite3.close_v2(self) LibSQLite3.close_v2(self)
end end
# :nodoc:
def perform_begin_transaction
self.prepared.exec "BEGIN"
end
# :nodoc:
def perform_commit_transaction
self.prepared.exec "COMMIT"
end
# :nodoc:
def perform_rollback_transaction
self.prepared.exec "ROLLBACK"
end
# :nodoc:
def perform_create_savepoint(name)
self.prepared.exec "SAVEPOINT #{name}"
end
# :nodoc:
def perform_release_savepoint(name)
self.prepared.exec "RELEASE SAVEPOINT #{name}"
end
# :nodoc:
def perform_rollback_savepoint(name)
self.prepared.exec "ROLLBACK TO #{name}"
end
# Dump the database to another SQLite3 database. This can be used for backing up a SQLite3 Database # Dump the database to another SQLite3 database. This can be used for backing up a SQLite3 Database
# to disk or the opposite # to disk or the opposite
def dump(to : SQLite3::Connection) def dump(to : SQLite3::Connection)