ridgepole 0.6.6 → 0.7.0.alpha

Sign up to get free protection for your applications and to get access to all the features.
Files changed (73) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +2 -7
  3. data/Appraisals +4 -5
  4. data/README.md +3 -0
  5. data/gemfiles/activerecord_5.0.gemfile +1 -1
  6. data/gemfiles/{activerecord_4.2.gemfile → activerecord_5.1.gemfile} +1 -2
  7. data/lib/ridgepole.rb +1 -0
  8. data/lib/ridgepole/client.rb +1 -3
  9. data/lib/ridgepole/connection_adapters.rb +11 -0
  10. data/lib/ridgepole/delta.rb +5 -0
  11. data/lib/ridgepole/diff.rb +5 -10
  12. data/lib/ridgepole/dsl_parser/context.rb +1 -4
  13. data/lib/ridgepole/dumper.rb +0 -11
  14. data/lib/ridgepole/schema_statements_ext.rb +1 -1
  15. data/lib/ridgepole/version.rb +1 -1
  16. data/ridgepole.gemspec +2 -2
  17. data/ridgepole.iml +9 -0
  18. data/spec/erb_helper.rb +25 -15
  19. data/spec/mysql/bigint_pk/bigint_pk_spec.rb +15 -15
  20. data/spec/mysql/bigint_pk/int_pk_spec.rb +45 -0
  21. data/spec/mysql/cli/config_spec.rb +7 -7
  22. data/spec/mysql/cli/ridgepole_spec.rb +20 -20
  23. data/spec/mysql/collation/collation_spec.rb +40 -41
  24. data/spec/mysql/comment/comment_spec.rb +19 -19
  25. data/spec/mysql/default_lambda/default_lambda_spec.rb +3 -3
  26. data/spec/mysql/diff/diff2_spec.rb +8 -5
  27. data/spec/mysql/diff/diff_spec.rb +8 -5
  28. data/spec/mysql/dump/dump_class_method_spec.rb +18 -68
  29. data/spec/mysql/dump/dump_some_tables_spec.rb +10 -30
  30. data/spec/mysql/dump/dump_spec.rb +21 -54
  31. data/spec/mysql/dump/dump_without_table_options_spec.rb +8 -35
  32. data/spec/mysql/fk/migrate_change_fk_spec.rb +8 -8
  33. data/spec/mysql/fk/migrate_create_fk_spec.rb +21 -35
  34. data/spec/mysql/fk/migrate_drop_fk_spec.rb +16 -30
  35. data/spec/mysql/migrate/migrate_add_column2_spec.rb +3 -5
  36. data/spec/mysql/migrate/migrate_add_column_order_spec.rb +21 -39
  37. data/spec/mysql/migrate/migrate_change_column5_spec.rb +8 -8
  38. data/spec/mysql/migrate/migrate_change_column6_spec.rb +18 -18
  39. data/spec/mysql/migrate/migrate_change_column_default_spec.rb +23 -16
  40. data/spec/mysql/migrate/migrate_change_column_spec.rb +34 -34
  41. data/spec/mysql/migrate/migrate_change_index3_spec.rb +19 -9
  42. data/spec/mysql/migrate/migrate_create_index_spec.rb +32 -32
  43. data/spec/mysql/migrate/migrate_create_table_spec.rb +0 -9
  44. data/spec/mysql/migrate/migrate_drop_index_spec.rb +32 -32
  45. data/spec/mysql/migrate/migrate_drop_table_spec.rb +30 -30
  46. data/spec/mysql/migrate/migrate_execute_spec.rb +68 -81
  47. data/spec/mysql/migrate/migrate_merge_mode_spec.rb +1 -3
  48. data/spec/mysql/migrate/migrate_noop_spec.rb +34 -61
  49. data/spec/mysql/migrate/migrate_rename_table_spec.rb +3 -24
  50. data/spec/mysql/migrate/migrate_same_spec.rb +12 -45
  51. data/spec/mysql/migrate/migrate_with_ignore_tables_spec.rb +6 -6
  52. data/spec/mysql/migrate/migrate_with_tables_spec.rb +2 -2
  53. data/spec/mysql/migrate/migrate_with_verbose_log_spec.rb +1 -6
  54. data/spec/mysql/migrate_/migrate_drop_index_with_alter_spec.rb +10 -10
  55. data/spec/mysql/text_blob_types/text_blob_types_spec.rb +3 -3
  56. data/spec/mysql/~default_name_fk/migrate_change_fk_spec.rb +6 -6
  57. data/spec/mysql/~default_name_fk/migrate_create_fk_spec.rb +10 -10
  58. data/spec/mysql/~default_name_fk/migrate_drop_fk_spec.rb +6 -6
  59. data/spec/postgresql/diff/diff_spec.rb +6 -0
  60. data/spec/postgresql/dump/dump_spec.rb +9 -33
  61. data/spec/postgresql/migrate/migrate_add_expression_index_spec.rb +3 -3
  62. data/spec/postgresql/migrate/migrate_bigint_spec.rb +10 -26
  63. data/spec/postgresql/migrate/migrate_create_table_spec.rb +0 -9
  64. data/spec/postgresql/migrate/migrate_create_table_with_default_proc_spec.rb +1 -1
  65. data/spec/postgresql/migrate/migrate_drop_column_with_index_spec.rb +2 -2
  66. data/spec/postgresql/migrate/migrate_drop_expression_index_spec.rb +7 -7
  67. data/spec/postgresql/migrate/migrate_drop_index_spec.rb +4 -4
  68. data/spec/postgresql/migrate/migrate_drop_table_spec.rb +3 -3
  69. data/spec/postgresql/migrate/migrate_ext_cols_spec.rb +0 -3
  70. data/spec/postgresql/migrate/migrate_same_spec.rb +9 -33
  71. data/spec/spec_condition.rb +15 -6
  72. data/spec/spec_helper.rb +2 -15
  73. metadata +14 -10
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: ea467f03fc539a7a3ea42722fe4b42e552d5583a
4
- data.tar.gz: 2d679e42be6a6f3a1034ff8ccfa66e8c349a9403
3
+ metadata.gz: 9c4e5ed48fbd6469287d34ef340f9a3693fc2470
4
+ data.tar.gz: e9cc11808cd560064217cf5441a875df892ca207
5
5
  SHA512:
