litestream 0.7.2-arm64-linux → 0.9.0-arm64-linux

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: 0ed179d2e6a5cbb1673c16ce9f56e0e412dcdc4c165caaaa058f48f542e0f21b
4
- data.tar.gz: 1c3e243958545df6d317ca993f007129835b5437fbbcb9b87b7b8deb8518a591
3
+ metadata.gz: dc472b950abdf855acfe66f39368cfa97827355c2d472ecbb77b4a8c14af2fee
4
+ data.tar.gz: 8c825cd5331255b16c0bf4e53608f7df56059589b29fc560014fb03f81556787
5
5
  SHA512:
6
- metadata.gz: 8b0b7cacf18a7a089bfe785992bbd793174d194166b02f75f896630f8d4820ae8ef77abd541732c4bd876d27339885465660b4d3bb858cec2f0d9d9da8c3992d
7
- data.tar.gz: 70ce1401f2a65964479cbbc9b46c3259980e1b69507f0a1871d5b9c69af3ffa078808c8dc9bb02756484a895b968caf7cc42bd368636454d33d6cca08a7074c9
6
+ metadata.gz: 89ba1fe375c44de1664e5883b94215d34c0902ce2eab6b3b14fae84309b4eca7b2ba21762b5cae5f88f6f11220dfaf9a27f611fb0f72a98673f6d79b1837d7a6
7
+ data.tar.gz: 5194734875bf2270823f03284b6ec704a0e8149d2606e6d1cfe6b1e9df254e64d86e5f491bac750f840b7fe4cb88dd06347123577aada2af719a9b809710c892
@@ -102,16 +102,29 @@ module Litestream
102
102
  }.merge(argv)
103
103
  restore(database, async: false, **args)
104
104
 
105
- restored_tables_count = `sqlite3 #{backup} "select count(*) from sqlite_schema where type='table';"`.chomp.to_i
106
- restored_size = File.size(backup)
107
- original_tables_count = `sqlite3 #{database} "select count(*) from sqlite_schema where type='table';"`.chomp.to_i
108
- original_size = File.size(database)
105
+ restored_schema = `sqlite3 #{backup} "select name, type from sqlite_schema;"`.chomp.split("\n")
106
+ restored_data = restored_schema.map { _1.split("|") }.group_by(&:last)
107
+ restored_rows_count = restored_data["table"]&.sum { |tbl, _| `sqlite3 #{backup} "select count(*) from #{tbl};"`.chomp.to_i }
108
+
109
+ original_schema = `sqlite3 #{database} "select name, type from sqlite_schema;"`.chomp.split("\n")
110
+ original_data = original_schema.map { _1.split("|") }.group_by(&:last)
111
+ original_rows_count = original_data["table"]&.sum { |tbl, _| `sqlite3 #{database} "select count(*) from #{tbl};"`.chomp.to_i }
109
112
 
110
113
  Dir.glob(backup + "*").each { |file| File.delete(file) }
111
114
 
112
115
  {
113
- "size" => {"original" => original_size, "restored" => restored_size},
114
- "tables" => {"original" => original_tables_count, "restored" => restored_tables_count}
116
+ "original" => {
117
+ "path" => database,
118
+ "tables" => original_data["table"]&.size,
119
+ "indexes" => original_data["index"]&.size,
120
+ "rows" => original_rows_count
121
+ },
122
+ "restored" => {
123
+ "path" => backup,
124
+ "tables" => restored_data["table"]&.size,
125
+ "indexes" => restored_data["index"]&.size,
126
+ "rows" => restored_rows_count
127
+ }
115
128
  }
116
129
  end
117
130
 
@@ -1,3 +1,3 @@
1
1
  module Litestream
2
- VERSION = "0.7.2"
2
+ VERSION = "0.9.0"
3
3
  end
@@ -93,18 +93,53 @@ namespace :litestream do
93
93
  options.symbolize_keys!
94
94
 
95
95
  result = Litestream::Commands.verify(database, async: true, **options)
96
-
97
- puts <<~TXT if result
98
-
99
- size
100
- original #{result["size"]["original"]}
101
- restored #{result["size"]["restored"]}
102
- delta #{result["size"]["original"] - result["size"]["restored"]}
103
-
104
- tables
105
- original #{result["tables"]["original"]}
106
- restored #{result["tables"]["restored"]}
107
- delta #{result["tables"]["original"] - result["tables"]["restored"]}
108
- TXT
96
+ original_tables = result["original"]["tables"]
97
+ restored_tables = result["restored"]["tables"]
98
+ original_indexes = result["original"]["indexes"]
99
+ restored_indexes = result["restored"]["indexes"]
100
+ original_rows = result["original"]["rows"]
101
+ restored_rows = result["restored"]["rows"]
102
+
103
+ same_number_of_tables = original_tables == restored_tables
104
+ same_number_of_indexes = original_indexes == restored_indexes
105
+ same_number_of_rows = original_rows == restored_rows
106
+
107
+ if same_number_of_tables && same_number_of_indexes && same_number_of_rows
108
+ puts "Backup for `#{database}` verified as consistent!\n" + [
109
+ " tables #{original_tables}",
110
+ " indexes #{original_indexes}",
111
+ " rows #{original_rows}"
112
+ ].compact.join("\n")
113
+ else
114
+ abort "Verification failed for #{database}:\n" + [
115
+ (unless same_number_of_tables
116
+ if original_tables > restored_tables
117
+ diff = original_tables - restored_tables
118
+ " Backup is missing #{diff} table#{"s" if diff > 1}"
119
+ else
120
+ diff = restored_tables - original_tables
121
+ " Backup has extra #{diff} table#{"s" if diff > 1}"
122
+ end
123
+ end),
124
+ (unless same_number_of_indexes
125
+ if original_indexes > restored_indexes
126
+ diff = original_indexes - restored_indexes
127
+ " Backup is missing #{diff} index#{"es" if diff > 1}"
128
+ else
129
+ diff = restored_indexes - original_indexes
130
+ " Backup has extra #{diff} index#{"es" if diff > 1}"
131
+ end
132
+ end),
133
+ (unless same_number_of_rows
134
+ if original_rows > restored_rows
135
+ diff = original_rows - restored_rows
136
+ " Backup is missing #{diff} row#{"s" if diff > 1}"
137
+ else
138
+ diff = restored_rows - original_rows
139
+ " Backup has extra #{diff} row#{"s" if diff > 1}"
140
+ end
141
+ end)
142
+ ].compact.join("\n")
143
+ end
109
144
  end
110
145
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: litestream
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.7.2
4
+ version: 0.9.0
5
5
  platform: arm64-linux
6
6
  authors:
7
7
  - Stephen Margheim
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2024-05-02 00:00:00.000000000 Z
11
+ date: 2024-05-04 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: logfmt