activerecord-spanner-adapter 1.4.1 → 1.4.2

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 2f432fe0aba4f4aaa5d2bcc689d8337fb944b393a8f71e11731f21bd2bc1aad5
4
- data.tar.gz: 3dd03abd67174f3b7239d2c19a18ae0df756ad009988ae8ecddbd2369eb7164b
3
+ metadata.gz: cfd752e3287084b088f8d8e7ba09d2644ec8bb3c5f699b80425ed7babc74ac1f
4
+ data.tar.gz: 2c72dad4930f696935f5a8ebe61db261da7ac11d3f8149b22f7bbe0bae900755
5
5
  SHA512:
6
- metadata.gz: d99d549f841dcb2facf0438335b06449f70e033ad9c030fa2396fff16650e8a9ee653157ee8699cd9e473515630766e2f9b3e117acc73d6ddf35fb8ee83724a1
7
- data.tar.gz: 4e207e65e60ab191c7479f7ae47c9fdd0ebac9a5ca54505841155428b88dc60c379dae96db6e43cd17e8c2bc2af9d9b7b5b4c5ae091281416cdf9d7616edaf9c
6
+ metadata.gz: 77e3afc2326448c8e7de3e838baf09d87beb631c28129c2588e14ae675cd20ea0bf4c18e89d2e1ec456fb519530dd9d968838fcfc2cab32d5dc66dd5fb586025
7
+ data.tar.gz: e4525d57eab407c0122a26ec412533e29e3ef51e942577a0686e36d22ddaf1a0243d30cc46ee350386b4ba292c9dc4a81dd7215e0beba5fc0eb08577f89a5ed1
@@ -0,0 +1,7 @@
1
+ bumpMinorPreMajor: true
2
+ handleGHRelease: true
3
+ manifest: true
4
+ monorepoTags: true
5
+ packageName: activerecord-spanner-adapter
6
+ primaryBranch: main
7
+ releaseType: ruby-yoshi
@@ -0,0 +1 @@
1
+ enabled: true
@@ -18,7 +18,7 @@ jobs:
18
18
  strategy:
19
19
  max-parallel: 4
20
20
  matrix:
21
- ruby: ["2.6", "2.7", "3.0", "3.1"]
21
+ ruby: ["2.6", "2.7", "3.0", "3.1", "3.2"]
22
22
  ar: ["~> 6.0.6", "~> 6.1.7", "~> 7.0.4"]
23
23
  # Exclude combinations that are not supported.
24
24
  exclude:
@@ -26,6 +26,8 @@ jobs:
26
26
  ar: "~> 6.0.6"
27
27
  - ruby: "3.1"
28
28
  ar: "~> 6.0.6"
29
+ - ruby: "3.2"
30
+ ar: "~> 6.0.6"
29
31
  - ruby: "2.6"
30
32
  ar: "~> 7.0.4"
31
33
  env:
@@ -10,7 +10,7 @@ jobs:
10
10
  strategy:
11
11
  max-parallel: 4
12
12
  matrix:
13
- ruby: ["2.6", "2.7", "3.0", "3.1"]
13
+ ruby: ["2.6", "2.7", "3.0", "3.1", "3.2"]
14
14
  ar: ["~> 6.0.6", "~> 6.1.7", "~> 7.0.4"]
15
15
  # Exclude combinations that are not supported.
16
16
  exclude:
@@ -18,6 +18,8 @@ jobs:
18
18
  ar: "~> 6.0.6"
19
19
  - ruby: "3.1"
20
20
  ar: "~> 6.0.6"
21
+ - ruby: "3.2"
22
+ ar: "~> 6.0.6"
21
23
  - ruby: "2.6"
22
24
  ar: "~> 7.0.4"
23
25
  env:
@@ -19,8 +19,8 @@ jobs:
19
19
  max-parallel: 4
20
20
  matrix:
21
21
  # Run acceptance tests all supported combinations of Ruby and ActiveRecord.
