Skip to content

Commit

Permalink
Add back pg_dump support to PostgresAdmin
Browse files Browse the repository at this point in the history
Removed as part of:

  ManageIQ/manageiq-gems-pending#302

In commit 69e001e8

  ManageIQ/manageiq-gems-pending@69e001e8

Also adds some tests for future confirmation that other additions and
refactoring will not brake what is already here.


(transferred from ManageIQ/manageiq-gems-pending@9dcbe55)
  • Loading branch information
NickLaMuro committed Mar 9, 2021
1 parent b088ad4 commit d1a2916
Show file tree
Hide file tree
Showing 2 changed files with 85 additions and 0 deletions.
7 changes: 7 additions & 0 deletions lib/manageiq/appliance_console/postgres_admin.rb
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,13 @@ def self.restore_pg_basebackup(file)
file
end

def self.backup_pg_dump(opts)
opts = opts.dup
dbname = opts.delete(:dbname)
runcmd("pg_dump", opts, :format => "c", :file => opts[:local_file], nil => dbname)
opts[:local_file]
end

def self.backup_pg_compress(opts)
opts = opts.dup

Expand Down
78 changes: 78 additions & 0 deletions spec/postgres_admin_spec.rb
Original file line number Diff line number Diff line change
@@ -1,6 +1,84 @@
require "util/postgres_admin"

describe PostgresAdmin do
describe ".backup_pg_dump" do
subject { described_class }

let(:local_file) { nil }
let(:expected_opts) { {} }
let(:expected_args) { default_args }
let(:default_args) do
{
:no_password => nil,
:format => "c",
:file => local_file,
nil => nil
}
end

before do
expect(subject).to receive(:runcmd_with_logging)
.with("pg_dump", expected_opts, expected_args)
end

context "with empty args" do
it "runs the command and returns the :local_file opt" do
expect(subject.backup_pg_dump({})).to eq(local_file)
end
end

context "with :local_file in opts" do
let(:local_file) { "/some/path/to/pg.dump" }
let(:expected_opts) { { :local_file => local_file } }

it "runs the command and returns the :local_file opt" do
opts = expected_opts
expect(subject.backup_pg_dump(opts)).to eq(local_file)
end
end

context "with :local_file and :dbname in opts" do
let(:local_file) { "/some/path/to/pg.dump" }
let(:expected_opts) { { :local_file => local_file } }
let(:expected_args) { default_args.merge(nil => "mydb") }

it "runs the command and returns the :local_file opt" do
opts = expected_opts.merge(:dbname => "mydb")
expect(subject.backup_pg_dump(opts)).to eq(local_file)
end
end

context "with :local_file, :dbname, :username, and :password in opts" do
let(:local_file) { "/some/path/to/pg.dump" }
let(:expected_opts) do
{
:local_file => local_file,
:username => "admin",
:password => "smartvm"
}
end
let(:expected_args) do
default_args.merge(nil => "mydb", :username => "admin")
end

it "runs the command and returns the :local_file opt" do
opts = expected_opts.merge(:dbname => "mydb")
expect(subject.backup_pg_dump(opts)).to eq(local_file)
end
end

context "with :local_file, :dbname and :hostname in opts" do
let(:local_file) { "/some/path/to/pg.dump" }
let(:expected_opts) { { :local_file => local_file, :hostname => 'foo' } }
let(:expected_args) { default_args.merge(nil => "mydb", :host => 'foo') }

it "runs the command and returns the :local_file opt" do
opts = expected_opts.merge(:dbname => "mydb")
expect(subject.backup_pg_dump(opts)).to eq(local_file)
end
end
end

context "ENV dependent" do
after do
ENV.delete_if { |k, _| k.start_with?("APPLIANCE") }
Expand Down

0 comments on commit d1a2916

Please sign in to comment.