micro_sql 0.3.0 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.3.0
1
+ 0.3.1
@@ -13,6 +13,47 @@ class MicroSql::PgAdapter < MicroSql
13
13
  @impl.set_notice_receiver { |result| MicroSql.logger.info(result.error_message) }
14
14
  end
15
15
 
16
+ TRANSACTION_STATUSES = %w(PQTRANS_IDLE PQTRANS_ACTIVE PQTRANS_INTRANS PQTRANS_INERROR PQTRANS_UNKNOWN)
17
+
18
+ def transaction_status
19
+ TRANSACTION_STATUSES[@impl.transaction_status]
20
+ end
21
+
22
+ def transaction?
23
+ status = @impl.transaction_status
24
+ status == PG::Connection::PQTRANS_INTRANS || status == PG::Connection::PQTRANS_INERROR
25
+ end
26
+
27
+ def transaction(&block)
28
+ return savepoint_transaction(&block) if transaction?
29
+
30
+ begin
31
+ r = nil
32
+ @impl.transaction do
33
+ r = yield
34
+ end
35
+ r
36
+ rescue RollbackException
37
+ nil
38
+ end
39
+ end
40
+
41
+ private
42
+
43
+ def savepoint_transaction(&block)
44
+ savepoint_name = "sqdb_#{object_id}"
45
+
46
+ exec! "SAVEPOINT #{savepoint_name}"
47
+ r = yield
48
+ exec! "RELEASE SAVEPOINT #{savepoint_name}"
49
+ r
50
+ rescue RollbackException
51
+ exec! "ROLLBACK TO SAVEPOINT #{savepoint_name}"
52
+ nil
53
+ end
54
+
55
+ public
56
+
16
57
  def tables
17
58
  exec("SELECT tablename FROM pg_tables WHERE tablename NOT LIKE 'pg_%' AND tablename NOT LIKE 'sql_%'").map(&:first)
18
59
  end
data/micro_sql.gemspec CHANGED
@@ -5,11 +5,11 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = "micro_sql"
8
- s.version = "0.3.0"
8
+ s.version = "0.3.1"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = ["radiospiel"]
12
- s.date = "2012-04-02"
12
+ s.date = "2012-04-03"
13
13
  s.description = "You only need a single method to talk to your database..."
14
14
  s.email = "eno@open-lab.org"
15
15
  s.extra_rdoc_files = [
@@ -99,6 +99,22 @@ class TestMicroSqlPg < Test::Unit::TestCase
99
99
  assert_equal 1, db.ask("SELECT COUNT(*) FROM t1")
100
100
  end
101
101
 
102
+ def test_nested_transaction
103
+ db.ask "CREATE TABLE t1(idx INTEGER PRIMARY KEY, b TEXT)"
104
+
105
+ foo = db.transaction do
106
+ db.ask("INSERT INTO t1 (idx,b) VALUES(12, 'twelve')")
107
+ db.transaction do
108
+ db.ask("INSERT INTO t1 (idx,b) VALUES(13, 'thirteen')")
109
+ db.rollback!
110
+ end
111
+ "bar"
112
+ end
113
+
114
+ assert_equal "bar", foo
115
+ assert_equal 1, db.ask("SELECT COUNT(*) FROM t1")
116
+ end
117
+
102
118
  def test_insert
103
119
  assert_equal([], db.tables)
104
120
  t1 = db.table "CREATE TABLE t1(idx INTEGER PRIMARY KEY, b TEXT)"
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: micro_sql
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.0
4
+ version: 0.3.1
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2012-04-02 00:00:00.000000000Z
12
+ date: 2012-04-03 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: pg
16
- requirement: &70130046726220 !ruby/object:Gem::Requirement
16
+ requirement: &70112976340220 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '0'
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *70130046726220
24
+ version_requirements: *70112976340220
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: sqlite3
27
- requirement: &70130046701360 !ruby/object:Gem::Requirement
27
+ requirement: &70112976338980 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ! '>='
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '0'
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *70130046701360
35
+ version_requirements: *70112976338980
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: bundler
38
- requirement: &70130046688900 !ruby/object:Gem::Requirement
38
+ requirement: &70112976337920 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ! '>='
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: '0'
44
44
  type: :development
45
45
  prerelease: false
46
- version_requirements: *70130046688900
46
+ version_requirements: *70112976337920
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: jeweler
49
- requirement: &70130046663760 !ruby/object:Gem::Requirement
49
+ requirement: &70112976336440 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ! '>='
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: '0'
55
55
  type: :development
56
56
  prerelease: false
57
- version_requirements: *70130046663760
57
+ version_requirements: *70112976336440
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: simplecov
60
- requirement: &70130046580920 !ruby/object:Gem::Requirement
60
+ requirement: &70112976328460 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ! '>='
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: '0'
66
66
  type: :development
67
67
  prerelease: false
68
- version_requirements: *70130046580920
68
+ version_requirements: *70112976328460
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: ruby-debug19
71
- requirement: &70130046570120 !ruby/object:Gem::Requirement
71
+ requirement: &70112976327360 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ! '>='
@@ -76,7 +76,7 @@ dependencies:
76
76
  version: '0'
77
77
  type: :development
78
78
  prerelease: false
79
- version_requirements: *70130046570120
79
+ version_requirements: *70112976327360
80
80
  description: You only need a single method to talk to your database...
81
81
  email: eno@open-lab.org
82
82
  executables: []
@@ -118,7 +118,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
118
118
  version: '0'
119
119
  segments:
120
120
  - 0
121
- hash: -292595813074764874
121
+ hash: 2450718260584937907
122
122
  required_rubygems_version: !ruby/object:Gem::Requirement
123
123
  none: false
124
124
  requirements: