ruby_event_store-active_record 2.12.0 → 2.13.0

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: 9987cdb6acdbe0954d31ef08815daeea9cf3bab6b0069bf5e03e2a60463bf13e
4
- data.tar.gz: bd8b1464de23ef8cc10e256ff90eee0c1851010cd23634f7484e1a1e9dc9544d
3
+ metadata.gz: 844a72fb4397a85af4951552a503d02f3f46fee88add52b3d4da559da0a578e1
4
+ data.tar.gz: c09cd8f7af18e4b3a276c09efa2a31f4e3ee5e62d29394f7022ab83ab7763ae5
5
5
  SHA512:
6
- metadata.gz: 61ceca1ee73adec8f023606dda0afb08f3b00f0bfe09be545ef909b093a71467a097ee2f2cf28224552e4b1c724d9eb23c8dd7b121c2925afc67861b5fccadb6
7
- data.tar.gz: 657b3186c572ed9f0e457640f1e5721b01e089aa330edc6886dac2fddd86c8f92b23a62d7a7f0dbf857c0daba9b987843c3997ea413a766fff9984d04ebfecb0
6
+ metadata.gz: 523f386852a08972217416c04335113e99f8c9bbe167100aed3035bc39e866f83d4cafb59d270ef314fbe974f2e1f23090479407eabe6bb44cf39382e0e953a8
7
+ data.tar.gz: a1974be5b9e5fe233e9dc27f23e98b4140bc51dced795a61f1cfc714d3af959c6fc6a5da40fd6c5cd508f408fa5a24b2840e7e06a435807c981cd2887ba9133c
@@ -17,8 +17,8 @@ module RubyEventStore
17
17
  batch_limit = [batch_size, total_limit - batch_offset].min
18
18
  results, offset_id = reader.call(offset_id, batch_limit)
19
19
 
20
- break if results.empty?
21
- yield results
20
+ yield results if results.any?
21
+ break if results.size < batch_size
22
22
  end
23
23
  end
24
24
 
@@ -96,7 +96,7 @@ module RubyEventStore
96
96
  stream = stream.where(newer_than_or_equal_condition(spec)) if spec.newer_than_or_equal
97
97
  stream.order(id: order(spec))
98
98
  else
99
- stream = @stream_klass.preload(:event).where(stream: spec.stream.name)
99
+ stream = @stream_klass.includes(:event).where(stream: spec.stream.name)
100
100
  stream = stream.where(event_id: spec.with_ids) if spec.with_ids?
101
101
  stream = stream.joins(:event).where(@event_klass.table_name => { event_type: spec.with_types }) if spec.with_types?
102
102
  stream = stream.joins(:event).order(as_at(spec)) if spec.time_sort_by_as_at?
@@ -6,13 +6,13 @@ module RubyEventStore
6
6
  InvalidDataTypeForAdapter = Class.new(StandardError)
7
7
 
8
8
  class DatabaseAdapter
9
- NOT_SET = Object.new.freeze
9
+ NONE = Object.new.freeze
10
10
 
11
11
  class PostgreSQL < self
12
12
  SUPPORTED_DATA_TYPES = %w[binary json jsonb].freeze
13
13
 
14
- def initialize(data_type = NOT_SET)
15
- super("postgresql", data_type)
14
+ def adapter_name
15
+ "postgresql"
16
16
  end
17
17
 
18
18
  def template_directory
@@ -23,8 +23,8 @@ module RubyEventStore
23
23
  class MySQL < self
24
24
  SUPPORTED_DATA_TYPES = %w[binary json].freeze
25
25
 
26
- def initialize(data_type = NOT_SET)
27
- super("mysql2", data_type)
26
+ def adapter_name
27
+ "mysql2"
28
28
  end
29
29
 
30
30
  def template_directory
@@ -35,21 +35,20 @@ module RubyEventStore
35
35
  class SQLite < self
36
36
  SUPPORTED_DATA_TYPES = %w[binary].freeze
37
37
 
38
- def initialize(data_type = NOT_SET)
39
- super("sqlite", data_type)
38
+ def adapter_name
39
+ "sqlite"
40
40
  end
