litestream 0.6.0-x86_64-linux → 0.7.1-x86_64-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: 7eb881ff50053fb9bd6f426a2266a8b4234e1f782cbe716b2f3bcc7a34c87ed4
4
- data.tar.gz: ed2bf4087f36d6148955f434cbe22649fa477540502ae733fb33daad6606b8c0
3
+ metadata.gz: '08afe3b30bd0e745eafa2959aa96f7961afca170597149f1ca70bc585c8810e8'
4
+ data.tar.gz: c11be09f09ce2144b16a98d0be2dc1f8e8f11dd407d9255f16126df4d7b1c378
5
5
  SHA512:
6
- metadata.gz: 90af11f5fc279c7b6e61c55f40a17f9c1e72a7e8edd4fed6d6929e7d46a6695bd4770880c288420d11dc1ece67f4c1a0abaebe06ff22b8fb4ee5feac173e6f0a
7
- data.tar.gz: 27580dfa663cece6a956e5b18f069d615bbbd2f337e0637f6fc472f701f84bd0d8b04b817d02b403fe2f54e7c5ffa2f490db0ac105f9dacec6679a5aad831cc7
6
+ metadata.gz: 51b272dc72f4bc02078e4efdb34cb6dd73d9e98b308e0ccccbbd228ab037a07710654f0930b60e3facac5d82e17e01a905bba6db7b403d6607e85e3241286bb4
7
+ data.tar.gz: d00b1075636484af33d233fb102ba51318fd246d730bcb6cb3994e693e94974be1635e28c3bdbfcd2e009c422845b4770e3c6eefddf2a94821708984730584c6
@@ -17,8 +17,8 @@ module Litestream
17
17
  # raised when a litestream command requires a database argument but it isn't provided
18
18
  DatabaseRequiredException = Class.new(StandardError)
19
19
 
20
- # raised when litestream fails to restore a database backup
21
- BackupFailedException = Class.new(StandardError)
20
+ # raised when a litestream command fails
21
+ CommandFailedException = Class.new(StandardError)
22
22
 
23
23
  class << self
24
24
  def platform
@@ -77,16 +77,14 @@ module Litestream
77
77
  end
78
78
 
79
79
  def replicate(async: false, **argv)
80
- execute("replicate", argv, async: async, hashify: false)
80
+ execute("replicate", argv, async: async, tabled_output: false)
81
81
  end
82
82
 
83
83
  def restore(database, async: false, **argv)
84
84
  raise DatabaseRequiredException, "database argument is required for restore command, e.g. litestream:restore -- --database=path/to/database.sqlite" if database.nil?
85
85
  argv.stringify_keys!
86
86
 
87
- execute("restore", argv, database, async: async, hashify: false)
88
-
89
- argv["-o"] || database
87
+ execute("restore", argv, database, async: async, tabled_output: false)
90
88
  end
91
89
 
92
90
  def verify(database, async: false, **argv)
@@ -101,10 +99,7 @@ module Litestream
101
99
  args = {
102
100
  "-o" => backup
103
101
  }.merge(argv)
104
-
105
- backup = restore(database, async: false, **args)
106
-
107
- raise BackupFailedException, "Failed to create backup for validation" unless File.exist?(backup)
102
+ restore(database, async: false, **args)
108
103
 
109
104
  restored_tables_count = `sqlite3 #{backup} "select count(*) from sqlite_schema where type='table';"`.chomp.to_i
110
105
  restored_size = File.size(backup)
@@ -120,26 +115,32 @@ module Litestream
120
115
  end
121
116
 
122
117
  def databases(async: false, **argv)
123
- execute("databases", argv, async: async, hashify: true)
118
+ execute("databases", argv, async: async, tabled_output: true)
124
119
  end
125
120
 
126
121
  def generations(database, async: false, **argv)
127
122
  raise DatabaseRequiredException, "database argument is required for generations command, e.g. litestream:generations -- --database=path/to/database.sqlite" if database.nil?
128
123
 
129
- execute("generations", argv, database, async: async, hashify: true)
124
+ execute("generations", argv, database, async: async, tabled_output: true)
130
125
  end
131
126
 
132
127
  def snapshots(database, async: false, **argv)
133
128
  raise DatabaseRequiredException, "database argument is required for snapshots command, e.g. litestream:snapshots -- --database=path/to/database.sqlite" if database.nil?
134
129
 
135
- execute("snapshots", argv, database, async: async, hashify: true)
130
+ execute("snapshots", argv, database, async: async, tabled_output: true)
136
131
  end
137
132
 
138
133
  private
139
134
 
140
- def execute(command, argv = {}, database = nil, async: false, hashify: false)
135
+ def execute(command, argv = {}, database = nil, async: false, tabled_output: false)
141
136
  cmd = prepare(command, argv, database)
142
- run(cmd, async: async, hashify: hashify)
137
+ results = run(cmd, async: async, tabled_output: tabled_output)
138
+
139
+ if Array === results && results.one? && results[0]["level"] == "ERROR"
140
+ raise CommandFailedException, "Failed to execute `#{cmd.join(" ")}`; Reason: #{results[0]["error"]}"
141
+ else
142
+ results
143
+ end
143
144
  end
144
145
 
145
146
  def prepare(command, argv = {}, database = nil)
@@ -158,14 +159,14 @@ module Litestream
158
159
  cmd
159
160
  end
160
161
 
161
- def run(cmd, async: false, hashify: false)
162
+ def run(cmd, async: false, tabled_output: false)
162
163
  if async
163
164
  # To release the resources of the Ruby process, just fork and exit.
164
165
  # The forked process executes litestream and replaces itself.
165
166
  exec(*cmd) if fork.nil?
166
167
  else
167
- out = `#{cmd.join(" ")}`
168
- text_table_to_hashes(out) if hashify
168
+ stdout = `#{cmd.join(" ")}`.chomp
169
+ tabled_output ? text_table_to_hashes(stdout) : stdout.split("\n").map { Logfmt.parse(_1) }
169
170
  end
170
171
  end
171
172
 
@@ -1,3 +1,3 @@
1
1
  module Litestream
2
- VERSION = "0.6.0"
2
+ VERSION = "0.7.1"
3
3
  end
metadata CHANGED
@@ -1,15 +1,29 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: litestream
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.6.0
4
+ version: 0.7.1
5
5
  platform: x86_64-linux
6
6
  authors:
7
7
  - Stephen Margheim
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2024-04-30 00:00:00.000000000 Z
11
+ date: 2024-05-02 00:00:00.000000000 Z
12
12
  dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: logfmt
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: 0.0.10
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: 0.0.10
13
27
  - !ruby/object:Gem::Dependency
14
28
  name: rubyzip
15
29
  requirement: !ruby/object:Gem::Requirement