22
- ruby: [2.6, 2.7, 3.0, 3.1]
23
- ar: [6.0.0, 6.0.1, 6.0.2.2, 6.0.3.7, 6.0.4, 6.1.3.2, 6.1.4.7, 6.1.5.1, 6.1.6.1, 7.0.2.4, 7.0.3.1, 7.0.4]
22
+ ruby: [2.6, 2.7, 3.0, 3.1, 3.2]
23
+ ar: [6.0.0, 6.0.1, 6.0.2.2, 6.0.3.7, 6.0.4, 6.1.3.2, 6.1.4.7, 6.1.5.1, 6.1.6.1, 7.0.2.4, 7.0.3.1, 7.0.4, 7.0.5]
24
24
  # Exclude combinations that are not supported.
25
25
  exclude:
26
26
  - ruby: 3.0
@@ -43,12 +43,24 @@ jobs:
43
43
  ar: 6.0.3.7
44
44
  - ruby: 3.1
45
45
  ar: 6.0.4
46
+ - ruby: 3.2
47
+ ar: 6.0.0
48
+ - ruby: 3.2
49
+ ar: 6.0.1
50
+ - ruby: 3.2
51
+ ar: 6.0.2.2
52
+ - ruby: 3.2
53
+ ar: 6.0.3.7
54
+ - ruby: 3.2
55
+ ar: 6.0.4
46
56
  - ruby: 2.6
47
57
  ar: 7.0.2.4
48
58
  - ruby: 2.6
49
59
  ar: 7.0.3.1
50
60
  - ruby: 2.6
51
61
  ar: 7.0.4
62
+ - ruby: 2.6
63
+ ar: 7.0.5
52
64
  env:
53
65
  AR_VERSION: ${{ matrix.ar }}
54
66
  steps:
@@ -11,8 +11,8 @@ jobs:
11
11
  max-parallel: 4
12
12
  matrix:
13
13
  # Run unit tests all supported combinations of Ruby and ActiveRecord.
14
- ruby: [2.6, 2.7, 3.0, 3.1]
15
- ar: [6.0.0, 6.0.1, 6.0.2.2, 6.0.3.7, 6.0.4, 6.1.3.2, 6.1.4.7, 6.1.5.1, 6.1.6.1, 7.0.2.4, 7.0.3.1, 7.0.4]
14
+ ruby: [2.6, 2.7, 3.0, 3.1, 3.2]
15
+ ar: [6.0.0, 6.0.1, 6.0.2.2, 6.0.3.7, 6.0.4, 6.1.3.2, 6.1.4.7, 6.1.5.1, 6.1.6.1, 7.0.2.4, 7.0.3.1, 7.0.4, 7.0.5]
16
16
  # Exclude combinations that are not supported.
17
17
  exclude:
18
18
  - ruby: 3.0
@@ -35,12 +35,24 @@ jobs:
35
35
  ar: 6.0.3.7
36
36
  - ruby: 3.1
37
37
  ar: 6.0.4
38
+ - ruby: 3.2
39
+ ar: 6.0.0
40
+ - ruby: 3.2
41
+ ar: 6.0.1
42
+ - ruby: 3.2
43
+ ar: 6.0.2.2
44
+ - ruby: 3.2
45
+ ar: 6.0.3.7
46
+ - ruby: 3.2
47
+ ar: 6.0.4
38
48
  - ruby: 2.6
39
49
  ar: 7.0.2.4
40
50
  - ruby: 2.6
41
51
  ar: 7.0.3.1
42
52
  - ruby: 2.6
43
53
  ar: 7.0.4
54
+ - ruby: 2.6
55
+ ar: 7.0.5
44
56
  env:
45
57
  AR_VERSION: ${{ matrix.ar }}
46
58
  steps:
@@ -1,7 +1,5 @@
1
1
  name: Release-Please
2
2
  on:
3
- schedule:
4
- - cron: '57 10 * * *'
5
3
  workflow_dispatch:
6
4
  inputs:
7
5
  gem:
data/.kokoro/release.cfg CHANGED
@@ -31,3 +31,12 @@ env_vars: {
31
31
  key: "SECRET_MANAGER_KEYS"
32
32
  value: "releasetool-publish-reporter-app,releasetool-publish-reporter-googleapis-installation,releasetool-publish-reporter-pem,docuploader_service_account"
33
33
  }
