prick 0.14.0 → 0.18.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: c155692c268326430a0e9225d4a7c156fedd52533114b62fae7e7ce61da01177
4
- data.tar.gz: 4e245212208c3ecc518f313cd9f1af709db5ce41b7281c7247a1078293c486de
3
+ metadata.gz: 22580f7a2f37e4ad59c6354e3b6ac1d7bb6f5eb7fe8f44eddb941ba715f8fa39
4
+ data.tar.gz: b0b5bf43389a0e35c6a739b92b4e50b043cb75ab1e215aa109a9a68e4f17e1e3
5
5
  SHA512:
6
- metadata.gz: 38ff771885f6a73a20f36985403cb61a63fc2f025c20f92bb1dea4cb2ba047f908e48c4a564a50b707594d32199a87f796e0640135f6f0da5a521fe572c70cdb
7
- data.tar.gz: 79641d89e168fe1be4d7493aed420fd40cd71cfb29ac98c359c34f82457bd1b7c265883e83cf661c29ff1ea6437bf1a087a652987409221cc4c439768b480922
6
+ metadata.gz: 7768a47145ae07f6ae99e808ad513107ccd98327fc009311cd0bfde1f1dbd3a52a3d9f5061c6bb3918b12da6850b0cf4e5242efade679d950a603047c8dd9cfc
7
+ data.tar.gz: e2709800fe62d599bba1ea64960b4a09e8a97a87da3d60731e8293f4957c9ac35147122dea16220481b9c49b17d3cf31377663f1328b99608c0fc3cc84ca4ad9
data/TODO CHANGED
@@ -1,4 +1,7 @@
1
1
 
2
+ o Add a top-level 'global' directory for stuff that doesn't belong to a schema or that
3
+ require superuser privileges. prick-build should then execute the content of that
4
+ directory first before switching to the database user
2
5
  o Check for commits to tags
3
6
  o Accumulate version history in prick.versions instead of just having the newest
4
7
  o Using rc's in migration syntax: fork-version-fork-version.rc1 ?
data/exe/prick CHANGED
@@ -198,7 +198,7 @@ begin
198
198
  # Change to parent directory containing the Prick version file if not found
199
199
  # in the current directory
200
200
  program.current_directory = Dir.getwd
201
- while !Dir.getwd != "/" && !File.exist?(PRICK_VERSION_FILE)
201
+ while Dir.getwd != "/" && !File.exist?(PRICK_VERSION_FILE)
202
202
  Dir.chdir("..")
203
203
  end
204
204
 
data/lib/prick/builder.rb CHANGED
@@ -19,7 +19,7 @@ module Prick
19
19
  # When a resource match a directory, the directory can contain a special
20
20
  # default resource ('build' or 'migrate') that takes over the rest of the
21
21
  # build process for that directory. Typically, you'll use the 'build.yml' or
22
- # 'migrate.yml' to control the build order of the other resources If a
22
+ # 'migrate.yml' to control the build order of the other resources. If a
23
23
  # directory doesn't contain a build resource, the resources in the directory
24
24
  # are built in alphabetic order
25
25
  #
@@ -38,6 +38,7 @@ module Prick
38
38
  @default = default
39
39
  @execute = true
40
40
  @lines = []
41
+ @cwd = Dir.getwd # used in error messages
41
42
  end
42
43
 
43
44
  def build(subject = default, execute: true)
@@ -59,6 +60,7 @@ module Prick
59
60
 
60
61
  protected
61
62
  def do_dir(path, &block)
63
+ # puts "do_dir(#{path.inspect})"
62
64
  dir, file = File.split(path)
63
65
  Dir.chdir(dir) { yield(file) }
64
66
  end
@@ -67,7 +69,13 @@ module Prick
67
69
  # puts "do_sql(#{path})"
68
70
  do_dir(path) { |file|
69
71
  if @execute
70
- Rdbms.exec_file(database.name, file, user: database.user, schema: schema)
72
+ begin
73
+ Rdbms.exec_file(database.name, file, user: database.user, schema: schema)
74
+ rescue Command::Error => ex
75
+ $stderr.puts ex.stderr
76
+ $stderr.puts "in #{reldir}/#{file}"
77
+ exit 1
78
+ end
71
79
  else
72
80
  @lines += IO.readlines(file).map(&:chomp)
73
81
  end
@@ -75,12 +83,19 @@ module Prick
75
83
  true
76
84
  end
77
85
 
78
- def do_exe(path, schema: nil)
79
- # puts "do_exe(#{path})"
86
+ def do_exe(path, args = [], schema: nil)
87
+ # puts "do_exe(#{path.inspect}, #{args.inspect})"
80
88
  do_dir(path) { |file|
81
- lines = Command.command "./#{file} #{database.name} #{database.user}" # FIXME Security
89
+ cmd = (["./#{file}"] + args).join(" ")
90
+ lines = Command.command cmd, stdin: [database.name, database.user]
82
91
  if @execute
83
- Rdbms.exec_sql(database.name, lines.join("\n"), user: database.user, schema: schema)
92
+ begin
93
+ Rdbms.exec_sql(database.name, lines.join("\n"), user: database.user, schema: schema)
94
+ rescue Command::Error => ex
95
+ $stderr.puts ex.stderr
96
+ $stderr.puts "from #{reldir}/#{file}"
97
+ exit 1
98
+ end
84
99
  else
85
100
  @lines += lines
86
101
  end
@@ -97,8 +112,9 @@ module Prick
97
112
 
98
113
  # A subject can be both an abstract subject or a concrete file (*.yml, *.sql)
99
114
  def build_subject(subject)
100
- if File.file?(subject) && File.executable?(subject)
101
- do_exe(subject)
115
+ cmd, *args = subject.split(/\s+/)
116
+ if File.file?(cmd) && File.executable?(cmd)
117
+ do_exe(cmd, args)
102
118
  elsif File.file?(subject) && subject.end_with?(".yml")
103
119
  do_yml(subject)
104
120
  elsif File.file?(subject) && subject.end_with?(".sql")
@@ -130,6 +146,14 @@ module Prick
130
146
  end
131
147
  }
132
148
  end
149
+
150
+ private
151
+ # Return the relative path to the current directory from the directory of
152
+ # the time of the instantiation of the Builder object. Used in error
153
+ # messages
154
+ def reldir
155
+ Dir.getwd.sub(/^#{@cwd}\//, "")
156
+ end
133
157
  end
134
158
 
135
159
  class MigrationBuilder < Builder
@@ -172,9 +196,9 @@ module Prick
172
196
  super(path, schema: schema)
173
197
  end
174
198
 
175
- def do_exe(path)
199
+ def do_exe(path, args = [])
176
200
  schema = Dir.getwd.sub(/^.*schema\/([^\/]+)(?:\/.*)?$/, '\1')
177
- super(path, schema: schema)
201
+ super(path, args, schema: schema)
178
202
  end
179
203
  end
180
204
  end
data/lib/prick/command.rb CHANGED
@@ -15,14 +15,17 @@ module Command
15
15
  end
16
16
 
17
17
  # Execute the shell command 'cmd' and return standard output as an array of
18
- # strings while stderr is passed through unless stderr: is false. If stderr:
18
+ # strings. while stderr is passed through unless stderr: is false. If stderr:
19
19
  # is true, it returns a tuple of [stdout, stderr] instead. The shell command
20
20
  # is executed with the `errexit` and `pipefail` bash options
21
+ #
22
+ # The :stdin option is a line or an array of lines that'll be fed to the
23
+ # standard input of the command. Default is nil
21
24
  #
22
25
  # It raises a Command::Error exception if the command fails unless :fail is
23
26
  # true. The exit status of the last command is stored in ::status
24
27
  #
25
- def command(cmd, stderr: false, fail: true)
28
+ def command(cmd, stdin: nil, stderr: false, fail: true)
26
29
  cmd = "set -o errexit\nset -o pipefail\n#{cmd}"
27
30
 
28
31
  pw = IO::pipe # pipe[0] for read, pipe[1] for write
@@ -52,12 +55,18 @@ module Command
52
55
  pr[1].close
53
56
  pe[1].close
54
57
 
58
+ if stdin
59
+ pw[1].puts(stdin)
60
+ pw[1].flush
61
+ pw[1].close
62
+ end
63
+
55
64
  @status = Process.waitpid2(pid)[1].exitstatus
56
65
 
57
66
  out = pr[0].readlines.collect { |line| line.chop }
58
- err = pe[0].readlines.collect { |line| line.chop }
67
+ err = pe[0].readlines.collect { |line| line.chop }.grep_v(/^NOTICE:/)
59
68
 
60
- pw[1].close
69
+ pw[1].close if !stdin
61
70
  pr[0].close
62
71
  pe[0].close
63
72
 
data/lib/prick/version.rb CHANGED
@@ -4,7 +4,7 @@
4
4
 
5
5
  # Required by gem
6
6
  module Prick
7
- VERSION = "0.14.0"
7
+ VERSION = "0.18.0"
8
8
  end
9
9
 
10
10
  # Project related code starts here
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: prick
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.14.0
4
+ version: 0.18.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Claus Rasmussen
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2021-03-18 00:00:00.000000000 Z
11
+ date: 2021-07-21 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: shellopts
@@ -155,7 +155,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
155
155
  - !ruby/object:Gem::Version
156
156
  version: '0'
157
157
  requirements: []
158
- rubygems_version: 3.1.2
158
+ rubygems_version: 3.1.4
159
159
  signing_key:
160
160
  specification_version: 4
161
161
  summary: A release control and management system for postgresql