temporal_tables 3.0.0 → 3.0.2

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 3ce2b662e846d6d42ccb774dc89abd731e3f7d43ca77f94347df8312df0fb543
4
- data.tar.gz: 25fd0c42c5e37dd35c0a2abbcaff994b6e1d54eefaa04a6e579a01260885cec3
3
+ metadata.gz: b2b3ca86de0cb9c2d6571de2dcda6069f9ea0de03b5b1ebf064bedb5d8e31370
4
+ data.tar.gz: 8456f39e5f9aeef0e6c66fe8bd0e9d771fdec212ba6e4e145e2acbf4f227974b
5
5
  SHA512:
6
- metadata.gz: 53b4b4680d68cf772b3d38430f93ce340226740747ea8825a87a1fe9953b24c26135ed2cbfb3ae840d608992a7bb4cf169ff07d6fc980744fb683153912ef2ca
7
- data.tar.gz: 9a1558d7ab3c79973314f1f7c74498d77ba901e3d608415028bdee79c618b77ad25e5f39f0f62a4ce249e2ef53b007461eeaa54a506da3cbf625999fe6d02903
6
+ metadata.gz: b22849a333b4ffeceae82a2683cad8a9462d8e41f982af130866d51aa8591d3c487601aa3cd5452f75a9b0d1fb528309968070fe00046387812b304aac730f72
7
+ data.tar.gz: 10833776cfeec2db6df3aa7b0a87d69c7596d1e9729ea1efab1d60cf5e4e517cb9b899868e11485dc65591188f65641e53de448691160840cae2648648302b59
@@ -3,7 +3,7 @@ name: Continuous Integration
3
3
  on:
4
4
  push:
5
5
  branches:
6
- - '**'
6
+ - "**"
7
7
  tags:
8
8
  - "v*.*.*"
9
9
  pull_request:
@@ -11,16 +11,40 @@ on:
11
11
  - master
12
12
 
13
13
  jobs:
14
+ rubocop:
15
+ runs-on: ubuntu-latest
16
+
17
+ strategy:
18
+ fail-fast: false
19
+ matrix:
20
+ ruby: ["3.3"]
21
+ gemfile:
22
+ - "gemfiles/Gemfile.7.1.pg"
23
+ env:
24
+ BUNDLE_GEMFILE: ${{github.workspace}}/${{matrix.gemfile }}
25
+ steps:
26
+ - uses: actions/checkout@v4
27
+ - uses: ruby/setup-ruby@v1
28
+ with:
29
+ ruby-version: "${{ matrix.ruby }}"
30
+ - name: Bundle
31
+ run: bundle install
32
+
33
+ - name: Run Rubocop
34
+ run: bundle exec rubocop
35
+
14
36
  tests:
15
37
  runs-on: ubuntu-latest
16
38
 
17
39
  services:
18
40
  postgres:
19
- image: postgres:11.5
41
+ image: ${{ endsWith(matrix.gemfile, '.pg') && 'postgres:16' || '' }}
42
+ env:
43
+ POSTGRES_HOST_AUTH_METHOD: trust
20
44
  ports: ["5432:5432"]
21
45
  options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5
22
46
  mysql:
23
- image: mysql:8.0
47
+ image: ${{ endsWith(matrix.gemfile, '.mysql') && 'mysql:8' || '' }}
24
48
  env:
25
49
  MYSQL_ROOT_PASSWORD: password
26
50
  ports: ["3306:3306"]
@@ -29,37 +53,41 @@ jobs:
29
53
  strategy:
30
54
  fail-fast: false
31
55
  matrix:
32
- ruby: ["3.0.6", "3.1.4", "3.2.2"]
33
- gemfile:
56
+ ruby: ["3.0", "3.1", "3.2", "3.3"]
57
+ gemfile:
34
58
  - "gemfiles/Gemfile.6.1.mysql"
35
59
  - "gemfiles/Gemfile.6.1.pg"
36
60
  - "gemfiles/Gemfile.7.0.mysql"
37
61
  - "gemfiles/Gemfile.7.0.pg"
38
62
  - "gemfiles/Gemfile.7.1.mysql"
39
63
  - "gemfiles/Gemfile.7.1.pg"
64
+ - "gemfiles/Gemfile.7.2.mysql"
65
+ - "gemfiles/Gemfile.7.2.pg"
66
+ exclude:
67
+ - ruby: "3.0"
68
+ gemfile: "gemfiles/Gemfile.7.2.mysql"
69
+ - ruby: "3.0"
70
+ gemfile: "gemfiles/Gemfile.7.2.pg"
40
71
  env:
41
72
  BUNDLE_GEMFILE: ${{github.workspace}}/${{matrix.gemfile }}
42
73
  steps:
43
- - uses: actions/checkout@v2
44
- - uses: ruby/setup-ruby@v1
45
- with:
46
- ruby-version: "${{ matrix.ruby }}"
47
- - name: Bundle
48
- run: |
49
- gem install bundler:2.4.10
50
- bundle install
51
-
52
- - name: Run Rubocop
53
- run: bundle exec rubocop
74
+ - uses: actions/checkout@v4
75
+ - uses: ruby/setup-ruby@v1
76
+ with:
77
+ ruby-version: "${{ matrix.ruby }}"
78
+ - name: Bundle
79
+ run: bundle install
54
80
 
55
- - name: Run Tests
56
- env:
57
- PGHOST: localhost
58
- PGUSER: postgres
59
- run: bundle exec rspec
81
+ - name: Run Tests
82
+ env:
83
+ PGHOST: localhost
84
+ PGUSER: postgres
85
+ run: bundle exec rspec
60
86
 
61
87
  publish:
62
- needs: [tests]
88
+ needs:
89
+ - rubocop
90
+ - tests
63
91
  runs-on: ubuntu-latest
64
92
  if: startsWith(github.ref, 'refs/tags/v')
65
93
 
@@ -68,9 +96,9 @@ jobs:
68
96
  id-token: write
69
97
 
70
98
  steps:
71
- - uses: actions/checkout@v2
99
+ - uses: actions/checkout@v4
72
100
  - uses: ruby/setup-ruby@v1
73
101
  with:
74
- ruby-version: "3.2.2"
102
+ ruby-version: "3.3"
75
103
  bundler-cache: true
