db-clone 1.1.1 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +12 -0
- data/.rspec +1 -0
- data/.travis.yml +5 -0
- data/Gemfile +9 -0
- data/LICENSE.txt +21 -0
- data/README.md +61 -0
- data/Rakefile +13 -20
- data/bin/console +14 -0
- data/bin/setup +8 -0
- data/db-clone.gemspec +30 -0
- data/lib/db/clone.rb +50 -0
- data/lib/db/clone/base.rb +59 -0
- data/lib/{db_clone → db/clone}/cmd_builder.rb +10 -12
- data/lib/db/clone/cmd_prompt.rb +43 -0
- data/lib/db/clone/rake_task.rb +17 -0
- data/lib/db/clone/version.rb +5 -0
- data/screenshot.png +0 -0
- metadata +54 -123
- data/MIT-LICENSE +0 -20
- data/app/assets/javascripts/db_clone/application.js +0 -13
- data/app/assets/stylesheets/db_clone/application.css +0 -15
- data/app/controllers/db_clone/application_controller.rb +0 -5
- data/app/helpers/db_clone/application_helper.rb +0 -4
- data/app/views/layouts/db_clone/application.html.erb +0 -14
- data/config/routes.rb +0 -2
- data/lib/db_clone.rb +0 -27
- data/lib/db_clone/db_selections.rb +0 -65
- data/lib/db_clone/engine.rb +0 -14
- data/lib/db_clone/version.rb +0 -3
- data/lib/tasks/db_clone_tasks.rake +0 -6
- data/spec/cmd_builder_spec.rb +0 -73
- data/spec/db_clone_spec.rb +0 -15
- data/spec/db_selections_spec.rb +0 -74
- data/spec/dummy/README.rdoc +0 -28
- data/spec/dummy/Rakefile +0 -6
- data/spec/dummy/app/assets/javascripts/application.js +0 -13
- data/spec/dummy/app/assets/stylesheets/application.css +0 -15
- data/spec/dummy/app/controllers/application_controller.rb +0 -5
- data/spec/dummy/app/helpers/application_helper.rb +0 -2
- data/spec/dummy/app/views/layouts/application.html.erb +0 -14
- data/spec/dummy/bin/bundle +0 -3
- data/spec/dummy/bin/rails +0 -4
- data/spec/dummy/bin/rake +0 -4
- data/spec/dummy/bin/setup +0 -29
- data/spec/dummy/config.ru +0 -4
- data/spec/dummy/config/application.rb +0 -31
- data/spec/dummy/config/boot.rb +0 -5
- data/spec/dummy/config/database.yml +0 -59
- data/spec/dummy/config/environment.rb +0 -5
- data/spec/dummy/config/environments/development.rb +0 -41
- data/spec/dummy/config/environments/production.rb +0 -79
- data/spec/dummy/config/environments/test.rb +0 -42
- data/spec/dummy/config/initializers/assets.rb +0 -11
- data/spec/dummy/config/initializers/backtrace_silencers.rb +0 -7
- data/spec/dummy/config/initializers/cookies_serializer.rb +0 -3
- data/spec/dummy/config/initializers/filter_parameter_logging.rb +0 -4
- data/spec/dummy/config/initializers/inflections.rb +0 -16
- data/spec/dummy/config/initializers/mime_types.rb +0 -4
- data/spec/dummy/config/initializers/session_store.rb +0 -3
- data/spec/dummy/config/initializers/wrap_parameters.rb +0 -14
- data/spec/dummy/config/locales/en.yml +0 -23
- data/spec/dummy/config/routes.rb +0 -4
- data/spec/dummy/config/secrets.yml +0 -22
- data/spec/dummy/log/test.log +0 -40
- data/spec/dummy/public/404.html +0 -67
- data/spec/dummy/public/422.html +0 -67
- data/spec/dummy/public/500.html +0 -66
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/rails_helper.rb +0 -59
- data/spec/spec_helper.rb +0 -92
data/lib/db_clone/engine.rb
DELETED
@@ -1,14 +0,0 @@
|
|
1
|
-
module DbClone
|
2
|
-
class Engine < ::Rails::Engine
|
3
|
-
isolate_namespace DbClone
|
4
|
-
|
5
|
-
engine_name 'db-clone'
|
6
|
-
|
7
|
-
config.generators do |g|
|
8
|
-
g.test_framework :rspec, :fixture => false
|
9
|
-
g.fixture_replacement :factory_girl, :dir => 'spec/factories'
|
10
|
-
g.assets false
|
11
|
-
g.helper false
|
12
|
-
end
|
13
|
-
end
|
14
|
-
end
|
data/lib/db_clone/version.rb
DELETED
data/spec/cmd_builder_spec.rb
DELETED
@@ -1,73 +0,0 @@
|
|
1
|
-
require 'rails_helper'
|
2
|
-
|
3
|
-
module DbClone
|
4
|
-
describe CmdBuilder do
|
5
|
-
describe 'postgresql command builder' do
|
6
|
-
h = {
|
7
|
-
src: {
|
8
|
-
'adapter' => 'postgresql',
|
9
|
-
'encoding' => 'unicode',
|
10
|
-
'database' => 'other_postgresql_db',
|
11
|
-
'username' => 'other_postgresql_user',
|
12
|
-
'password' => 'other_postgresql_password',
|
13
|
-
'host' => 'fake_postgresql_host',
|
14
|
-
'port' => 5432,
|
15
|
-
:label => 'second_test_postgresql'
|
16
|
-
},
|
17
|
-
dest: {
|
18
|
-
'adapter' => 'postgresql',
|
19
|
-
'encoding' => 'unicode',
|
20
|
-
'database' => 'fake_postgresql_db',
|
21
|
-
'username' => 'fake_postgresql_user',
|
22
|
-
'password' => 'fake_postgresql_password',
|
23
|
-
'host' => 'fake_postgresql_host',
|
24
|
-
'port' => 5432,
|
25
|
-
:label => 'test_postgresql'
|
26
|
-
}
|
27
|
-
}
|
28
|
-
cb = CmdBuilder.new h
|
29
|
-
|
30
|
-
it 'should be able to generate a pg_dump command' do
|
31
|
-
expect(cb.get_cmd).to eql("pg_dump --no-password --clean --host=fake_postgresql_host --port=5432 --username=other_postgresql_user other_postgresql_db | psql --host=fake_postgresql_host --port=5432 --username=fake_postgresql_user fake_postgresql_db")
|
32
|
-
end
|
33
|
-
end
|
34
|
-
|
35
|
-
describe 'mysql command builder' do
|
36
|
-
before(:each) do
|
37
|
-
@h = {
|
38
|
-
:src => {
|
39
|
-
'adapter' => 'mysql2',
|
40
|
-
'database' => 'fake_mysql_db',
|
41
|
-
'username' => 'fake_mysql_usr',
|
42
|
-
'password' => 'fake_mysql_password',
|
43
|
-
'host' => 'fake_mysql_host',
|
44
|
-
'port' => 3306,
|
45
|
-
:label => 'test_mysql'
|
46
|
-
},
|
47
|
-
:dest => {
|
48
|
-
'adapter' => 'mysql2',
|
49
|
-
'database' => 'other_mysql_db',
|
50
|
-
'username' => 'other_mysql_usr',
|
51
|
-
'password' => 'other_mysql_password',
|
52
|
-
'host' => 'other_mysql_host',
|
53
|
-
'port' => 3306,
|
54
|
-
:label => 'second_test_mysql'
|
55
|
-
}
|
56
|
-
}
|
57
|
-
end
|
58
|
-
|
59
|
-
it 'should be able to generate a mysqldump command' do
|
60
|
-
cb = CmdBuilder.new @h
|
61
|
-
expect(cb.get_cmd).to eql("mysqldump --no-create-db --add-drop-table --lock-tables=false --user=fake_mysql_usr --password=fake_mysql_password --host=fake_mysql_host --port=3306 fake_mysql_db | mysql --user=other_mysql_usr --password=other_mysql_password --host=other_mysql_host --port=3306 other_mysql_db")
|
62
|
-
end
|
63
|
-
|
64
|
-
it 'should be able to generate a mysqldump command with ignore tables' do
|
65
|
-
DbClone.config = {
|
66
|
-
ignore_tables: ['tableAAAA', 'tableBBBB', 'tableCCCC']
|
67
|
-
}
|
68
|
-
cb = CmdBuilder.new @h
|
69
|
-
expect(cb.get_cmd).to eql("mysqldump --no-create-db --add-drop-table --lock-tables=false --user=fake_mysql_usr --password=fake_mysql_password --host=fake_mysql_host --port=3306 --ignore-table=fake_mysql_db.tableAAAA --ignore-table=fake_mysql_db.tableBBBB --ignore-table=fake_mysql_db.tableCCCC fake_mysql_db | mysql --user=other_mysql_usr --password=other_mysql_password --host=other_mysql_host --port=3306 other_mysql_db")
|
70
|
-
end
|
71
|
-
end
|
72
|
-
end
|
73
|
-
end
|
data/spec/db_clone_spec.rb
DELETED
@@ -1,15 +0,0 @@
|
|
1
|
-
require 'rails_helper'
|
2
|
-
|
3
|
-
module DbClone
|
4
|
-
describe DbClone do
|
5
|
-
it 'should be able to auto clone' do
|
6
|
-
DbClone.config = {
|
7
|
-
default_source: 'second_test_mysql',
|
8
|
-
default_destination: 'test_mysql',
|
9
|
-
}
|
10
|
-
ds = DbSelections.new Rails.root.join('config', 'database.yml')
|
11
|
-
cb = CmdBuilder.new ds.selections( use_defaults: true )
|
12
|
-
expect(cb.get_cmd).to eql("mysqldump --no-create-db --add-drop-table --lock-tables=false --user=other_mysql_usr --password=other_mysql_password --host=other_mysql_host --port=3306 other_mysql_db | mysql --user=fake_mysql_usr --password=fake_mysql_password --host=fake_mysql_host --port=3306 fake_mysql_db")
|
13
|
-
end
|
14
|
-
end
|
15
|
-
end
|
data/spec/db_selections_spec.rb
DELETED
@@ -1,74 +0,0 @@
|
|
1
|
-
require 'rails_helper'
|
2
|
-
|
3
|
-
module DbClone
|
4
|
-
describe DbSelections do
|
5
|
-
describe 'db selections' do
|
6
|
-
DbClone.config = {
|
7
|
-
default_source: 'production',
|
8
|
-
default_destination: 'development',
|
9
|
-
}
|
10
|
-
ds = DbSelections.new Rails.root.join('config', 'database.yml')
|
11
|
-
|
12
|
-
it 'should prompt for a source' do
|
13
|
-
str = "\n Choose a \e[0;35;49msource\e[0m database from one of the blocks defined in \e[0;92;49mconfig/database.yml\e[0m:\n\n [ \e[0;94;49m1\e[0m ] \e[0;33;49mdefault\e[0m\n [ \e[0;94;49m2\e[0m ] \e[0;33;49mdevelopment\e[0m\n [ \e[0;94;49m3\e[0m ] \e[0;33;49mproduction\e[0m\n [ \e[0;94;49m4\e[0m ] \e[0;33;49msecond_test_mysql\e[0m\n [ \e[0;94;49m5\e[0m ] \e[0;33;49msecond_test_postgresql\e[0m\n [ \e[0;94;49m6\e[0m ] \e[0;33;49mtest\e[0m\n [ \e[0;94;49m7\e[0m ] \e[0;33;49mtest_mysql\e[0m\n [ \e[0;94;49m8\e[0m ] \e[0;33;49mtest_postgresql\e[0m\n\n Choose a \e[0;35;49msource\e[0m database (\e[0;94;49m1\e[0m-\e[0;94;49m8\e[0m) [production = \e[0;94;49m3\e[0m]: "
|
14
|
-
expect { ds.source_prompt }.to output(str).to_stdout
|
15
|
-
end
|
16
|
-
|
17
|
-
it 'should set a source' do
|
18
|
-
allow(STDIN).to receive(:gets) { '5' }
|
19
|
-
str = "\n \e[0;35;49mSource\e[0m set to: \e[0;33;49msecond_test_postgresql\e[0m\n"
|
20
|
-
expect { ds.source_get }.to output(str).to_stdout
|
21
|
-
end
|
22
|
-
|
23
|
-
it 'should prompt for a destination' do
|
24
|
-
str = "\n Choose a \e[0;35;49mdestination\e[0m database from one of the blocks defined in \e[0;92;49mconfig/database.yml\e[0m:\n\n [ \e[0;94;49m1\e[0m ] \e[0;33;49mdefault\e[0m\n [ \e[0;94;49m2\e[0m ] \e[0;33;49mdevelopment\e[0m\n [ \e[0;94;49m3\e[0m ] \e[0;33;49mproduction\e[0m\n [ \e[0;94;49m4\e[0m ] \e[0;33;49msecond_test_mysql\e[0m\n [ \e[0;31;49mX\e[0m ] \e[0;31;49msecond_test_postgresql\e[0m\n [ \e[0;94;49m6\e[0m ] \e[0;33;49mtest\e[0m\n [ \e[0;94;49m7\e[0m ] \e[0;33;49mtest_mysql\e[0m\n [ \e[0;94;49m8\e[0m ] \e[0;33;49mtest_postgresql\e[0m\n\n Choose a \e[0;35;49mdestination\e[0m database (\e[0;94;49m1\e[0m-\e[0;94;49m8\e[0m) [development = \e[0;94;49m2\e[0m]: "
|
25
|
-
expect { ds.dest_prompt }.to output(str).to_stdout
|
26
|
-
end
|
27
|
-
|
28
|
-
it 'should set a destination' do
|
29
|
-
allow(STDIN).to receive(:gets) { '8' }
|
30
|
-
str = "\n \e[0;35;49mDestination\e[0m set to: \e[0;33;49mtest_postgresql\e[0m\n"
|
31
|
-
expect { ds.dest_get }.to output(str).to_stdout
|
32
|
-
end
|
33
|
-
|
34
|
-
it 'should have a source and destination set' do
|
35
|
-
expected_selections = {
|
36
|
-
src: {
|
37
|
-
'adapter' => 'postgresql',
|
38
|
-
'encoding' => 'unicode',
|
39
|
-
'database' => 'other_postgresql_db',
|
40
|
-
'username' => 'other_postgresql_user',
|
41
|
-
'password' => 'other_postgresql_password',
|
42
|
-
'host' => 'fake_postgresql_host',
|
43
|
-
'port' => 5432,
|
44
|
-
:label => 'second_test_postgresql'
|
45
|
-
},
|
46
|
-
dest: {
|
47
|
-
'adapter' => 'postgresql',
|
48
|
-
'encoding' => 'unicode',
|
49
|
-
'database' => 'fake_postgresql_db',
|
50
|
-
'username' => 'fake_postgresql_user',
|
51
|
-
'password' => 'fake_postgresql_password',
|
52
|
-
'host' => 'fake_postgresql_host',
|
53
|
-
'port' => 5432,
|
54
|
-
:label => 'test_postgresql'
|
55
|
-
}
|
56
|
-
}
|
57
|
-
expect(ds.selections).to eql(expected_selections)
|
58
|
-
end
|
59
|
-
end
|
60
|
-
|
61
|
-
describe 'db mismatched selections' do
|
62
|
-
ds = DbSelections.new Rails.root.join('config', 'database.yml')
|
63
|
-
|
64
|
-
it 'should prohibit cloneing between different adapters' do
|
65
|
-
expect { ds.source_prompt }.to output.to_stdout
|
66
|
-
allow(STDIN).to receive(:gets) { '7' }
|
67
|
-
expect { ds.source_get }.to output.to_stdout
|
68
|
-
expect { ds.dest_prompt }.to output.to_stdout
|
69
|
-
allow(STDIN).to receive(:gets) { '8' }
|
70
|
-
expect { ds.dest_get }.to raise_error(ArgumentError)
|
71
|
-
end
|
72
|
-
end
|
73
|
-
end
|
74
|
-
end
|
data/spec/dummy/README.rdoc
DELETED
@@ -1,28 +0,0 @@
|
|
1
|
-
== README
|
2
|
-
|
3
|
-
This README would normally document whatever steps are necessary to get the
|
4
|
-
application up and running.
|
5
|
-
|
6
|
-
Things you may want to cover:
|
7
|
-
|
8
|
-
* Ruby version
|
9
|
-
|
10
|
-
* System dependencies
|
11
|
-
|
12
|
-
* Configuration
|
13
|
-
|
14
|
-
* Database creation
|
15
|
-
|
16
|
-
* Database initialization
|
17
|
-
|
18
|
-
* How to run the test suite
|
19
|
-
|
20
|
-
* Services (job queues, cache servers, search engines, etc.)
|
21
|
-
|
22
|
-
* Deployment instructions
|
23
|
-
|
24
|
-
* ...
|
25
|
-
|
26
|
-
|
27
|
-
Please feel free to use a different markup language if you do not plan to run
|
28
|
-
<tt>rake doc:app</tt>.
|
data/spec/dummy/Rakefile
DELETED
@@ -1,13 +0,0 @@
|
|
1
|
-
// This is a manifest file that'll be compiled into application.js, which will include all the files
|
2
|
-
// listed below.
|
3
|
-
//
|
4
|
-
// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
|
5
|
-
// or any plugin's vendor/assets/javascripts directory can be referenced here using a relative path.
|
6
|
-
//
|
7
|
-
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
8
|
-
// compiled file.
|
9
|
-
//
|
10
|
-
// Read Sprockets README (https://github.com/rails/sprockets#sprockets-directives) for details
|
11
|
-
// about supported directives.
|
12
|
-
//
|
13
|
-
//= require_tree .
|
@@ -1,15 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
* This is a manifest file that'll be compiled into application.css, which will include all the files
|
3
|
-
* listed below.
|
4
|
-
*
|
5
|
-
* Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
|
6
|
-
* or any plugin's vendor/assets/stylesheets directory can be referenced here using a relative path.
|
7
|
-
*
|
8
|
-
* You're free to add application-wide styles to this file and they'll appear at the bottom of the
|
9
|
-
* compiled file so the styles you add here take precedence over styles defined in any styles
|
10
|
-
* defined in the other CSS/SCSS files in this directory. It is generally better to create a new
|
11
|
-
* file per style scope.
|
12
|
-
*
|
13
|
-
*= require_tree .
|
14
|
-
*= require_self
|
15
|
-
*/
|
@@ -1,14 +0,0 @@
|
|
1
|
-
<!DOCTYPE html>
|
2
|
-
<html>
|
3
|
-
<head>
|
4
|
-
<title>Dummy</title>
|
5
|
-
<%= stylesheet_link_tag 'application', media: 'all', 'data-turbolinks-track' => true %>
|
6
|
-
<%= javascript_include_tag 'application', 'data-turbolinks-track' => true %>
|
7
|
-
<%= csrf_meta_tags %>
|
8
|
-
</head>
|
9
|
-
<body>
|
10
|
-
|
11
|
-
<%= yield %>
|
12
|
-
|
13
|
-
</body>
|
14
|
-
</html>
|
data/spec/dummy/bin/bundle
DELETED
data/spec/dummy/bin/rails
DELETED
data/spec/dummy/bin/rake
DELETED
data/spec/dummy/bin/setup
DELETED
@@ -1,29 +0,0 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
require 'pathname'
|
3
|
-
|
4
|
-
# path to your application root.
|
5
|
-
APP_ROOT = Pathname.new File.expand_path('../../', __FILE__)
|
6
|
-
|
7
|
-
Dir.chdir APP_ROOT do
|
8
|
-
# This script is a starting point to setup your application.
|
9
|
-
# Add necessary setup steps to this file:
|
10
|
-
|
11
|
-
puts "== Installing dependencies =="
|
12
|
-
system "gem install bundler --conservative"
|
13
|
-
system "bundle check || bundle install"
|
14
|
-
|
15
|
-
# puts "\n== Copying sample files =="
|
16
|
-
# unless File.exist?("config/database.yml")
|
17
|
-
# system "cp config/database.yml.sample config/database.yml"
|
18
|
-
# end
|
19
|
-
|
20
|
-
puts "\n== Preparing database =="
|
21
|
-
system "bin/rake db:setup"
|
22
|
-
|
23
|
-
puts "\n== Removing old logs and tempfiles =="
|
24
|
-
system "rm -f log/*"
|
25
|
-
system "rm -rf tmp/cache"
|
26
|
-
|
27
|
-
puts "\n== Restarting application server =="
|
28
|
-
system "touch tmp/restart.txt"
|
29
|
-
end
|
data/spec/dummy/config.ru
DELETED
@@ -1,31 +0,0 @@
|
|
1
|
-
require File.expand_path('../boot', __FILE__)
|
2
|
-
|
3
|
-
# Pick the frameworks you want:
|
4
|
-
require "active_record/railtie"
|
5
|
-
require "action_controller/railtie"
|
6
|
-
require "action_mailer/railtie"
|
7
|
-
require "action_view/railtie"
|
8
|
-
require "sprockets/railtie"
|
9
|
-
# require "rails/test_unit/railtie"
|
10
|
-
|
11
|
-
Bundler.require(*Rails.groups)
|
12
|
-
require "db_clone"
|
13
|
-
|
14
|
-
module Dummy
|
15
|
-
class Application < Rails::Application
|
16
|
-
# Settings in config/environments/* take precedence over those specified here.
|
17
|
-
# Application configuration should go into files in config/initializers
|
18
|
-
# -- all .rb files in that directory are automatically loaded.
|
19
|
-
|
20
|
-
# Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
|
21
|
-
# Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
|
22
|
-
# config.time_zone = 'Central Time (US & Canada)'
|
23
|
-
|
24
|
-
# The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
|
25
|
-
# config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
|
26
|
-
# config.i18n.default_locale = :de
|
27
|
-
|
28
|
-
# Do not swallow errors in after_commit/after_rollback callbacks.
|
29
|
-
config.active_record.raise_in_transactional_callbacks = true
|
30
|
-
end
|
31
|
-
end
|
data/spec/dummy/config/boot.rb
DELETED
@@ -1,59 +0,0 @@
|
|
1
|
-
# SQLite version 3.x
|
2
|
-
# gem install sqlite3
|
3
|
-
#
|
4
|
-
# Ensure the SQLite 3 gem is defined in your Gemfile
|
5
|
-
# gem 'sqlite3'
|
6
|
-
#
|
7
|
-
default: &default
|
8
|
-
adapter: sqlite3
|
9
|
-
pool: 5
|
10
|
-
timeout: 5000
|
11
|
-
|
12
|
-
development:
|
13
|
-
<<: *default
|
14
|
-
database: db/development.sqlite3
|
15
|
-
|
16
|
-
# Warning: The database defined as "test" will be erased and
|
17
|
-
# re-generated from your development database when you run "rake".
|
18
|
-
# Do not set this db to the same as development or production.
|
19
|
-
test:
|
20
|
-
<<: *default
|
21
|
-
database: db/test.sqlite3
|
22
|
-
|
23
|
-
production:
|
24
|
-
<<: *default
|
25
|
-
database: db/production.sqlite3
|
26
|
-
|
27
|
-
test_mysql:
|
28
|
-
adapter: mysql2
|
29
|
-
database: fake_mysql_db
|
30
|
-
username: fake_mysql_usr
|
31
|
-
password: fake_mysql_password
|
32
|
-
host: fake_mysql_host
|
33
|
-
port: 3306
|
34
|
-
|
35
|
-
test_postgresql:
|
36
|
-
adapter: postgresql
|
37
|
-
encoding: unicode
|
38
|
-
database: fake_postgresql_db
|
39
|
-
username: fake_postgresql_user
|
40
|
-
password: fake_postgresql_password
|
41
|
-
host: fake_postgresql_host
|
42
|
-
port: 5432
|
43
|
-
|
44
|
-
second_test_mysql:
|
45
|
-
adapter: mysql2
|
46
|
-
database: other_mysql_db
|
47
|
-
username: other_mysql_usr
|
48
|
-
password: other_mysql_password
|
49
|
-
host: other_mysql_host
|
50
|
-
port: 3306
|
51
|
-
|
52
|
-
second_test_postgresql:
|
53
|
-
adapter: postgresql
|
54
|
-
encoding: unicode
|
55
|
-
database: other_postgresql_db
|
56
|
-
username: other_postgresql_user
|
57
|
-
password: other_postgresql_password
|
58
|
-
host: fake_postgresql_host
|
59
|
-
port: 5432
|