tapsoob 0.5.24 → 0.5.26

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: 85d42c955109e84e5af46ab969b893d144d33ec4c022c94fb286ceed5aa50596
4
- data.tar.gz: 67b2ed47364c35f7d8a5756374b0706a5fb67975c58c3b24a69e0581cbb7e734
3
+ metadata.gz: 9f19b27231e8231c5a11cb879256df846b2963712eb9a335549f7c3199144b74
4
+ data.tar.gz: 792abe05f841fe4aa5a55de950d371f0ba23bb0d1ebfcb4e7c6ab76b695cd47d
5
5
  SHA512:
6
- metadata.gz: eeb40937fdb97fc9031537e555492686d5df9eb26edc8a2b3c3590ab4e3631bb7011008c16e8ce4c375f6fc857064d0ee4302cb61dc1bf01fa2b613eee1a8e9b
7
- data.tar.gz: 937d994cbf16669db3d15e7e1520ddd26d15097909a7bb4168f68ca97df652e8415abe7750b9e31afa61008027d3538989b573695cf235aab696806a6ce6a236
6
+ metadata.gz: d0ca8097f4ba556ef856e33b8c9e6e03c68636af1dc2c6d1896d3c399d5835cedb2de3d889bef199e903efc09eb2a3da74a9f9e2806dcc7a178bd3cda37c175f
7
+ data.tar.gz: 6a9c81e0acc7eca5296e718bd3e20bc224b23cb788b16d8b9651e48eda87cde3bcece13159d0ffcae4ff4d2e8b71144d818b2eef276dd7e967e1fd6020a5292c
data/.gitignore CHANGED
File without changes
data/.rspec CHANGED
File without changes
data/Gemfile CHANGED
@@ -35,7 +35,7 @@ end
35
35
  gemspec
36
36
 
37
37
  group :development do
38
- gem 'warbler', '~> 2.0.4', platform: :jruby, require: false
38
+ gem 'warbler', '~> 2.0.5', platform: :jruby, github: "jruby/warbler", require: false
39
39
  end
40
40
 
41
41
  group :test do
data/README.md CHANGED
File without changes
data/Rakefile CHANGED
File without changes
File without changes
File without changes
File without changes
File without changes
data/lib/tapsoob/cli.rb CHANGED
File without changes
File without changes
@@ -87,14 +87,34 @@ module Tapsoob
87
87
 
88
88
  def fetch_file(dump_path)
89
89
  #state[:chunksize] = fetch_chunksize
90
- ds = JSON.parse(File.read(File.join(dump_path, "data", "#{table_name}.json")))
91
- state[:size] = ds["data"].size
90
+ # Read NDJSON format - each line is a separate JSON chunk
91
+ file_path = File.join(dump_path, "data", "#{table_name}.json")
92
+
93
+ # Parse all chunks and combine them
94
+ all_data = []
95
+ table_name_val = nil
96
+ header_val = nil
97
+ types_val = nil
98
+
99
+ File.readlines(file_path).each do |line|
100
+ chunk = JSON.parse(line.strip)
101
+ table_name_val ||= chunk["table_name"]
102
+ header_val ||= chunk["header"]
103
+ types_val ||= chunk["types"]
104
+ all_data.concat(chunk["data"]) if chunk["data"]
105
+ end
106
+
107
+ # Apply skip-duplicates if needed
108
+ all_data = all_data.uniq if @options[:"skip-duplicates"]
109
+
110
+ state[:size] = all_data.size
92
111
  log.debug "DataStream#fetch_file"
112
+
93
113
  rows = {
94
- :table_name => ds["table_name"],
95
- :header => ds["header"],
96
- :data => ((@options[:"skip-duplicates"] ? ds["data"].uniq : ds["data"])[state[:offset], (state[:offset] + state[:chunksize])] || [ ]),
97
- :types => ds["types"]
114
+ :table_name => table_name_val,
115
+ :header => header_val,
116
+ :data => (all_data[state[:offset], state[:chunksize]] || []),
117
+ :types => types_val
98
118
  }
99
119
  update_chunksize_stats
100
120
  rows
File without changes
data/lib/tapsoob/log.rb CHANGED
File without changes
@@ -249,6 +249,9 @@ module Tapsoob
249
249
  stream.fetch_data_from_database(data) do |rows|
250
250
  next if rows == {}
251
251
 
252
+ # Update progress bar immediately when data is ready, before I/O
253
+ progress.inc(row_size) if progress
254
+
252
255
  if dump_path.nil?
253
256
  puts JSON.generate(rows)
254
257
  else
@@ -258,9 +261,9 @@ module Tapsoob
258
261
  log.debug "row size: #{row_size}"
259
262
  stream.error = false