76
104
  - uses: rubygems/release-gem@v1
data/.ruby-version CHANGED
@@ -1 +1 @@
1
- 3.2.2
1
+ 3.3
@@ -1,8 +1,8 @@
1
1
  PATH
2
2
  remote: ..
3
3
  specs:
4
- temporal_tables (3.0.0)
5
- rails (>= 6.0, < 7.2)
4
+ temporal_tables (3.0.1)
5
+ rails (>= 6.1, < 7.2)
6
6
 
7
7
  GEM
8
8
  remote: https://rubygems.org/
@@ -1,8 +1,8 @@
1
1
  PATH
2
2
  remote: ..
3
3
  specs:
4
- temporal_tables (3.0.0)
5
- rails (>= 6.0, < 7.2)
4
+ temporal_tables (3.0.1)
5
+ rails (>= 6.1, < 7.2)
6
6
 
7
7
  GEM
8
8
  remote: https://rubygems.org/
@@ -1,8 +1,8 @@
1
1
  PATH
2
2
  remote: ..
3
3
  specs:
4
- temporal_tables (3.0.0)
5
- rails (>= 6.0, < 7.2)
4
+ temporal_tables (3.0.1)
5
+ rails (>= 6.1, < 7.2)
6
6
 
7
7
  GEM
8
8
  remote: https://rubygems.org/
@@ -1,8 +1,8 @@
1
1
  PATH
2
2
  remote: ..
3
3
  specs:
4
- temporal_tables (3.0.0)
5
- rails (>= 6.0, < 7.2)
4
+ temporal_tables (3.0.1)
5
+ rails (>= 6.1, < 7.2)
6
6
 
7
7
  GEM
8
8
  remote: https://rubygems.org/
@@ -1,8 +1,8 @@
1
1
  PATH
2
2
  remote: ..
3
3
  specs:
4
- temporal_tables (3.0.0)
5
- rails (>= 6.0, < 7.2)
4
+ temporal_tables (3.0.1)
5
+ rails (>= 6.1, < 7.2)
6
6
 
7
7
  GEM
8
8
  remote: https://rubygems.org/
@@ -1,8 +1,8 @@
1
1
  PATH
2
2
  remote: ..
3
3
  specs:
4
- temporal_tables (3.0.0)
5
- rails (>= 6.0, < 7.2)
4
+ temporal_tables (3.0.1)
5
+ rails (>= 6.1, < 7.2)
6
6
 
7
7
  GEM
8
8
  remote: https://rubygems.org/
@@ -0,0 +1,19 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Runtime dependencies
4
+ gem 'rails', '~> 7.2.0'
5
+ gem 'mysql2'
6
+
7
+ # Development dependencies
8
+ gem 'rspec', '~> 3.4'
9
+ gem 'rake'
10
+ gem 'byebug'
11
+ gem 'database_cleaner'
12
+ gem 'combustion'
13
+ gem 'gemika'
14
+ gem 'rubocop'
15
+ gem 'rubocop-rails'
16
+ gem 'rubocop-rspec'
17
+
18
+ # Gem under test
19
+ gem 'temporal_tables', :path => '..'
@@ -0,0 +1,273 @@
1
+ PATH
2
+ remote: ..
3
+ specs:
4
+ temporal_tables (3.0.1)
5
+ rails (>= 6.1, < 7.3)
6
+
7
+ GEM
8
+ remote: https://rubygems.org/
9
+ specs:
10
+ actioncable (7.2.0)
11
+ actionpack (= 7.2.0)
12
+ activesupport (= 7.2.0)
13
+ nio4r (~> 2.0)
14
+ websocket-driver (>= 0.6.1)
15
+ zeitwerk (~> 2.6)
16
+ actionmailbox (7.2.0)
17
+ actionpack (= 7.2.0)
18
+ activejob (= 7.2.0)
19
+ activerecord (= 7.2.0)
20
+ activestorage (= 7.2.0)
21
+ activesupport (= 7.2.0)
22
+ mail (>= 2.8.0)
23
+ actionmailer (7.2.0)
24
+ actionpack (= 7.2.0)
25
+ actionview (= 7.2.0)
26
+ activejob (= 7.2.0)
27
+ activesupport (= 7.2.0)
28
+ mail (>= 2.8.0)
29
+ rails-dom-testing (~> 2.2)
30
+ actionpack (7.2.0)
31
+ actionview (= 7.2.0)
32
+ activesupport (= 7.2.0)
33
+ nokogiri (>= 1.8.5)
34
+ racc
35
+ rack (>= 2.2.4, < 3.2)
36
+ rack-session (>= 1.0.1)
37
+ rack-test (>= 0.6.3)
38
+ rails-dom-testing (~> 2.2)
39
+ rails-html-sanitizer (~> 1.6)
40
+ useragent (~> 0.16)
41
+ actiontext (7.2.0)
42
+ actionpack (= 7.2.0)
43
+ activerecord (= 7.2.0)
44
+ activestorage (= 7.2.0)
45
+ activesupport (= 7.2.0)
46
+ globalid (>= 0.6.0)
47
+ nokogiri (>= 1.8.5)
48
+ actionview (7.2.0)
49
+ activesupport (= 7.2.0)
50
+ builder (~> 3.1)
51
+ erubi (~> 1.11)
52
+ rails-dom-testing (~> 2.2)
53
+ rails-html-sanitizer (~> 1.6)
54
+ activejob (7.2.0)
55
+ activesupport (= 7.2.0)
56
+ globalid (>= 0.3.6)
57
+ activemodel (7.2.0)
58
+ activesupport (= 7.2.0)
59
+ activerecord (7.2.0)
60
+ activemodel (= 7.2.0)
61
+ activesupport (= 7.2.0)
62
+ timeout (>= 0.4.0)
63
+ activestorage (7.2.0)
64
+ actionpack (= 7.2.0)
65
+ activejob (= 7.2.0)
66
+ activerecord (= 7.2.0)
67
+ activesupport (= 7.2.0)
68
+ marcel (~> 1.0)
69
+ activesupport (7.2.0)
70
+ base64
71
+ bigdecimal
72
+ concurrent-ruby (~> 1.0, >= 1.3.1)
73
+ connection_pool (>= 2.2.5)
74
+ drb
75
+ i18n (>= 1.6, < 2)
76
+ logger (>= 1.4.2)
77
+ minitest (>= 5.1)
78
+ securerandom (>= 0.3)
79
+ tzinfo (~> 2.0, >= 2.0.5)
80
+ ast (2.4.2)
81
+ base64 (0.2.0)
82
+ bigdecimal (3.1.8)
83
+ builder (3.3.0)
84
+ byebug (11.1.3)
85
+ combustion (1.5.0)
86
+ activesupport (>= 3.0.0)
87
+ railties (>= 3.0.0)
88
+ thor (>= 0.14.6)
89
+ concurrent-ruby (1.3.4)
90
+ connection_pool (2.4.1)
91
+ crass (1.0.6)
92
+ database_cleaner (2.0.2)
93
+ database_cleaner-active_record (>= 2, < 3)
94
+ database_cleaner-active_record (2.2.0)
95
+ activerecord (>= 5.a)
96
+ database_cleaner-core (~> 2.0.0)
97
+ database_cleaner-core (2.0.1)
98
+ date (3.3.4)
99
+ diff-lcs (1.5.1)
100
+ drb (2.2.1)
101
+ erubi (1.13.0)
102
+ gemika (0.8.3)
103
+ globalid (1.2.1)
104
+ activesupport (>= 6.1)
105
+ i18n (1.14.5)
106
+ concurrent-ruby (~> 1.0)
107
+ io-console (0.7.2)
108
+ irb (1.14.0)
109
+ rdoc (>= 4.0.0)
110
+ reline (>= 0.4.2)
111
+ json (2.7.2)
112
+ language_server-protocol (3.17.0.3)
113
+ logger (1.6.0)
114
+ loofah (2.22.0)
115
+ crass (~> 1.0.2)
116
+ nokogiri (>= 1.12.0)
117
+ mail (2.8.1)
118
+ mini_mime (>= 0.1.1)
119
+ net-imap
120
+ net-pop
121
+ net-smtp
122
+ marcel (1.0.4)
123
+ mini_mime (1.1.5)
124
+ minitest (5.24.1)
125
+ mysql2 (0.5.6)
126
+ net-imap (0.4.14)
127
+ date
128
+ net-protocol
129
+ net-pop (0.1.2)
130
+ net-protocol
131
+ net-protocol (0.2.2)
132
+ timeout
133
+ net-smtp (0.5.0)
134
+ net-protocol
135
+ nio4r (2.7.3)
136
+ nokogiri (1.16.7-aarch64-linux)
137
+ racc (~> 1.4)
138
+ nokogiri (1.16.7-arm-linux)
139
+ racc (~> 1.4)
140
+ nokogiri (1.16.7-arm64-darwin)
141
+ racc (~> 1.4)
142
+ nokogiri (1.16.7-x86-linux)
143
+ racc (~> 1.4)
144
+ nokogiri (1.16.7-x86_64-darwin)
145
+ racc (~> 1.4)
146
+ nokogiri (1.16.7-x86_64-linux)
147
+ racc (~> 1.4)
148
+ parallel (1.26.2)
149
+ parser (3.3.4.2)
150
+ ast (~> 2.4.1)
151
+ racc
152
+ psych (5.1.2)
153
+ stringio
154
+ racc (1.8.1)
155
+ rack (3.1.7)
156
+ rack-session (2.0.0)
157
+ rack (>= 3.0.0)
158
+ rack-test (2.1.0)
159
+ rack (>= 1.3)
160
+ rackup (2.1.0)
161
+ rack (>= 3)
162
+ webrick (~> 1.8)
163
+ rails (7.2.0)
164
+ actioncable (= 7.2.0)
165
+ actionmailbox (= 7.2.0)
166
+ actionmailer (= 7.2.0)
167
+ actionpack (= 7.2.0)
168
+ actiontext (= 7.2.0)
169
+ actionview (= 7.2.0)
170
+ activejob (= 7.2.0)
171
+ activemodel (= 7.2.0)
172
+ activerecord (= 7.2.0)
173
+ activestorage (= 7.2.0)
174
+ activesupport (= 7.2.0)
175
+ bundler (>= 1.15.0)
176
+ railties (= 7.2.0)
177
+ rails-dom-testing (2.2.0)
178
+ activesupport (>= 5.0.0)
179
+ minitest
180
+ nokogiri (>= 1.6)
181
+ rails-html-sanitizer (1.6.0)
182
+ loofah (~> 2.21)
183
+ nokogiri (~> 1.14)
184
+ railties (7.2.0)
185
+ actionpack (= 7.2.0)
186
+ activesupport (= 7.2.0)
187
+ irb (~> 1.13)
188
+ rackup (>= 1.0.0)
189
+ rake (>= 12.2)
190
+ thor (~> 1.0, >= 1.2.2)
191
+ zeitwerk (~> 2.6)
192
+ rainbow (3.1.1)
193
+ rake (13.2.1)
194
+ rdoc (6.7.0)
195
+ psych (>= 4.0.0)
196
+ regexp_parser (2.9.2)
197
+ reline (0.5.9)
198
+ io-console (~> 0.5)
199
+ rexml (3.3.5)
200
+ strscan
201
+ rspec (3.13.0)
202
+ rspec-core (~> 3.13.0)
203
+ rspec-expectations (~> 3.13.0)
204
+ rspec-mocks (~> 3.13.0)
205
+ rspec-core (3.13.0)
206
+ rspec-support (~> 3.13.0)
207
+ rspec-expectations (3.13.1)
208
+ diff-lcs (>= 1.2.0, < 2.0)
209
+ rspec-support (~> 3.13.0)
210
+ rspec-mocks (3.13.1)
211
+ diff-lcs (>= 1.2.0, < 2.0)
212
+ rspec-support (~> 3.13.0)
213
+ rspec-support (3.13.1)
214
+ rubocop (1.65.1)
215
+ json (~> 2.3)
216
+ language_server-protocol (>= 3.17.0)
217
+ parallel (~> 1.10)
218
+ parser (>= 3.3.0.2)
219
+ rainbow (>= 2.2.2, < 4.0)
220
+ regexp_parser (>= 2.4, < 3.0)
221
+ rexml (>= 3.2.5, < 4.0)
222
+ rubocop-ast (>= 1.31.1, < 2.0)
223
+ ruby-progressbar (~> 1.7)
224
+ unicode-display_width (>= 2.4.0, < 3.0)
225
+ rubocop-ast (1.32.0)
226
+ parser (>= 3.3.1.0)
227
+ rubocop-rails (2.25.1)
228
+ activesupport (>= 4.2.0)
229
+ rack (>= 1.1)
230
+ rubocop (>= 1.33.0, < 2.0)
231
+ rubocop-ast (>= 1.31.1, < 2.0)
232
+ rubocop-rspec (3.0.4)
233
+ rubocop (~> 1.61)
234
+ ruby-progressbar (1.13.0)
235
+ securerandom (0.3.1)
236
+ stringio (3.1.1)
237
+ strscan (3.1.0)
238
+ thor (1.3.1)
239
+ timeout (0.4.1)
240
+ tzinfo (2.0.6)
241
+ concurrent-ruby (~> 1.0)
242
+ unicode-display_width (2.5.0)
243
+ useragent (0.16.10)
244
+ webrick (1.8.1)
245
+ websocket-driver (0.7.6)
246
+ websocket-extensions (>= 0.1.0)
247
+ websocket-extensions (0.1.5)
248
+ zeitwerk (2.6.17)
249
+
250
+ PLATFORMS
251
+ aarch64-linux
252
+ arm-linux
253
+ arm64-darwin
254
+ x86-linux
255
+ x86_64-darwin
256
+ x86_64-linux
257
+
258
+ DEPENDENCIES
259
+ byebug
260
+ combustion
261
+ database_cleaner
262
+ gemika
263
+ mysql2
264
+ rails (~> 7.2.0)
265
+ rake
266
+ rspec (~> 3.4)
267
+ rubocop
268
+ rubocop-rails
269
+ rubocop-rspec
270
+ temporal_tables!
271
+
272
+ BUNDLED WITH
273
+ 2.5.3
@@ -0,0 +1,19 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Runtime dependencies
4
+ gem 'rails', '~> 7.2.0'
5
+ gem 'pg', '>= 0.18', '< 2.0'
6
+
7
+ # Development dependencies
8
+ gem 'rspec', '~> 3.4'
9
+ gem 'rake'
10
+ gem 'byebug'
11
+ gem 'database_cleaner'
12
+ gem 'combustion'
13
+ gem 'gemika'
14
+ gem 'rubocop'
15
+ gem 'rubocop-rails'
16
+ gem 'rubocop-rspec'
17
+
18
+ # Gem under test
19
+ gem 'temporal_tables', :path => '..'
@@ -0,0 +1,273 @@
1
+ PATH
2
+ remote: ..
3
+ specs:
4
+ temporal_tables (3.0.1)
5
+ rails (>= 6.1, < 7.3)
6
+
7
+ GEM
8
+ remote: https://rubygems.org/
9
+ specs:
10
+ actioncable (7.2.0)
11
+ actionpack (= 7.2.0)
12
+ activesupport (= 7.2.0)
13
+ nio4r (~> 2.0)
14
+ websocket-driver (>= 0.6.1)
15
+ zeitwerk (~> 2.6)
16
+ actionmailbox (7.2.0)
17
+ actionpack (= 7.2.0)
18
+ activejob (= 7.2.0)
19
+ activerecord (= 7.2.0)
20
+ activestorage (= 7.2.0)
21
+ activesupport (= 7.2.0)
22
+ mail (>= 2.8.0)
23
+ actionmailer (7.2.0)
24
+ actionpack (= 7.2.0)
25
+ actionview (= 7.2.0)
26
+ activejob (= 7.2.0)
27
+ activesupport (= 7.2.0)
28
+ mail (>= 2.8.0)
29
+ rails-dom-testing (~> 2.2)
30
+ actionpack (7.2.0)
31
+ actionview (= 7.2.0)
32
+ activesupport (= 7.2.0)
33
+ nokogiri (>= 1.8.5)
34
+ racc
35
+ rack (>= 2.2.4, < 3.2)
36
+ rack-session (>= 1.0.1)
37
+ rack-test (>= 0.6.3)
38
+ rails-dom-testing (~> 2.2)
39
+ rails-html-sanitizer (~> 1.6)
40
+ useragent (~> 0.16)
41
+ actiontext (7.2.0)
42
+ actionpack (= 7.2.0)
43
+ activerecord (= 7.2.0)
44
+ activestorage (= 7.2.0)
45
+ activesupport (= 7.2.0)
46
+ globalid (>= 0.6.0)
47
+ nokogiri (>= 1.8.5)
48
+ actionview (7.2.0)
49
+ activesupport (= 7.2.0)
50
+ builder (~> 3.1)
51
+ erubi (~> 1.11)
52
+ rails-dom-testing (~> 2.2)
53
+ rails-html-sanitizer (~> 1.6)
54
+ activejob (7.2.0)
55
+ activesupport (= 7.2.0)
56
+ globalid (>= 0.3.6)
57
+ activemodel (7.2.0)
58
+ activesupport (= 7.2.0)
59
+ activerecord (7.2.0)
60
+ activemodel (= 7.2.0)
61
+ activesupport (= 7.2.0)
62
+ timeout (>= 0.4.0)
63
+ activestorage (7.2.0)
64
+ actionpack (= 7.2.0)
65
+ activejob (= 7.2.0)
66
+ activerecord (= 7.2.0)
67
+ activesupport (= 7.2.0)
68
+ marcel (~> 1.0)
69
+ activesupport (7.2.0)
70
+ base64
71
+ bigdecimal
72
+ concurrent-ruby (~> 1.0, >= 1.3.1)
73
+ connection_pool (>= 2.2.5)
74
+ drb
75
+ i18n (>= 1.6, < 2)
76
+ logger (>= 1.4.2)
77
+ minitest (>= 5.1)
78
+ securerandom (>= 0.3)
79
+ tzinfo (~> 2.0, >= 2.0.5)
80
+ ast (2.4.2)
81
+ base64 (0.2.0)
82
+ bigdecimal (3.1.8)
83
+ builder (3.3.0)
84
+ byebug (11.1.3)
85
+ combustion (1.5.0)
86
+ activesupport (>= 3.0.0)
87
+ railties (>= 3.0.0)
88
+ thor (>= 0.14.6)
89
+ concurrent-ruby (1.3.4)
90
+ connection_pool (2.4.1)
91
+ crass (1.0.6)
92
+ database_cleaner (2.0.2)
93
+ database_cleaner-active_record (>= 2, < 3)
94
+ database_cleaner-active_record (2.2.0)
95
+ activerecord (>= 5.a)
96
+ database_cleaner-core (~> 2.0.0)
97
+ database_cleaner-core (2.0.1)
98
+ date (3.3.4)
99
+ diff-lcs (1.5.1)
100
+ drb (2.2.1)
101
+ erubi (1.13.0)
102
+ gemika (0.8.3)
103
+ globalid (1.2.1)
104
+ activesupport (>= 6.1)
105
+ i18n (1.14.5)
106
+ concurrent-ruby (~> 1.0)
107
+ io-console (0.7.2)
108
+ irb (1.14.0)
109
+ rdoc (>= 4.0.0)
110
+ reline (>= 0.4.2)
111
+ json (2.7.2)
112
+ language_server-protocol (3.17.0.3)
113
+ logger (1.6.0)
114
+ loofah (2.22.0)
115
+ crass (~> 1.0.2)
116
+ nokogiri (>= 1.12.0)
117
+ mail (2.8.1)
118
+ mini_mime (>= 0.1.1)
119
+ net-imap
120
+ net-pop
121
+ net-smtp
122
+ marcel (1.0.4)
123
+ mini_mime (1.1.5)
124
+ minitest (5.24.1)
125
+ net-imap (0.4.14)
126
+ date
127
+ net-protocol
128
+ net-pop (0.1.2)
129
+ net-protocol
130
+ net-protocol (0.2.2)
131
+ timeout
132
+ net-smtp (0.5.0)
133
+ net-protocol
134
+ nio4r (2.7.3)
135
+ nokogiri (1.16.7-aarch64-linux)
136
+ racc (~> 1.4)
137
+ nokogiri (1.16.7-arm-linux)
138
+ racc (~> 1.4)
139
+ nokogiri (1.16.7-arm64-darwin)
140
+ racc (~> 1.4)
141
+ nokogiri (1.16.7-x86-linux)
142
+ racc (~> 1.4)
143
+ nokogiri (1.16.7-x86_64-darwin)
144
+ racc (~> 1.4)
145
+ nokogiri (1.16.7-x86_64-linux)
146
+ racc (~> 1.4)
147
+ parallel (1.26.2)
148
+ parser (3.3.4.2)
149
+ ast (~> 2.4.1)
150
+ racc
151
+ pg (1.5.7)
152
+ psych (5.1.2)
153
+ stringio
154
+ racc (1.8.1)
155
+ rack (3.1.7)
156
+ rack-session (2.0.0)
157
+ rack (>= 3.0.0)
158
+ rack-test (2.1.0)
159
+ rack (>= 1.3)
160
+ rackup (2.1.0)
161
+ rack (>= 3)
162
+ webrick (~> 1.8)
163
+ rails (7.2.0)
164
+ actioncable (= 7.2.0)
165
+ actionmailbox (= 7.2.0)
166
+ actionmailer (= 7.2.0)
167
+ actionpack (= 7.2.0)
168
+ actiontext (= 7.2.0)
169
+ actionview (= 7.2.0)
170
+ activejob (= 7.2.0)
171
+ activemodel (= 7.2.0)
172
+ activerecord (= 7.2.0)
173
+ activestorage (= 7.2.0)
174
+ activesupport (= 7.2.0)
175
+ bundler (>= 1.15.0)
176
+ railties (= 7.2.0)
177
+ rails-dom-testing (2.2.0)
178
+ activesupport (>= 5.0.0)
179
+ minitest
180
+ nokogiri (>= 1.6)
181
+ rails-html-sanitizer (1.6.0)
182
+ loofah (~> 2.21)
183
+ nokogiri (~> 1.14)
184
+ railties (7.2.0)
185
+ actionpack (= 7.2.0)
186
+ activesupport (= 7.2.0)
187
+ irb (~> 1.13)
188
+ rackup (>= 1.0.0)
189
+ rake (>= 12.2)
190
+ thor (~> 1.0, >= 1.2.2)
191
+ zeitwerk (~> 2.6)
192
+ rainbow (3.1.1)
193
+ rake (13.2.1)
194
+ rdoc (6.7.0)
195
+ psych (>= 4.0.0)
196
+ regexp_parser (2.9.2)
197
+ reline (0.5.9)
198
+ io-console (~> 0.5)
199
+ rexml (3.3.5)
200
+ strscan
201
+ rspec (3.13.0)
202
+ rspec-core (~> 3.13.0)
203
+ rspec-expectations (~> 3.13.0)
204
+ rspec-mocks (~> 3.13.0)
205
+ rspec-core (3.13.0)
206
+ rspec-support (~> 3.13.0)
207
+ rspec-expectations (3.13.1)
208
+ diff-lcs (>= 1.2.0, < 2.0)
209
+ rspec-support (~> 3.13.0)
210
+ rspec-mocks (3.13.1)
211
+ diff-lcs (>= 1.2.0, < 2.0)
212
+ rspec-support (~> 3.13.0)
213
+ rspec-support (3.13.1)
214
+ rubocop (1.65.1)
215
+ json (~> 2.3)
216
+ language_server-protocol (>= 3.17.0)
217
+ parallel (~> 1.10)
218
+ parser (>= 3.3.0.2)
219
+ rainbow (>= 2.2.2, < 4.0)
220
+ regexp_parser (>= 2.4, < 3.0)
221
+ rexml (>= 3.2.5, < 4.0)
222
+ rubocop-ast (>= 1.31.1, < 2.0)
223
+ ruby-progressbar (~> 1.7)
224
+ unicode-display_width (>= 2.4.0, < 3.0)
225
+ rubocop-ast (1.32.0)
226
+ parser (>= 3.3.1.0)
227
+ rubocop-rails (2.25.1)
228
+ activesupport (>= 4.2.0)
229
+ rack (>= 1.1)
230
+ rubocop (>= 1.33.0, < 2.0)
231
+ rubocop-ast (>= 1.31.1, < 2.0)
232
+ rubocop-rspec (3.0.4)
233
+ rubocop (~> 1.61)
234
+ ruby-progressbar (1.13.0)
235
+ securerandom (0.3.1)
236
+ stringio (3.1.1)
237
+ strscan (3.1.0)
238
+ thor (1.3.1)
239
+ timeout (0.4.1)
240
+ tzinfo (2.0.6)
241
+ concurrent-ruby (~> 1.0)
242
+ unicode-display_width (2.5.0)
243
+ useragent (0.16.10)
244
+ webrick (1.8.1)
245
+ websocket-driver (0.7.6)
246
+ websocket-extensions (>= 0.1.0)
247
+ websocket-extensions (0.1.5)
248
+ zeitwerk (2.6.17)
249
+
250
+ PLATFORMS
251
+ aarch64-linux
252
+ arm-linux
253
+ arm64-darwin
254
+ x86-linux
255
+ x86_64-darwin
256
+ x86_64-linux
257
+
258
+ DEPENDENCIES
259
+ byebug
260
+ combustion
261
+ database_cleaner
262
+ gemika
263
+ pg (>= 0.18, < 2.0)
264
+ rails (~> 7.2.0)
265
+ rake
266
+ rspec (~> 3.4)
267
+ rubocop
268
+ rubocop-rails
269
+ rubocop-rspec
270
+ temporal_tables!
271
+
272
+ BUNDLED WITH
273
+ 2.5.3
@@ -7,6 +7,11 @@ module TemporalTables
7
7
  execute "drop trigger #{table_name}_ai on #{table_name}"
8
8
  execute "drop trigger #{table_name}_au on #{table_name}"
9
9
  execute "drop trigger #{table_name}_ad on #{table_name}"
10
+
11
+ # remove functions that where created, too
12
+ execute "drop function #{table_name}_ai()"
13
+ execute "drop function #{table_name}_au()"
14
+ execute "drop function #{table_name}_ad()"
10
15
  end
11
16
 
12
17
  def create_temporal_triggers(table_name, primary_key) # rubocop:disable Metrics/MethodLength
@@ -33,13 +33,15 @@ module TemporalTables
33
33
 
34
34
  def threadify_at
35
35
  if at_value && !Thread.current[:at_time]
36
- Thread.current[:at_time] = at_value
37
- result = yield
38
- Thread.current[:at_time] = nil
36
+ begin
37
+ Thread.current[:at_time] = at_value
38
+ yield
39
+ ensure
40
+ Thread.current[:at_time] = nil
41
+ end
39
42
  else
40
- result = yield
43
+ yield
41
44
  end
42
- result
43
45
  end
44
46
 
45
47
  def limited_ids_for(*args)
@@ -39,7 +39,7 @@ module TemporalTables
39
39
  t.datetime :eff_to, null: false, limit: 6, default: TemporalTables::END_OF_TIME