41
41
  end
42
42
 
43
- def initialize(adapter_name, data_type)
43
+ def initialize(data_type = NONE)
44
44
  raise UnsupportedAdapter if instance_of?(DatabaseAdapter)
45
45
 
46
46
  validate_data_type!(data_type)
47
47
 
48
- @adapter_name = adapter_name
49
48
  @data_type = data_type
50
49
  end
51
50
 
52
- attr_reader :adapter_name, :data_type
51
+ attr_reader :data_type
53
52
 
54
53
  def supported_data_types
55
54
  self.class::SUPPORTED_DATA_TYPES
@@ -68,7 +67,7 @@ module RubyEventStore
68
67
  def template_directory
69
68
  end
70
69
 
71
- def self.from_string(adapter_name, data_type = NOT_SET)
70
+ def self.from_string(adapter_name, data_type = NONE)
72
71
  raise NoMethodError unless eql?(DatabaseAdapter)
73
72
 
74
73
  case adapter_name.to_s.downcase
@@ -86,7 +85,7 @@ module RubyEventStore
86
85
  private
87
86
 
88
87
  def validate_data_type!(data_type)
89
- if !data_type.eql?(NOT_SET) && !supported_data_types.include?(data_type)
88
+ if !data_type.eql?(NONE) && !supported_data_types.include?(data_type)
90
89
  raise InvalidDataTypeForAdapter,
91
90
  "#{class_name} doesn't support #{data_type.inspect}. Supported types are: #{supported_data_types.join(", ")}."
92
91
  end
@@ -3,10 +3,10 @@
3
3
  module RubyEventStore
4
4
  module ActiveRecord
5
5
  class ForeignKeyOnEventIdMigrationGenerator
6
- def call(database_adapter_name, migration_path)
7
- database_adapter = DatabaseAdapter.from_string(database_adapter_name)
8
- each_migration(database_adapter) do |migration_name|
9
- path = build_path(migration_path, migration_name)
6
+ def call(database_adapter, migration_path)
7
+ time = Time.now
8
+ each_migration(database_adapter) do |migration_name, i|
9
+ path = build_path(migration_path, migration_name, time + i)
10
10
  write_to_file(path, migration_code(database_adapter, migration_name))
11
11
  end
12
12
  end
@@ -22,7 +22,7 @@ module RubyEventStore
22
22
  ]
23
23
  else
24
24
  ['add_foreign_key_on_event_id_to_event_store_events_in_streams']
25
- end.each(&block)
25
+ end.each.with_index(&block)
26
26
  end
27
27
 
28
28
  def absolute_path(path)
@@ -45,16 +45,16 @@ module RubyEventStore
45
45
  ::ActiveRecord::Migration.current_version
46
46
  end
47
47
 
48
- def timestamp
49
- Time.now.strftime("%Y%m%d%H%M%S")
50
- end
51
-
52
48
  def write_to_file(path, migration_code)
53
49
  File.write(path, migration_code)
54
50
  end
55
51
 
56
- def build_path(migration_path, migration_name)
57
- File.join("#{migration_path}", "#{timestamp}_#{migration_name}.rb")
52
+ def build_path(migration_path, migration_name, time)
53
+ File.join("#{migration_path}", "#{migration_verion_number(time)}_#{migration_name}.rb")
54
+ end
55
+
56
+ def migration_verion_number(time)
57
+ time.strftime("%Y%m%d%H%M%S")
58
58
  end
59
59
  end
60
60
  end
@@ -27,13 +27,14 @@ if defined?(Rails::Generators::Base)
27
27
  def create_migration
28
28
  case @database_adapter
29
29
  when DatabaseAdapter::PostgreSQL
30
+ time = Time.now
30
31
  template "#{@database_adapter.template_directory}add_foreign_key_on_event_id_to_event_store_events_in_streams_template.erb",
31
- "db/migrate/#{timestamp}_add_foreign_key_on_event_id_to_event_store_events_in_streams.rb"
32
+ "db/migrate/#{migration_verion_number(time)}_add_foreign_key_on_event_id_to_event_store_events_in_streams.rb"
32
33
  template "#{@database_adapter.template_directory}validate_add_foreign_key_on_event_id_to_event_store_events_in_streams_template.erb",
33
- "db/migrate/#{timestamp}_validate_add_foreign_key_on_event_id_to_event_store_events_in_streams.rb"
34
+ "db/migrate/#{migration_verion_number(time + 1)}_validate_add_foreign_key_on_event_id_to_event_store_events_in_streams.rb"
34
35
  else
35
36
  template "#{@database_adapter.template_directory}add_foreign_key_on_event_id_to_event_store_events_in_streams_template.erb",
36
- "db/migrate/#{timestamp}_add_foreign_key_on_event_id_to_event_store_events_in_streams.rb"
37
+ "db/migrate/#{migration_verion_number(Time.now)}_add_foreign_key_on_event_id_to_event_store_events_in_streams.rb"
37
38
  end
38
39
  end
39
40
 
@@ -47,8 +48,8 @@ if defined?(Rails::Generators::Base)
47
48
  ::ActiveRecord::Migration.current_version
48
49
  end
49
50
 
50
- def timestamp
51
- Time.now.strftime("%Y%m%d%H%M%S")
51
+ def migration_verion_number(time)
52
+ time.strftime("%Y%m%d%H%M%S")
52
53
  end
53
54
  end
54
55
  end
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class AddForeginKeyOnEventIdToEventStoreEventsInStreams < ActiveRecord::Migration[<%= migration_version %>]
3
+ class AddForeignKeyOnEventIdToEventStoreEventsInStreams < ActiveRecord::Migration[<%= migration_version %>]
4
4
  def change
5
5
  add_foreign_key :event_store_events_in_streams, :event_store_events, column: :event_id, primary_key: :event_id, if_not_exists: true
6
6
  end
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class AddForeginKeyOnEventIdToEventStoreEventsInStreams < ActiveRecord::Migration[<%= migration_version %>]
3
+ class AddForeignKeyOnEventIdToEventStoreEventsInStreams < ActiveRecord::Migration[<%= migration_version %>]
4
4
  def change
5
5
  add_foreign_key :event_store_events_in_streams, :event_store_events, column: :event_id, primary_key: :event_id, if_not_exists: true
6
6
  end
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class AddForeginKeyOnEventIdToEventStoreEventsInStreams < ActiveRecord::Migration[<%= migration_version %>]
3
+ class AddForeignKeyOnEventIdToEventStoreEventsInStreams < ActiveRecord::Migration[<%= migration_version %>]
4
4
  def change
5
5
  add_foreign_key :event_store_events_in_streams, :event_store_events, column: :event_id, primary_key: :event_id, if_not_exists: true, validate: false
6
6
  end
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- class ValidateAddForeginKeyOnEventIdToEventStoreEventsInStreams < ActiveRecord::Migration[<%= migration_version %>]
3
+ class ValidateAddForeignKeyOnEventIdToEventStoreEventsInStreams < ActiveRecord::Migration[<%= migration_version %>]
4
4
  def change
5
5
  validate_foreign_key :event_store_events_in_streams, :event_store_events, column: :event_id, primary_key: :event_id
6
6
  end
@@ -2,33 +2,60 @@ require_relative "../generators/migration_generator"
2
2
 
3
3
  desc "Generate migration"
4
4
  task "db:migrations:copy" do
5
- data_type =
6
- ENV["DATA_TYPE"] || raise("Specify data type (binary, json, jsonb): rake db:migrations:copy DATA_TYPE=json")
7
- ::ActiveRecord::Base.establish_connection(ENV["DATABASE_URL"])
8
- database_adapter =
9
- RubyEventStore::ActiveRecord::DatabaseAdapter.from_string(::ActiveRecord::Base.connection.adapter_name, data_type)
5
+ task = MigrationTask.new("db:migrations:copy")
6
+ task.establish_connection
10
7
 
11
8
  path =