260
263
  self.stream_state = stream.to_hash
261
-
264
+
262
265
  c.idle_secs = (d1 + d2)
263
-
266
+
264
267
  elapsed_time
265
268
  end
266
269
  rescue Tapsoob::CorruptedData => e
@@ -268,8 +271,6 @@ module Tapsoob
268
271
  stream.error = true
269
272
  next
270
273
  end
271
-
272
- progress.inc(row_size) if progress
273
274
 
274
275
  break if stream.complete?
275
276
  end
@@ -375,7 +376,9 @@ module Tapsoob
375
376
  idxs = {}
376
377
  table_idxs = Dir.glob(File.join(dump_path, "indexes", "*.json")).map { |path| File.basename(path, '.json') }
377
378
  table_idxs.each do |table_idx|
378
- idxs[table_idx] = JSON.parse(File.read(File.join(dump_path, "indexes", "#{table_idx}.json")))
379
+ # Read NDJSON format - each line is a separate index
380
+ index_file = File.join(dump_path, "indexes", "#{table_idx}.json")
381
+ idxs[table_idx] = File.readlines(index_file).map { |line| JSON.parse(line.strip) }
379
382
  end
380
383
 
381
384
  return unless idxs.size > 0
File without changes
File without changes
File without changes
data/lib/tapsoob/utils.rb CHANGED
@@ -143,26 +143,21 @@ Data : #{data}
143
143
  end
144
144
 
145
145
  def export_indexes(dump_path, table, index_data)
146
- data = [index_data]
147
- if File.exist?(File.join(dump_path, "indexes", "#{table}.json"))
148
- previous_data = JSON.parse(File.read(File.join(dump_path, "indexes", "#{table}.json")))
149
- data = data + previous_data
150
- end
146
+ # Use append-only writes to avoid O(n²) complexity
147
+ index_file = File.join(dump_path, "indexes", "#{table}.json")
151
148
 
152
- File.open(File.join(dump_path, "indexes", "#{table}.json"), 'w') do |file|
153
- file.write(JSON.generate(data))
149
+ File.open(index_file, 'a') do |file|
150
+ file.write(JSON.generate(index_data) + "\n")
154
151
  end
155
152
  end
156
153
 
157
154
  def export_rows(dump_path, table, row_data)
158
- data = row_data
159
- if File.exist?(File.join(dump_path, "data", "#{table}.json"))
160
- previous_data = JSON.parse(File.read(File.join(dump_path, "data", "#{table}.json")))
161
- data[:data] = previous_data["data"] + row_data[:data] unless row_data[:data].nil?
162
- end
155
+ # Use append-only writes to avoid O(n²) complexity
156
+ # Store metadata separately and append data chunks as NDJSON
157
+ data_file = File.join(dump_path, "data", "#{table}.json")
163
158
 
164
- File.open(File.join(dump_path, "data", "#{table}.json"), 'w') do |file|
165
- file.write(JSON.generate(data))
159
+ File.open(data_file, 'a') do |file|
160
+ file.write(JSON.generate(row_data) + "\n")
166
161
  end
167
162
  end
168
163
 
@@ -1,4 +1,4 @@
1
1
  # -*- encoding : utf-8 -*-
2
2
  module Tapsoob
3
- VERSION = "0.5.24".freeze
3
+ VERSION = "0.5.26".freeze
4
4
  end
data/lib/tapsoob.rb CHANGED
File without changes
File without changes
File without changes
File without changes
data/spec/spec_helper.rb CHANGED
File without changes
data/tapsoob.gemspec CHANGED
@@ -20,18 +20,18 @@ Gem::Specification.new do |s|
20
20
  s.require_paths = ["lib"]
21
21
 
22
22
  # Dependencies
23
- s.add_dependency "sequel", "~> 5.80.0"
24
- s.add_dependency "thor", "~> 1.3.1"
23
+ s.add_dependency "sequel", "~> 5.96.0"
24
+ s.add_dependency "thor", "~> 1.4.0"
25
25
 
26
26
  if (RUBY_PLATFORM =~ /java/).nil?
27
- s.add_development_dependency "mysql2", "~> 0.4.10"
28
- s.add_development_dependency "pg", "~> 0.21.0"
29
- s.add_development_dependency "sqlite3", "~> 1.3.11"
27
+ s.add_development_dependency "mysql2", "~> 0.5.7"
28
+ s.add_development_dependency "pg", "~> 1.6.2"
29
+ s.add_development_dependency "sqlite3", "~> 2.7.4"
30
30
  else
31
31
  s.platform = 'java'
32
32
 