40
40
 
41
41
  columns(table_name).each do |c|
42
- column_options = { limit: c.limit }
42
+ column_options = { limit: c.limit, array: c.try(:array) }.compact
43
43
  column_type = c.type
44
44
  if column_type == :enum
45
45
  enum_type = c.sql_type_metadata.sql_type
@@ -74,7 +74,7 @@ module TemporalTables
74
74
  return unless table_exists?(temporal_name(table_name))
75
75
 
76
76
  drop_temporal_triggers table_name
77
- drop_table_without_temporal temporal_name(table_name)
77
+ drop_table temporal_name(table_name)
78
78
  end
79
79
 
80
80
  def drop_table(table_name, **options)
@@ -172,7 +172,9 @@ module TemporalTables
172
172
  # exclude unique constraints for temporal tables
173
173
  name: index_name,
174
174
  length: index.lengths,
175
- order: index.orders
175
+ order: index.orders,
176
+ using: index.using,
177
+ opclass: index.opclasses
176
178
  )
177
179
  end
178
180
  end
@@ -42,8 +42,7 @@ module TemporalTables
42
42
  association.macro, association.name,
43
43
  **association.options.merge(
44
44
  class_name: clazz.name,
45
- foreign_key: association.foreign_key,
46
- primary_key: clazz.orig_class.primary_key
45
+ foreign_key: association.foreign_key
47
46
  )
48
47
  )
49
48
  end
@@ -60,6 +59,9 @@ module TemporalTables
60
59
  type_name += 'History' unless type_name =~ /History\Z/
61
60
 
62
61
  begin
62
+ # Calling .history makes sure history class is created
63
+ type_name.sub(/History$/, '').constantize.history
64
+
63
65
  super
64
66
  rescue ActiveRecord::SubclassNotFound
65
67
  superclass.send(:find_sti_class, type_name)
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module TemporalTables
4
- VERSION = '3.0.0'
4
+ VERSION = '3.0.2'
5
5
  end
@@ -62,6 +62,15 @@ describe Person do
62
62
  end
63
63
  end
64
64
 
65
+ describe 'creating a join query' do
66
+ it 'correctly joins even after generating sql has failed before' do
67
+ expect { Person.history.at(100.years.ago).joins(:warts).where(x: proc {}).to_sql }.to raise_error(TypeError)
68
+
69
+ # it still fetches the history correctly
70
+ expect(Person.history.at(Time.current).joins(:warts)).to be_present
71
+ end
72
+ end
73
+
65
74
  describe 'when preloading associations' do
66
75
  let(:orig_emily) { emily.history.at(@init_time).preload(:warts).first }
67
76
 
@@ -147,6 +156,13 @@ describe Person do
147
156
  end
148
157
  end
149
158
 
159
+ describe 'when working with STI and using superclass history' do
160
+ it 'allows to fetch history entry of subclass history' do
161
+ Broom.create person: emily, model: 'Cackler 2000'
162
+ expect(FlyingMachine.history.last.class.name).to eql('BroomHistory')
163
+ end
164
+ end
165
+
150
166
  describe 'when working with STI one level deep' do
151
167
  let!(:broom) { Broom.create person: emily, model: 'Cackler 2000' }
152
168
 
@@ -191,6 +207,22 @@ describe Person do
191
207
  end
192
208
  end
193
209
 
210
+ if TemporalTables::DatabaseAdapter.adapter_name != 'mysql'
211
+ describe 'when changing a creature with an array column' do
212
+ let!(:cat) { Cat.create name: 'Mr. Mittens', nicknames: %w[Blacky Kitty] }
213
+
214
+ before do
215
+ cat.update nicknames: %w[Cutie Mizie]
216
+ end
217
+
218
+ it 'show nicknames correctly' do
219
+ expect(cat.nicknames).to eq(%w[Cutie Mizie])
220
+ expect(cat.history.last.nicknames).to eq(%w[Cutie Mizie])
221
+ expect(cat.history.first.nicknames).to eq(%w[Blacky Kitty])
222
+ end
223
+ end
224
+ end
225
+
194
226
  # The following tests PKs with names other than "id"
195
227
  describe 'when spawning and renaming a creature with PK not named id' do
196
228
  let!(:dog) { Dog.create name: 'Fido' }
@@ -264,3 +296,19 @@ describe Bird do
264
296
  end
265
297
  end
266
298
  end
299
+
300
+ describe Hamster do
301
+ context 'with tables that have non-default primary key names' do
302
+ let(:hamster) { Hamster.create name: 'Fluffy' }
303
+ let(:wheel) { HamsterWheel.create hamster: hamster }
304
+
305
+ it 'can create instance of class with nested class name with history entries' do
306
+ expect(hamster).not_to be_nil
307
+ expect(wheel).not_to be_nil
308
+ expect(hamster.hamster_wheel).not_to be_nil
309
+ hamster_history = Hamster.history.at(Time.now.utc).first
310
+ expect(hamster_history).not_to be_nil
311
+ expect(hamster_history.hamster_wheel).not_to be_nil
312
+ end
313
+ end
314
+ end
@@ -0,0 +1,7 @@
1
+ # frozen_string_literal: true
2
+
3
+ class Hamster < ActiveRecord::Base
4
+ self.primary_key = :uuid
5
+
6
+ has_one :hamster_wheel, foreign_key: :hamster_uuid, inverse_of: :hamster
7
+ end
@@ -0,0 +1,5 @@
1
+ # frozen_string_literal: true
2
+
3
+ class HamsterWheel < ActiveRecord::Base
4
+ belongs_to :hamster, foreign_key: :hamster_uuid, primary_key: :uuid, inverse_of: :hamster_wheel
5
+ end
@@ -9,6 +9,7 @@ end
9
9
  ActiveRecord::Schema.define do
10
10
  if postgres
11
11
  enable_extension 'pgcrypto'
12
+ enable_extension 'pg_trgm'
12
13
  execute <<-SQL
13
14
  CREATE TYPE cat_breed AS ENUM ('ragdoll', 'persian', 'sphynx');
14
15
  SQL
@@ -42,6 +43,7 @@ ActiveRecord::Schema.define do
42
43
  t.string :name
43
44
  t.string :color
44
45
  t.column :breed, (postgres ? :cat_breed : :string), null: false, default: 'ragdoll'
46
+ t.string :nicknames, array: true if postgres
45
47
  end
46
48
 
47
49
  create_table :cat_lives, id: (postgres ? :uuid : :integer), temporal: true do |t|
@@ -69,4 +71,24 @@ ActiveRecord::Schema.define do
69
71
  t.belongs_to :bird, type: (postgres ? :uuid : :integer)
70
72
  t.integer :height
71
73
  end
74
+
75
+ if postgres
76
+ create_table :hamsters, id: false do |t|
77
+ t.column :uuid, :uuid, default: 'gen_random_uuid()'
78
+ t.string :name
79
+ t.index "((uuid)::text || ' '::text || (name)::text) gin_trgm_ops",
80
+ name: :uuid_name_index_with_opclass_and_using, opclass: :gin_trgm_ops, using: :gin
81
+ end
82
+ execute 'ALTER TABLE hamsters ADD PRIMARY KEY (uuid);'
83
+ add_temporal_table :hamsters
84
+ else
85
+ create_table :hamsters, primary_key: :uuid, temporal: true do |t|
86
+ t.string :name
87
+ end
88
+ end
89
+
90
+ create_table :hamster_wheels, id: (postgres ? :uuid : :integer), temporal: true do |t|
91
+ t.column :hamster_uuid, (postgres ? :uuid : :bigint), null: false
92
+ t.foreign_key :hamsters, column: :hamster_uuid, primary_key: :uuid
93
+ end
72
94
  end
@@ -1,13 +1,43 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- module TemporalTables
4
- module DatabaseAdapter
5
- def self.adapter_name
6
- if Gemika::Env.gem?('pg')
7
- 'postgresql'
8
- elsif Gemika::Env.gem?('mysql2')
9
- 'mysql'
10
- end
3
+ def adapter_name
4
+ if Gemika::Env.gem?('pg')
5
+ 'postgresql'
6
+ elsif Gemika::Env.gem?('mysql2')
7
+ 'mysql'
8
+ else
9
+ raise 'Cannot determine adapter'
10
+ end
11
+ end
12
+
13
+ def table_exists?(name)
14
+ ActiveRecord::Base.connection.table_exists?(name)
15
+ end
16
+
17
+ def function_exists?(name)
18
+ case adapter_name
19
+ when 'postgresql'
20
+ begin
21
+ ActiveRecord::Base.connection.execute("select(pg_get_functiondef('#{name}'::regprocedure))").present?
22
+ rescue ActiveRecord::StatementInvalid
23
+ false
11
24
  end
25
+ when 'mysql' then raise NotImplementedError
26
+ else raise "Unknown adapter #{adapter_name}"
27
+ end
28
+ end
29
+
30
+ def trigger_exists?(name) # rubocop:disable Metrics/MethodLength
31
+ case adapter_name
32
+ when 'postgresql'
33
+ ActiveRecord::Base.connection.execute(
34
+ "select (pg_get_triggerdef(oid)) FROM pg_trigger WHERE tgname = '#{name}'"
35
+ ).first.present?
36
+ when 'mysql'
37
+ ActiveRecord::Base.connection.execute(
38
+ 'SHOW TRIGGERS FROM temporal_tables_test'
39
+ ).find { |row| row.first == name }.present?
40
+ else
41
+ raise "Unknown adapter #{adapter_name}"
12
42
  end
13
43
  end
@@ -0,0 +1,32 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'spec_helper'
4
+
5
+ describe TemporalTables::TemporalAdapter do
6
+ describe '#remove_temporal_table' do
7
+ it 'correctly removes history table, functions and triggers' do
8
+ skip 'mysql has no functions' if adapter_name == 'mysql'
9
+
10
+ expect do
11
+ ActiveRecord::Schema.define { remove_temporal_table :people }
12
+ end.to change { table_exists?('people_h') }.from(true).to(false)
13
+ .and change { function_exists?('people_ai()') }.from(true).to(false)
14
+ .and change { function_exists?('people_au()') }.from(true).to(false)
15
+ .and change { function_exists?('people_ad()') }.from(true).to(false)
16
+ .and change { trigger_exists?('people_ai') }.from(true).to(false)
17
+ .and change { trigger_exists?('people_au') }.from(true).to(false)
18
+ .and change { trigger_exists?('people_ad') }.from(true).to(false)
19
+ end
20
+
21
+ it 'correctly removes history table and triggers' do
22
+ skip 'other adapters than mysql have functions, too' if adapter_name != 'mysql'
23
+
24
+ expect do
25
+ ActiveRecord::Schema.define { remove_temporal_table :people }
26
+ end.to change { table_exists?('people_h') }.from(true).to(false)
27
+ .and change { trigger_exists?('people_ai') }.from(true).to(false)
28
+ .and change { trigger_exists?('people_au') }.from(true).to(false)
29
+ .and change { trigger_exists?('people_ad') }.from(true).to(false)
30
+ end
31
+ end
32
+ end
@@ -24,7 +24,7 @@ Gem::Specification.new do |gem|
24
24
  gem.required_ruby_version = '>= 3.0.0'
25
25
  gem.metadata = { 'rubygems_mfa_required' => 'true' }
26
26
 
27
- gem.add_dependency 'rails', '>= 6.1', '< 7.2'
27
+ gem.add_dependency 'rails', '>= 6.1', '< 7.3'
28
28
  gem.add_development_dependency 'combustion', '~> 1'
29
29
  gem.add_development_dependency 'database_cleaner'
30
30
  gem.add_development_dependency 'gemika', '~> 0.8'
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: temporal_tables
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.0.0
4
+ version: 3.0.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Brent Kroeker
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-01-11 00:00:00.000000000 Z
11
+ date: 2024-10-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails
@@ -19,7 +19,7 @@ dependencies:
19
19
  version: '6.1'
20
20
  - - "<"
21
21
  - !ruby/object:Gem::Version
22
- version: '7.2'
22
+ version: '7.3'
23
23
  type: :runtime
24
24
  prerelease: false
25
25
  version_requirements: !ruby/object:Gem::Requirement
@@ -29,7 +29,7 @@ dependencies:
29
29
  version: '6.1'
30
30
  - - "<"
31
31
  - !ruby/object:Gem::Version
32
- version: '7.2'
32
+ version: '7.3'
33
33
  - !ruby/object:Gem::Dependency
34
34
  name: combustion
35
35
  requirement: !ruby/object:Gem::Requirement
@@ -201,6 +201,10 @@ files:
201
201
  - gemfiles/Gemfile.7.1.mysql.lock
202
202
  - gemfiles/Gemfile.7.1.pg
203
203
  - gemfiles/Gemfile.7.1.pg.lock
204
+ - gemfiles/Gemfile.7.2.mysql
205
+ - gemfiles/Gemfile.7.2.mysql.lock
206
+ - gemfiles/Gemfile.7.2.pg
207
+ - gemfiles/Gemfile.7.2.pg.lock
204
208
  - lib/temporal_tables.rb
205
209
  - lib/temporal_tables/arel_table.rb
206
210
  - lib/temporal_tables/association_extensions.rb
@@ -224,6 +228,8 @@ files:
224
228
  - spec/internal/app/models/coven.rb
225
229
  - spec/internal/app/models/dog.rb
226
230
  - spec/internal/app/models/flying_machine.rb
231
+ - spec/internal/app/models/hamster.rb
232
+ - spec/internal/app/models/hamster_wheel.rb
227
233
  - spec/internal/app/models/person.rb
228
234
  - spec/internal/app/models/rocket_broom.rb
229
235
  - spec/internal/app/models/wart.rb
@@ -234,12 +240,13 @@ files:
234
240
  - spec/internal/public/favicon.ico
235
241
  - spec/spec_helper.rb
236
242
  - spec/support/database.rb
243
+ - spec/temporal_tables/temporal_adapter_spec.rb
237
244
  - temporal_tables.gemspec
238
245
  homepage: ''
239
246
  licenses: []
240
247
  metadata:
241
248
  rubygems_mfa_required: 'true'
242
- post_install_message:
249
+ post_install_message:
243
250
  rdoc_options: []
244
251
  require_paths:
245
252
  - lib
@@ -254,8 +261,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
254
261
  - !ruby/object:Gem::Version
255
262
  version: '0'
256
263
  requirements: []
257
- rubygems_version: 3.4.10
258
- signing_key:
264
+ rubygems_version: 3.5.3
265
+ signing_key:
259
266
  specification_version: 4
260
267
  summary: Tracks all history of changes to a table automatically in a history table.
261
268
  test_files:
@@ -268,6 +275,8 @@ test_files:
268
275
  - spec/internal/app/models/coven.rb
269
276
  - spec/internal/app/models/dog.rb
270
277
  - spec/internal/app/models/flying_machine.rb
278
+ - spec/internal/app/models/hamster.rb
279
+ - spec/internal/app/models/hamster_wheel.rb
271
280
  - spec/internal/app/models/person.rb
272
281
  - spec/internal/app/models/rocket_broom.rb
273
282
  - spec/internal/app/models/wart.rb
@@ -278,3 +287,4 @@ test_files:
278
287
  - spec/internal/public/favicon.ico
279
288
  - spec/spec_helper.rb
280
289
  - spec/support/database.rb
290
+ - spec/temporal_tables/temporal_adapter_spec.rb