12
- RubyEventStore::ActiveRecord::MigrationGenerator.new.call(database_adapter, ENV["MIGRATION_PATH"] || "db/migrate")
9
+ RubyEventStore::ActiveRecord::MigrationGenerator.new.call(task.adapter, task.migration_path)
13
10
 
14
11
  puts "Migration file created #{path}"
15
12
  end
16
13
 
17
14
  desc "Generate migration for missing event_id index"
18
15
  task "db:migrations:fix_missing_event_id_index" do
19
- ::ActiveRecord::Base.establish_connection(ENV["DATABASE_URL"])
16
+ task = MigrationTask.new("db:migrations:fix_missing_event_id_index")
17
+ task.establish_connection
20
18
 
21
- path = RubyEventStore::ActiveRecord::EventIdIndexMigrationGenerator.new.call(ENV["MIGRATION_PATH"] || "db/migrate")
19
+ path = RubyEventStore::ActiveRecord::EventIdIndexMigrationGenerator.new.call(task.migration_path)
22
20
 
23
21
  puts "Migration file created #{path}"
24
22
  end
25
23
 
26
24
  desc "Generate migration for adding foreign key on event_store_events_in_streams.event_id"
27
25
  task "db:migrations:add_foreign_key_on_event_id" do
28
- ::ActiveRecord::Base.establish_connection(ENV["DATABASE_URL"])
26
+ task = MigrationTask.new("db:migrations:add_foreign_key_on_event_id")
27
+ task.establish_connection
29
28
 
30
29
  path =
31
- RubyEventStore::ActiveRecord::ForeignKeyOnEventIdMigrationGenerator.new.call(ENV["MIGRATION_PATH"] || "db/migrate")
30
+ RubyEventStore::ActiveRecord::ForeignKeyOnEventIdMigrationGenerator.new.call(task.adapter, task.migration_path)
32
31
 
33
32
  puts "Migration file created #{path}"
34
33
  end
34
+
35
+ class MigrationTask
36
+ def initialize(
37
+ task,
38
+ database_url: ENV["DATABASE_URL"],
39
+ data_type: ENV["DATA_TYPE"],
40
+ migration_path: ENV["MIGRATION_PATH"]
41
+ )
42
+ @task = task
43
+ @data_type = data_type
44
+ @migration_path = migration_path
45
+ @database_url = database_url
46
+ end
47
+
48
+ def establish_connection
49
+ ::ActiveRecord::Base.establish_connection(@database_url)
50
+ end
51
+
52
+ def adapter
53
+ data_type = @data_type || raise("Specify data type (binary, json, jsonb): rake #{@task} DATA_TYPE=json")
54
+
55
+ RubyEventStore::ActiveRecord::DatabaseAdapter.from_string(::ActiveRecord::Base.connection.adapter_name, data_type)
56
+ end
57
+
58
+ def migration_path
59
+ @migration_path || "db/migrate"
60
+ end
61
+ end
@@ -2,6 +2,6 @@
2
2
 
3
3
  module RubyEventStore
4
4
  module ActiveRecord
5
- VERSION = "2.12.0"
5
+ VERSION = "2.13.0"
6
6
  end
7
7
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: ruby_event_store-active_record
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.12.0
4
+ version: 2.13.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Arkency
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2023-09-04 00:00:00.000000000 Z
11
+ date: 2023-12-07 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: ruby_event_store
@@ -16,14 +16,14 @@ dependencies:
16
16
  requirements:
17
17
  - - '='
18
18
  - !ruby/object:Gem::Version
19
- version: 2.12.0
19
+ version: 2.13.0
20
20
  type: :runtime
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
24
  - - '='
25
25
  - !ruby/object:Gem::Version
26
- version: 2.12.0
26
+ version: 2.13.0
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: activerecord
29
29
  requirement: !ruby/object:Gem::Requirement
@@ -104,7 +104,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
104
104
  - !ruby/object:Gem::Version
105
105
  version: '0'
106
106
  requirements: []
107
- rubygems_version: 3.4.17
107
+ rubygems_version: 3.3.7
108
108
  signing_key:
109
109
  specification_version: 4
110
110
  summary: Persistent event repository implementation for RubyEventStore based on ActiveRecord