litestream 0.7.2-arm64-darwin → 0.9.0-arm64-darwin
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/litestream/commands.rb +19 -6
- data/lib/litestream/version.rb +1 -1
- data/lib/tasks/litestream_tasks.rake +48 -13
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7ae7ada05f79c43a91fe4dab24d78e0f540594f149b81c158ae8c9de9a5e0102
|
4
|
+
data.tar.gz: 3663ac9db5970fdcd0c6ca4061107bb4617470c8a9eae92dd081fd2976a01305
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: e2288c916563650e6ce7fc341b60782811bffa01f25fb7c9b1c77b7b4d777cacacd76c0db62ffd5f2e1a09535449f22dfd785d9e36a0dc1198eed2a4008dfd5b
|
7
|
+
data.tar.gz: ae1e4efb3bf1e6d0a7bc6d5a0bf181c1f542aabaec5ce585988701e4de1b71c78e55422a59405b24e35720a920b90e8005b033733d6646b47cb643d5e05bf5ca
|
data/lib/litestream/commands.rb
CHANGED
@@ -102,16 +102,29 @@ module Litestream
|
|
102
102
|
}.merge(argv)
|
103
103
|
restore(database, async: false, **args)
|
104
104
|
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
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
|
-
"
|
114
|
-
|
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
|
|
data/lib/litestream/version.rb
CHANGED
@@ -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
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
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.
|
4
|
+
version: 0.9.0
|
5
5
|
platform: arm64-darwin
|
6
6
|
authors:
|
7
7
|
- Stephen Margheim
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-05-
|
11
|
+
date: 2024-05-04 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: logfmt
|