6
- metadata.gz: 297ace649b5038d556ae3255f0745daed7f3d07fb9c7dfeeedff13d4ec9fe92560a70e1076f3a6e11078e69d49341daba87f8a63456ddbbe902bb30d056f1c67
7
- data.tar.gz: '062959707f274e168ae6bf8b81a65d24383fb168a1af074196aaf07ccde80a4974ffcc8ba6ff53bc881785b98220c5c0e912800c3203e567d5aa0c52f977eec6'
6
+ metadata.gz: ad5e244204d6cad0ea31b7b330813f2086e49881e4773277748beaf5f36de9e2c7a927bad952acdaf87631a1f932aa97ca5c0eaeeafe16bd35b06c5e9604637c
7
+ data.tar.gz: 4e6abdd8a8fd60bf425cf2431c693f140ddcf7836fd1b5f2353f31aa57f870def2d4c6442e0e144839010a3b8b4bd4d0927428cbb74bf23f821a68939c0fbe4b
@@ -21,17 +21,12 @@ before_script:
21
21
  script:
22
22
  - bundle exec rake
23
23
  gemfile:
24
- - gemfiles/activerecord_4.2.gemfile
25
24
  - gemfiles/activerecord_5.0.gemfile
25
+ - gemfiles/activerecord_5.1.gemfile
26
26
  env:
27
27
  matrix:
28
- - ENABLE_MYSQL_AWESOME=0
29
- - ENABLE_MYSQL_AWESOME=1
28
+ - POSTGRESQL=0
30
29
  - POSTGRESQL=1
31
- matrix:
32
- exclude:
33
- - env: ENABLE_MYSQL_AWESOME=1
34
- gemfile: gemfiles/activerecord_5.0.gemfile
35
30
  services:
36
31
  - docker
37
32
  addons:
data/Appraisals CHANGED
@@ -1,8 +1,7 @@
1
- appraise "activerecord-4.2" do
2
- gem 'activerecord', '~> 4.2.0'
3
- gem 'activerecord-mysql-awesome', '>= 0.0.7'
1
+ appraise 'activerecord-5.0' do
2
+ gem 'activerecord', '~> 5.0.1'
4
3
  end
5
4
 
6
- appraise 'activerecord-5.0' do
7
- gem 'activerecord', '~> 5.0.0'
5
+ appraise 'activerecord-5.1' do
6
+ gem 'activerecord', '~> 5.1.0'
8
7
  end
data/README.md CHANGED
@@ -73,6 +73,9 @@ add_foreign_key :articles, :authors # without `name:`
73
73
  * Use `t.column` for migration ([pull#114](https://github.com/winebarrel/ridgepole/pull/114))
74
74
  * Support DATABASE_URL format ([pull#118](https://github.com/winebarrel/ridgepole/pull/118))
75
75
  * Add Ruby2.4 CI ([pull#119](https://github.com/winebarrel/ridgepole/pull/119))
76
+ * `>= 0.7.0`
77
+ * Remove Rails 4.x support
78
+ * Add Rails 5.1 support
76
79
 
77
80
  ## Installation
78
81
 
@@ -2,6 +2,6 @@
2
2
 
3
3
  source "https://rubygems.org"
4
4
 
5
- gem "activerecord", "~> 5.0.0"
5
+ gem "activerecord", "~> 5.0.1"
6
6
 
7
7
  gemspec path: "../"
@@ -2,7 +2,6 @@
2
2
 
3
3
  source "https://rubygems.org"
4
4
 
5
- gem "activerecord", "~> 4.2.0"
6
- gem "activerecord-mysql-awesome", ">= 0.0.7"
5
+ gem "activerecord", "~> 5.1.0"
7
6
 
8
7
  gemspec path: "../"
@@ -14,6 +14,7 @@ require 'diffy'
14
14
  module Ridgepole; end
15
15
 
16
16
  require 'ridgepole/client'
17
+ require 'ridgepole/connection_adapters'
17
18
  require 'ridgepole/default_limit'
18
19
  require 'ridgepole/delta'
19
20
  require 'ridgepole/diff'
@@ -26,9 +26,7 @@ class Ridgepole::Client
26
26
  require 'ridgepole/ext/schema_dumper'
27
27
  end
28
28
 
29
- if ActiveRecord::VERSION::MAJOR >= 5 and @options[:dump_without_table_options]
30
- require 'ridgepole/ext/abstract_mysql_adapter/disable_table_options'
31
- end
29
+ require 'ridgepole/ext/abstract_mysql_adapter/disable_table_options'
32
30
  end
33
31
 
34
32
  def dump(&block)
@@ -0,0 +1,11 @@
1
+ module Ridgepole
2
+ class ConnectionAdapters
3
+ def self.mysql?
4
+ defined?(ActiveRecord::ConnectionAdapters::AbstractMysqlAdapter) && ActiveRecord::Base.connection.is_a?(ActiveRecord::ConnectionAdapters::AbstractMysqlAdapter)
5
+ end
6
+
7
+ def self.postgresql?
8
+ defined?(ActiveRecord::ConnectionAdapters::PostgreSQLAdapter) && ActiveRecord::Base.connection.is_a?(ActiveRecord::ConnectionAdapters::PostgreSQLAdapter)
9
+ end
10
+ end
11
+ end
@@ -345,6 +345,11 @@ rename_column(#{table_name.inspect}, #{from_column_name.inspect}, #{to_column_na
345
345
  type = attrs.fetch(:type)
346
346
  options = attrs[:options] || {}
347
347
 
348
+ # Fix for https://github.com/rails/rails/commit/7f0567b43b73b1bd1a16bfac9cd32fcbf1321b51
349
+ if Ridgepole::ConnectionAdapters.mysql? and ActiveRecord::VERSION::STRING !~ /\A5\.0\./
350
+ options[:comment] = nil unless options.has_key?(:comment)
351
+ end
352
+
348
353
  if @options[:bulk_change]
349
354
  buf.puts(<<-EOS)
350
355
  t.change(#{column_name.inspect}, #{type.inspect}, #{inspect_options_include_default_proc(options)})
@@ -55,8 +55,6 @@ class Ridgepole::Diff
55
55
  next unless target?(table_name)
56
56
 
57
57
  if (from_table_name = (to_attrs[:options] || {}).delete(:renamed_from))
58
- from_table_name = from_table_name.to_s if from_table_name
59
-
60
58
  # Already renamed
61
59
  next if from[table_name]
62
60
 
@@ -149,7 +147,7 @@ class Ridgepole::Diff
149
147
  priv_column_name = column_name
150
148
  end
151
149
 
152
- if self.class.postgresql?
150
+ if Ridgepole::ConnectionAdapters.postgresql?
153
151
  added_size = 0
154
152
  to.reverse_each.with_index do |(column_name, to_attrs), i|
155
153
  if to_attrs[:options].delete(:after)
@@ -197,8 +195,6 @@ class Ridgepole::Diff
197
195
  def scan_column_rename(from, to, definition_delta)
198
196
  to.dup.each do |column_name, to_attrs|
199
197
  if (from_column_name = (to_attrs[:options] || {}).delete(:renamed_from))
200
- from_column_name = from_column_name.to_s if from_column_name
201
-
202
198
  # Already renamed
203
199
  next if from[column_name]
204
200
 
@@ -372,8 +368,10 @@ class Ridgepole::Diff
372
368
  to_attrs[:options].delete(:null)
373
369
  end
374
370
 
375
- if to_attrs[:options][:default] == nil and to_attrs[:options][:null] == false
376
- Ridgepole::Logger.instance.warn("[WARNING] Table `#{table_name}`: `default: nil` is ignored when `null: false`. Please apply twice")
371
+ if Ridgepole::ConnectionAdapters.mysql? and ActiveRecord::VERSION::STRING =~ /\A5\.0\./
372
+ if to_attrs[:options][:default] == nil and to_attrs[:options][:null] == false
373
+ Ridgepole::Logger.instance.warn("[WARNING] Table `#{table_name}`: `default: nil` is ignored when `null: false`. Please apply twice")
374
+ end
377
375
  end
378
376
 
379
377
  to_attrs
@@ -403,7 +401,4 @@ class Ridgepole::Diff
403
401
  diffy.to_s(:text).gsub(/\s+\z/m, '')
404
402
  end
405
403
 
406
- def self.postgresql?
407
- defined?(ActiveRecord::ConnectionAdapters::PostgreSQLAdapter) && ActiveRecord::Base.connection.is_a?(ActiveRecord::ConnectionAdapters::PostgreSQLAdapter)
408
- end
409
404
  end
@@ -65,10 +65,7 @@ class Ridgepole::DSLParser
65
65
  options[:length][col] = index_length
66
66
  end
67
67
 
68
- # XXX: fix for https://github.com/rails/rails/commit/5025fd3a99c68f95bdd6fd43f382c62e9653236b
69
- if ActiveRecord::VERSION::MAJOR >= 6 or (ActiveRecord::VERSION::MAJOR == 5 and (ActiveRecord::VERSION::MINOR >= 1 or ActiveRecord::VERSION::TINY >= 1))
70
- options[:length] = options[:length].symbolize_keys
71
- end
68
+ options[:length] = options[:length].symbolize_keys
72
69
  end
73
70
 
74
71
  @__definition[table_name][:indices][idx] = {
@@ -36,17 +36,6 @@ class Ridgepole::Dumper
36
36
  line !~ /\Aend/
37
37
  end
38
38
 
39
- # XXX: for activerecord-mysql-awesome
40
- if ActiveRecord::VERSION::MAJOR < 5
41
- dsl = dsl.map do |line|
42
- if @options[:dump_without_table_options] and line =~ /\A create_table /
43
- line.gsub(/, options: ("(?:[^"]|\")*")/, '')
44
- else
45
- line
46
- end
47
- end
48
- end
49
-
50
39
  dsl = dsl.join.strip_heredoc
51
40
 
52
41
  definitions = []
@@ -2,7 +2,7 @@ require 'active_record/connection_adapters/abstract/schema_statements'
2
2
 
3
3
  module Ridgepole
4
4
  module SchemaStatementsExt
5
- def index_name_exists?(table_name, column_name, options = {})
5
+ def index_name_exists?(table_name, column_name, default = nil)
6
6
  if Ridgepole::ExecuteExpander.noop
7
7
  caller_methods = caller.map {|i| i =~ /:\d+:in `(.+)'/ ? $1 : '' }
8
8
  if caller_methods.any? {|i| i =~ /\Aremove_index/ }
@@ -1,3 +1,3 @@
1
1
  module Ridgepole
2
- VERSION = '0.6.6'
2
+ VERSION = '0.7.0.alpha'
3
3
  end
@@ -18,7 +18,7 @@ Gem::Specification.new do |spec|
18
18
  spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
19
  spec.require_paths = ['lib']
20
20
 
21
- spec.add_dependency 'activerecord', '>= 4.2', '< 6'
21
+ spec.add_dependency 'activerecord', '>= 5.0.1', '< 6'
22
22
  spec.add_dependency 'diffy'
23
23
  spec.add_development_dependency 'bundler'
24
24
  spec.add_development_dependency 'rake'
@@ -30,5 +30,5 @@ Gem::Specification.new do |spec|
30
30
  spec.add_development_dependency 'rspec-match_fuzzy', '>= 0.1.3'
31
31
  spec.add_development_dependency 'erbh', '>= 0.1.2'
32
32
  spec.add_development_dependency 'hash_modern_inspect', '>= 0.1.1'
33
- spec.add_development_dependency 'hash_order_helper', '>= 0.1.5'
33
+ spec.add_development_dependency 'hash_order_helper', '>= 0.1.6'
34
34
  end
@@ -0,0 +1,9 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <module type="WEB_MODULE" version="4">
3
+ <component name="NewModuleRootManager" inherit-compiler-output="true">
4
+ <exclude-output />
5
+ <content url="file://$MODULE_DIR$" />
6
+ <orderEntry type="inheritedJdk" />
7
+ <orderEntry type="sourceFolder" forTests="false" />
8
+ </component>
9
+ </module>
@@ -10,25 +10,29 @@ ERBh.define_method(:i) do |obj|
10
10
  end
11
11
 
12
12
  ERBh.define_method(:add_index) do |table_name, column_name, options|
13
- if condition(:activerecord_5)
14
- if options[:length].is_a?(Hash)
15
- options[:length] = options[:length].symbolize_keys
16
- end
13
+ if options[:length].is_a?(Hash)
14
+ options[:length] = options[:length].symbolize_keys
15
+ end
17
16
 
18
- @_erbout.sub!(/\bend\s*\z/, '')
17
+ @_erbout.sub!(/\bend\s*\z/, '')
19
18
 
20
- <<-EOS
21
- t.index #{column_name.inspect}, #{options.modern_inspect_without_brace}
22
- end
23
- EOS
24
- else
25
- "add_index #{table_name.inspect}, #{column_name.inspect}, #{options.modern_inspect_without_brace}"
19
+ # XXX:
20
+ if not condition('5.0') and options[:using] == :btree
21
+ options.delete(:using)
26
22
  end
23
+
24
+ # XXX:
25
+ if options.has_key?(:force_using)
26
+ options[:using] = options.delete(:force_using)
27
+ end
28
+
29
+ <<-EOS
30
+ t.index #{column_name.inspect}, #{options.modern_inspect_without_brace}
31
+ end
32
+ EOS
27
33
  end
28
34
 
29
35
  ERBh.define_method(:unsigned) do |value, *conds|
30
- conds = [:mysql_awesome_enabled] if conds.empty?
31
-
32
36
  if condition(*conds)
33
37
  {unsigned: value}
34
38
  else
@@ -37,11 +41,17 @@ ERBh.define_method(:unsigned) do |value, *conds|
37
41
  end
38
42
 
39
43
  ERBh.define_method(:limit) do |value, *conds|
40
- conds = [:activerecord_4] if conds.empty?
41
-
42
44
  if condition(*conds)
43
45
  {limit: value}
44
46
  else
45
47
  {}
46
48
  end
47
49
  end
50
+
51
+ ERBh.define_method(:cond) do |conds, m, e = nil|
52
+ if condition(*Array(conds))
53
+ m
54
+ else
55
+ e || (m.class.new rescue nil)
56
+ end
57
+ end
@@ -1,45 +1,45 @@
1
- describe 'Ridgepole::Client (with bigint pk)', condition: [:mysql_awesome_enabled, :activerecord_5] do
2
- let(:dsl1) {
3
- erbh(<<-EOS)
1
+ describe 'Ridgepole::Client (with bigint pk)', condition: '5.0.' do
2
+ let(:id_primary_key_create_table) {
3
+ <<-RUBY
4
4
  create_table "books", id: :primary_key, limit: 8, force: :cascade do |t|
5
- t.string "title", <%= i limit(255) + {null: false} %>
6
- t.integer "author_id", <%= i limit(4) + {null: false} %>
5
+ t.string "title", null: false
6
+ t.integer "author_id", null: false
7
7
  t.datetime "created_at"
8
8
  t.datetime "updated_at"
9
9
  end
10
- EOS
10
+ RUBY
11
11
  }
12
12
 
13
- let(:dsl2) {
14
- erbh(<<-EOS)
13
+ let(:id_bigint_create_table) {
14
+ <<-RUBY
15
15
  create_table "books", id: :bigint, force: :cascade do |t|
16
- t.string "title", <%= i limit(255) + {null: false} %>
17
- t.integer "author_id", <%= i limit(4) + {null: false} %>
16
+ t.string "title", null: false
17
+ t.integer "author_id", null: false
18
18
  t.datetime "created_at"
19
19
  t.datetime "updated_at"
20
20
  end
21
- EOS
21
+ RUBY
22
22
  }
23
23
 
24
24
  context 'when with limit:8' do
25
25
  subject { client }
26
26
 
27
- before { subject.diff(dsl1).migrate }
27
+ before { subject.diff(id_primary_key_create_table).migrate }
28
28
 
29
29
  it {
30
30
  expect(show_create_table(:books)).to include '`id` bigint(20) NOT NULL AUTO_INCREMENT'
31
- expect(subject.dump).to match_fuzzy dsl2
31
+ expect(subject.dump).to match_fuzzy id_bigint_create_table
32
32
  }
33
33
  end
34
34
 
35
35
  context 'when with id:bigint' do
36
36
  subject { client }
37
37
 
38
- before { subject.diff(dsl2).migrate }
38
+ before { subject.diff(id_bigint_create_table).migrate }
39
39
 
40
40
  it {
41
41
  expect(show_create_table(:books)).to include '`id` bigint(20) NOT NULL AUTO_INCREMENT'
42
- expect(subject.dump).to match_fuzzy dsl2
42
+ expect(subject.dump).to match_fuzzy id_bigint_create_table
43
43
  }
44
44
  end
45
45
  end
@@ -0,0 +1,45 @@
1
+ describe 'Ridgepole::Client (with integer pk)', condition: '5.1.' do
2
+ context 'when with id:integer' do
3
+ let(:dsl) {
4
+ <<-RUBY
5
+ create_table "books", id: :integer, force: :cascade do |t|
6
+ t.string "title", null: false
7
+ t.integer "author_id", null: false
8
+ t.datetime "created_at"
9
+ t.datetime "updated_at"
10
+ end
11
+ RUBY
12
+ }
13
+
14
+ subject { client }
15
+
16
+ before { subject.diff(dsl).migrate }
17
+
18
+ specify {
19
+ expect(show_create_table(:books)).to include '`id` int(11) NOT NULL AUTO_INCREMENT'
20
+ expect(subject.dump).to match_fuzzy dsl
21
+ }
22
+ end
23
+
24
+ context 'when without id:integer' do
25
+ let(:dsl) {
26
+ <<-RUBY
27
+ create_table "books", force: :cascade do |t|
28
+ t.string "title", null: false
29
+ t.integer "author_id", null: false
30
+ t.datetime "created_at"
31
+ t.datetime "updated_at"
32
+ end
33
+ RUBY
34
+ }
35
+
36
+ subject { client }
37
+
38
+ before { subject.diff(dsl).migrate }
39
+
40
+ specify {
41
+ expect(show_create_table(:books)).to include '`id` bigint(20) NOT NULL AUTO_INCREMENT'
42
+ expect(subject.dump).to match_fuzzy dsl
43
+ }
44
+ end
45
+ end
@@ -11,7 +11,7 @@ describe Ridgepole::Config do
11
11
  YAML
12
12
  }
13
13
  let(:env) { 'development' }
14
- it {
14
+ specify {
15
15
  expect(subject['adapter']).to eq "mysql2"
16
16
  expect(subject['encoding']).to eq "utf8"
17
17
  expect(subject['database']).to eq "blog"
@@ -29,7 +29,7 @@ describe Ridgepole::Config do
29
29
  YAML
30
30
  }
31
31
  let(:env) { 'development' }
32
- it {
32
+ specify {
33
33
  expect(subject['adapter']).to eq "mysql2"
34
34
  expect(subject['encoding']).to eq "utf8"
35
35
  expect(subject['database']).to eq "blog_3"
@@ -41,7 +41,7 @@ describe Ridgepole::Config do
41
41
  let(:config) {
42
42
  <<-YAML.strip_heredoc
43
43
  development:
44
- adapter: sqlite
44
+ adapter: sqlspecifye
45
45
  database: db/sample.db
46
46
  production:
47
47
  adapter: mysql2
@@ -53,8 +53,8 @@ describe Ridgepole::Config do
53
53
 
54
54
  context 'in development env' do
55
55
  let(:env) { 'development' }
56
- it {
57
- expect(subject['adapter']).to eq "sqlite"
56
+ specify {
57
+ expect(subject['adapter']).to eq "sqlspecifye"
58
58
  expect(subject['database']).to eq "db/sample.db"
59
59
  expect(subject['username']).to be_nil
60
60
  }
@@ -62,7 +62,7 @@ describe Ridgepole::Config do
62
62
 
63
63
  context 'in production env' do
64
64
  let(:env) { 'production' }
65
- it {
65
+ specify {
66
66
  expect(subject['adapter']).to eq "mysql2"
67
67
  expect(subject['encoding']).to eq "utf8"
68
68
  expect(subject['database']).to eq "blog"
@@ -101,7 +101,7 @@ describe Ridgepole::Config do
101
101
 
102
102
  let(:env) { 'development' }
103
103
 
104
- it {
104
+ specify {
105
105
  expect {
106
106
  subject
107
107
  }.to raise_error 'Invalid config: "database.yml"'