33
- s.add_dependency "jdbc-mysql", "~> 5.1.44"
34
- s.add_dependency "jdbc-postgres", "~> 42.2.25"
35
- s.add_dependency "jdbc-sqlite3", "~> 3.28.0"
33
+ s.add_dependency "jdbc-mysql", "~> 9.1.0.1"
34
+ s.add_dependency "jdbc-postgres", "~> 42.6.0"
35
+ s.add_dependency "jdbc-sqlite3", "~> 3.46.1.1"
36
36
  end
37
37
  end
metadata CHANGED
@@ -1,15 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: tapsoob
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.5.24
4
+ version: 0.5.26
5
5
  platform: ruby
6
6
  authors:
7
7
  - Félix Bellanger
8
8
  - Michael Chrisco
9
- autorequire:
10
9
  bindir: bin
11
10
  cert_chain: []
12
- date: 2024-05-04 00:00:00.000000000 Z
11
+ date: 1980-01-02 00:00:00.000000000 Z
13
12
  dependencies:
14
13
  - !ruby/object:Gem::Dependency
15
14
  name: sequel
@@ -17,70 +16,70 @@ dependencies:
17
16
  requirements:
18
17
  - - "~>"
19
18
  - !ruby/object:Gem::Version
20
- version: 5.80.0
19
+ version: 5.96.0
21
20
  type: :runtime
22
21
  prerelease: false
23
22
  version_requirements: !ruby/object:Gem::Requirement
24
23
  requirements:
25
24
  - - "~>"
26
25
  - !ruby/object:Gem::Version
27
- version: 5.80.0
26
+ version: 5.96.0
28
27
  - !ruby/object:Gem::Dependency
29
28
  name: thor
30
29
  requirement: !ruby/object:Gem::Requirement
31
30
  requirements:
32
31
  - - "~>"
33
32
  - !ruby/object:Gem::Version
34
- version: 1.3.1
33
+ version: 1.4.0
35
34
  type: :runtime
36
35
  prerelease: false
37
36
  version_requirements: !ruby/object:Gem::Requirement
38
37
  requirements:
39
38
  - - "~>"
40
39
  - !ruby/object:Gem::Version
41
- version: 1.3.1
40
+ version: 1.4.0
42
41
  - !ruby/object:Gem::Dependency
43
42
  name: mysql2
44
43
  requirement: !ruby/object:Gem::Requirement
45
44
  requirements:
46
45
  - - "~>"
47
46
  - !ruby/object:Gem::Version
48
- version: 0.4.10
47
+ version: 0.5.7
49
48
  type: :development
50
49
  prerelease: false
51
50
  version_requirements: !ruby/object:Gem::Requirement
52
51
  requirements:
53
52
  - - "~>"
54
53
  - !ruby/object:Gem::Version
55
- version: 0.4.10
54
+ version: 0.5.7
56
55
  - !ruby/object:Gem::Dependency
57
56
  name: pg
58
57
  requirement: !ruby/object:Gem::Requirement
59
58
  requirements:
60
59
  - - "~>"
61
60
  - !ruby/object:Gem::Version
62
- version: 0.21.0
61
+ version: 1.6.2
63
62
  type: :development
64
63
  prerelease: false
65
64
  version_requirements: !ruby/object:Gem::Requirement
66
65
  requirements:
67
66
  - - "~>"
68
67
  - !ruby/object:Gem::Version
69
- version: 0.21.0
68
+ version: 1.6.2
70
69
  - !ruby/object:Gem::Dependency
71
70
  name: sqlite3
72
71
  requirement: !ruby/object:Gem::Requirement
73
72
  requirements:
74
73
  - - "~>"
75
74
  - !ruby/object:Gem::Version
76
- version: 1.3.11
75
+ version: 2.7.4
77
76
  type: :development
78
77
  prerelease: false
79
78
  version_requirements: !ruby/object:Gem::Requirement
80
79
  requirements:
81
80
  - - "~>"
82
81
  - !ruby/object:Gem::Version
83
- version: 1.3.11
82
+ version: 2.7.4
84
83
  description: Simple tool to import/export databases inspired by taps but OOB, meaning
85
84
  databases are imported/exported from the filesystem.
86
85
  email: felix.bellanger@faveod.com
@@ -120,7 +119,6 @@ homepage: https://github.com/Keeguon/tapsoob
120
119
  licenses:
121
120
  - MIT
122
121
  metadata: {}
123
- post_install_message:
124
122
  rdoc_options: []
125
123
  require_paths:
126
124
  - lib
@@ -135,8 +133,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
135
133
  - !ruby/object:Gem::Version
136
134
  version: '0'
137
135
  requirements: []
138
- rubygems_version: 3.3.26
139
- signing_key:
136
+ rubygems_version: 3.6.9
140
137
  specification_version: 4
141
138
  summary: Simple tool to import/export databases.
142
139
  test_files: