Sha256: 64ba83c9027240da5b2f6b4dca1baba6bcb944b2c3bd2ba91443c2f86db3771f

Contents?: true

Size: 1.21 KB

Versions: 9

Compression:

Stored size: 1.21 KB

Contents

# frozen_string_literal: true

module Ridgepole
  class ExternalSqlExecuter
    def initialize(script, logger)
      @script = script
      @logger = logger
    end

    def execute(sql)
      cmd = Shellwords.join([@script, sql, JSON.dump(ActiveRecord::Base.connection_db_config.configuration_hash)])
      @logger.info("Execute #{@script}")
      script_basename = File.basename(@script)

      Open3.popen3(cmd) do |stdin, stdout, stderr, wait_thr|
        stdin.close_write
        files = [stdout, stderr]

        begin
          until files.empty?
            ready = IO.select(files)

            next unless ready

            readable = ready[0]

            readable.each do |f|
              data = f.read_nonblock(1024)
              next if data.nil?

              data.chomp!

              if f == stderr
                @logger.warn("[WARNING] #{script_basename}: #{data}")
              else
                @logger.info("#{script_basename}: #{data}")
              end
            rescue EOFError
              files.delete f
            end
          end
        rescue EOFError
          # nothing to do
        end

        raise "`#{@script}` execution failed" unless wait_thr.value.success?
      end
    end
  end
end

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
ridgepole-3.0.0 lib/ridgepole/external_sql_executer.rb
ridgepole-2.1.1 lib/ridgepole/external_sql_executer.rb
ridgepole-2.1.0 lib/ridgepole/external_sql_executer.rb
ridgepole-2.0.3 lib/ridgepole/external_sql_executer.rb
ridgepole-2.0.2 lib/ridgepole/external_sql_executer.rb
ridgepole-2.0.1 lib/ridgepole/external_sql_executer.rb
ridgepole-2.0.0 lib/ridgepole/external_sql_executer.rb
ridgepole-2.0.0.beta2 lib/ridgepole/external_sql_executer.rb
ridgepole-2.0.0.beta lib/ridgepole/external_sql_executer.rb