34
+
35
+ # Store the packages uploaded to rubygems.org, which
36
+ # we can later use to generate SBOMs and attestations.
37
+ action {
38
+ define_artifacts {
39
+ regex: "github/ruby-spanner-activerecord/pkg/*.gem"
40
+ strip_prefix: "github"
41
+ }
42
+ }
@@ -1,3 +1,3 @@
1
1
  {
2
- ".": "1.4.1"
2
+ ".": "1.4.2"
3
3
  }
data/CHANGELOG.md CHANGED
@@ -1,5 +1,12 @@
1
1
  # Changelog
2
2
 
3
+ ### 1.4.2 (2023-06-01)
4
+
5
+ #### Bug Fixes
6
+
7
+ * allow functions to be default values ([#252](https://github.com/googleapis/ruby-spanner-activerecord/issues/252))
8
+ * use original types for composite primary keys ([#246](https://github.com/googleapis/ruby-spanner-activerecord/issues/246))
9
+
3
10
  ### 1.4.1 (2023-03-01)
4
11
 
5
12
  #### Bug Fixes
data/CONTRIBUTING.md CHANGED
@@ -48,10 +48,26 @@ Variable|Description|Comment
48
48
  `activerecord_tests`
49
49
 
50
50
  #### Example
51
+
51
52
  ```shell
52
53
  bundle exec rake acceptance[appdev-soda-spanner-staging,/home/Downloads/creds.json,activerecord_tests]
53
54
  ```
54
55
 
56
+ You can also use the [Cloud Spanner emulator](https://cloud.google.com/spanner/docs/emulator).
57
+
58
+ ```shell
59
+ docker run -d --rm -p 9010:9010 gcr.io/cloud-spanner-emulator/emulator
60
+ export SPANNER_EMULATOR_HOST=localhost:9010
61
+ bundle exec rake "acceptance[dummy-project,,dummy-instance,]"
62
+ ```
63
+
64
+ If you want to run only one test, you can specify a test file.
65
+
66
+ ```shell
67
+ bundle exec rake "acceptance[dummy-project,,dummy-instance,]" \
68
+ TEST=acceptance/cases/models/default_value_test.rb
69
+ ```
70
+
55
71
  ## Coding Style
56
72
 
57
73
  Please follow the established coding style in the library. The style is is
@@ -76,4 +92,4 @@ The rubocop settings depend on [googleapis/ruby-style](https://github.com/google
76
92
 
77
93
  Please note that this project is released with a Contributor Code of Conduct. By
78
94
  participating in this project you agree to abide by its terms. See
79
- {file:CODE_OF_CONDUCT.md Code of Conduct} for more information.
95
+ {file:CODE_OF_CONDUCT.md Code of Conduct} for more information.
data/Gemfile CHANGED
@@ -4,7 +4,7 @@ source "https://rubygems.org"
4
4
  gemspec
5
5
 
6
6
  gem "activerecord", ENV.fetch("AR_VERSION", "~> 6.1.6.1")
7
- gem "minitest", "~> 5.16.3"
7
+ gem "minitest", "~> 5.18.0"
8
8
  gem "pry", "~> 0.13.0"
9
9
  gem "pry-byebug", "~> 3.9.0"
10
10
 
@@ -86,7 +86,7 @@ module ActiveRecord
86
86
 
87
87
  def test_index_exists
88
88
  with_change_table do |t|
89
- if Gem::Version.new(RUBY_VERSION) >= Gem::Version.new("3")
89
+ if Gem::Version.new(RUBY_VERSION) >= Gem::Version.new("3") && ActiveRecord::gem_version <= Gem::Version.create('7.0.4')
90
90
  @connection.expect :index_exists?, nil, [:delete_me, :bar, {}]
91
91
  t.index_exists?(:bar, {})
92
92
  else
@@ -98,7 +98,7 @@ module ActiveRecord
98
98
 
99
99
  def test_index_exists_with_options
100
100
  with_change_table do |t|
101
- if Gem::Version.new(RUBY_VERSION) >= Gem::Version.new("3")
101
+ if Gem::Version.new(RUBY_VERSION) >= Gem::Version.new("3") && ActiveRecord::gem_version <= Gem::Version.create('7.0.4')
102
102
  @connection.expect :index_exists?, nil, [:delete_me, :bar, {unique: true}]
103
103
  t.index_exists?(:bar, {unique: true})
104
104
  else
@@ -0,0 +1,22 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "test_helper"
4
+ require "test_helpers/with_separate_database"
5
+
6
+ module Models
7
+ class DefaultValueTest < SpannerAdapter::TestCase
8
+ include TestHelpers::WithSeparateDatabase
9
+
10
+ class DynamicItem < ActiveRecord::Base; end
11
+
12
+ def test_dynamic_default_values
13
+ connection.create_table :dynamic_items do |t|
14
+ t.column :col_timestamp, :datetime, default: -> { "CURRENT_TIMESTAMP()" }
15
+ end
16
+
17
+ item = DynamicItem.create!
18
+ item.reload
19
+ assert(item.col_timestamp)
20
+ end
21
+ end
22
+ end
@@ -7,29 +7,100 @@
7
7
  # frozen_string_literal: true
8
8
 
9
9
  require "test_helper"
10
- require "models/singer"
11
- require "models/album_partial_disabled"
10
+ require "test_helpers/with_separate_database"
12
11
 
13
12
  module ActiveRecord
14
13
  module Model
15
- class InterleaveTest < SpannerAdapter::TestCase
16
- include SpannerAdapter::Associations::TestHelper
14
+ class InterleaveTest
15
+ class WithPartialInsertsDisabledTest < SpannerAdapter::TestCase
16
+ include SpannerAdapter::Associations::TestHelper
17
17
 
18
- attr_accessor :singer
18
+ class Singer < ActiveRecord::Base
19
+ has_many :albums, foreign_key: :singerid, dependent: :delete_all
20
+ has_many :tracks, foreign_key: :singerid
21
+ end
19
22
 
20
- def setup
21
- super
23
+ class Album < ActiveRecord::Base
24
+ self.primary_keys = :singerid, :albumid
22
25
 
23
- @singer = Singer.create first_name: "FirstName", last_name: "LastName"
24
- end
26
+ belongs_to :singer, foreign_key: :singerid
27
+
28
+ if ActiveRecord::VERSION::MAJOR >= 7
29
+ self.partial_inserts = false
30
+ end
31
+ end
32
+
33
+ attr_accessor :singer
34
+
35
+ def setup
36
+ super
25
37
 
26
- def teardown
27
- Album.destroy_all
28
- Singer.destroy_all
38
+ @singer = Singer.create first_name: "FirstName", last_name: "LastName"
39
+ end
40
+
41
+ def teardown
42
+ Album.destroy_all
43
+ Singer.destroy_all
44
+ end
45
+
46
+ def test_with_partial_inserts_disabled
47
+ Album.create! title: "Title3", singer: singer
48
+ end
29
49
  end
30
50
 
31
- def test_with_partial_inserts_disabled
32
- AlbumPartialDisabled.create! title: "Title3", singer: singer
51
+ class StringParentKeyTest < SpannerAdapter::TestCase
52
+ include TestHelpers::WithSeparateDatabase
53
+
54
+ class Singer < ActiveRecord::Base
55
+ has_many :albums, foreign_key: :singer_id
56
+ end
57
+
58
+ class Album < ActiveRecord::Base
59
+ self.primary_keys = [:singer_id, :album_id]
60
+ belongs_to :singer, foreign_key: :singer_id
61
+ end
62
+
63
+ def setup
64
+ super
65
+
66
+ connection.ddl_batch do
67
+ connection.create_table :singers, id: false do |t|
68
+ t.string :singer_id, limit: 36, primary_key: true, null: false
69
+ t.string :name, null: false
70
+ end
71
+
72
+ connection.create_table :albums, id: false do |t|
73
+ t.interleave_in :singers
74
+ t.string :singer_id, limit: 36, parent_key: true, primary_key: true, null: false
75
+ t.integer :album_id, primary_key: true, null: false
76
+ t.string :title, null: false
77
+ end
78
+ end
79
+
80
+ @singer = Singer.create!(id: SecureRandom.uuid, name: "a singer")
81
+ end
82
+
83
+ def test_create_album
84
+ Album.create!(singer: @singer, title: "an album")
85
+ end
86
+
87
+ def test_update_album
88
+ album = Album.create!(singer: @singer, title: "an album")
89
+ album.update!(title: "an album 2")
90
+ end
91
+
92
+ def test_get_album
93
+ album = Album.create!(singer: @singer, title: "an album")
94
+ got_album = Album.find([@singer.singer_id, album.album_id])
95
+ assert_equal(album, got_album)
96
+ end
97
+
98
+ def test_get_albums_as_children
99
+ album1 = Album.create!(singer: @singer, title: "album1")
100
+ album2 = Album.create!(singer: @singer, title: "album2")
101
+ albums = @singer.albums.order(:title)
102
+ assert_equal([album1, album2], albums)
103
+ end
33
104
  end
34
105
  end
35
106
  end
@@ -4,8 +4,6 @@
4
4
  # license that can be found in the LICENSE file or at
5
5
  # https://opensource.org/licenses/MIT.
6
6
 
7
- require "composite_primary_keys"
8
-
9
7
  class Album < ActiveRecord::Base
10
8
  # Register both primary key columns with composite_primary_keys
11
9
  self.primary_keys = :singerid, :albumid
@@ -15,6 +15,7 @@ require "active_support/testing/stream"
15
15
  require "activerecord-spanner-adapter"
16
16
  require "active_record/connection_adapters/spanner_adapter"
17
17
  require "securerandom"
18
+ require "composite_primary_keys"
18
19
 
19
20
  # rubocop:disable Style/GlobalVars
20
21
 
@@ -0,0 +1,47 @@
1
+ # Copyright 2023 Google LLC
2
+ #
3
+ # Use of this source code is governed by an MIT-style
4
+ # license that can be found in the LICENSE file or at
5
+ # https://opensource.org/licenses/MIT.
6
+
7
+ require "securerandom"
8
+
9
+ require "active_record/tasks/spanner_database_tasks"
10
+
11
+ module TestHelpers
12
+ module WithSeparateDatabase
13
+ attr_reader :connection
14
+
15
+ def setup
16
+ spanner_adapter_connection.create_database
17
+ ActiveRecord::Base.establish_connection connection_config
18
+ @connection = ActiveRecord::Base.connection
19
+ end
20
+
21
+ def teardown
22
+ spanner_adapter_connection.database.drop
23
+ end
24
+
25
+ def connection_config
26
+ {
27
+ "adapter" => "spanner",
28
+ "emulator_host" => ENV["SPANNER_EMULATOR_HOST"],
29
+ "project" => ENV["SPANNER_TEST_PROJECT"],
30
+ "instance" => ENV["SPANNER_TEST_INSTANCE"],
31
+ "credentials" => ENV["SPANNER_TEST_KEYFILE"],
32
+ "database" => database_id,
33
+ }
34
+ end
35
+
36
+ def database_id
37
+ @database_id ||= "ar-test-#{SecureRandom.hex 4}"
38
+ end
39
+
40
+ def spanner_adapter_connection
41
+ @spanner_adapter_connection ||=
42
+ ActiveRecordSpannerAdapter::Connection.new(
43
+ connection_config.symbolize_keys
44
+ )
45
+ end
46
+ end
47
+ end
@@ -148,8 +148,10 @@ module ActiveRecord
148
148
 
149
149
  def self._set_composite_primary_key_value primary_key, values
150
150
  value = values[primary_key]
151
+ type = ActiveModel::Type::BigInteger.new
151
152
 
152
153
  if value.is_a? ActiveModel::Attribute
154
+ type = value.type
153
155
  value = value.value
154
156
  end
155
157
 
@@ -161,8 +163,7 @@ module ActiveRecord
161
163
 
162
164
  values[primary_key] =
163
165
  if ActiveRecord::VERSION::MAJOR >= 7
164
- ActiveModel::Attribute.from_database primary_key, value,
165
- ActiveModel::Type::BigInteger.new
166
+ ActiveModel::Attribute.from_database primary_key, value, type
166
167
  else
167
168
  value
168
169
  end
@@ -79,6 +79,14 @@ module ActiveRecordSpannerAdapter
79
79
  column_name = row["COLUMN_NAME"]
80
80
  options = column_options[column_name]
81
81
 
82
+ default = row["COLUMN_DEFAULT"]
83
+ default_function = row["GENERATION_EXPRESSION"]
84
+
85
+ if /\w+\(.*\)/.match?(default)
86
+ default_function ||= default
87
+ default = nil
88
+ end
89
+
82
90
  Table::Column.new \
83
91
  table_name,
84
92
  column_name,
@@ -87,8 +95,8 @@ module ActiveRecordSpannerAdapter
87
95
  allow_commit_timestamp: options["allow_commit_timestamp"],
88
96
  ordinal_position: row["ORDINAL_POSITION"],
89
97
  nullable: row["IS_NULLABLE"] == "YES",
90
- default: row["COLUMN_DEFAULT"],
91
- default_function: row["GENERATION_EXPRESSION"],
98
+ default: default,
99
+ default_function: default_function,
92
100
  generated: row["GENERATION_EXPRESSION"].present?
93
101
  end
94
102
  end
@@ -5,5 +5,5 @@
5
5
  # https://opensource.org/licenses/MIT.
6
6
 
7
7
  module ActiveRecordSpannerAdapter
8
- VERSION = "1.4.1".freeze
8
+ VERSION = "1.4.2".freeze
9
9
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: activerecord-spanner-adapter
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.4.1
4
+ version: 1.4.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Google LLC
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2023-03-02 00:00:00.000000000 Z
11
+ date: 2023-06-01 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: google-cloud-spanner
@@ -221,6 +221,8 @@ extra_rdoc_files: []
221
221
  files:
222
222
  - ".github/CODEOWNERS"
223
223
  - ".github/blunderbuss.yml"
224
+ - ".github/release-please.yml"
225
+ - ".github/release-trigger.yml"
224
226
  - ".github/sync-repo-settings.yaml"
225
227
  - ".github/workflows/acceptance-tests-on-emulator.yaml"
226
228
  - ".github/workflows/acceptance-tests-on-production.yaml"
@@ -270,6 +272,7 @@ files:
270
272
  - acceptance/cases/migration/rename_column_test.rb
271
273
  - acceptance/cases/migration/schema_dumper_test.rb
272
274
  - acceptance/cases/models/calculation_query_test.rb
275
+ - acceptance/cases/models/default_value_test.rb
273
276
  - acceptance/cases/models/generated_column_test.rb
274
277
  - acceptance/cases/models/insert_all_test.rb
275
278
  - acceptance/cases/models/interleave_test.rb
@@ -296,7 +299,6 @@ files:
296
299
  - acceptance/models/account.rb
297
300
  - acceptance/models/address.rb
298
301
  - acceptance/models/album.rb
299
- - acceptance/models/album_partial_disabled.rb
300
302
  - acceptance/models/all_types.rb
301
303
  - acceptance/models/author.rb
302
304
  - acceptance/models/club.rb
@@ -314,6 +316,7 @@ files:
314
316
  - acceptance/models/transaction.rb
315
317
  - acceptance/schema/schema.rb
316
318
  - acceptance/test_helper.rb
319
+ - acceptance/test_helpers/with_separate_database.rb
317
320
  - activerecord-spanner-adapter.gemspec
318
321
  - assets/solidus-db.png
319
322
  - benchmarks/README.md
@@ -1,17 +0,0 @@
1
- # Copyright 2021 Google LLC
2
- #
3
- # Use of this source code is governed by an MIT-style
4
- # license that can be found in the LICENSE file or at
5
- # https://opensource.org/licenses/MIT.
6
-
7
- # frozen_string_literal: true
8
-
9
- require "models/album"
10
-
11
- class AlbumPartialDisabled < Album
12
- self.table_name = :albums
13
-
14
- if ActiveRecord::VERSION::MAJOR >= 7
15
- self.partial_inserts = false
16
- end
17
- end