Sha256: 257bc150ef0a36afe6cdbc5895def431b9da3f653e59c98fc62a201d20d7c61a

Contents?: true

Size: 1.67 KB

Versions: 7

Compression:

Stored size: 1.67 KB

Contents

# frozen_string_literal: true

describe 'Ridgepole::Client#diff -> migrate (with index)', condition: '>= 5.1.0' do
  context 'when create table with auto increment column' do
    let(:actual_dsl) { '' }

    let(:expected_dsl) do
      erbh(<<-ERB)
        create_table "dept_emp", primary_key: ["emp_no", "dept_no"], force: :cascade do |t|
          t.integer "emp_no", null: false
          t.integer "dept_no", null: false, auto_increment: true
          t.date    "from_date", null: false
          t.date    "to_date", null: false
          t.index ["dept_no"], name: "dept_no", <%= i cond(5.0, using: :btree) %>
          t.index ["emp_no"], name: "emp_no", <%= i cond(5.0, using: :btree) %>
        end
      ERB
    end

    before { subject.diff(actual_dsl).migrate }
    subject { client(create_table_with_index: true, mysql_dump_auto_increment: true) }

    it {
      delta = subject.diff(expected_dsl)
      expect(delta.differ?).to be_truthy

      expect(delta.script).to match_fuzzy erbh(<<-ERB)
        create_table("dept_emp", **{:primary_key=>["emp_no", "dept_no"]}) do |t|
          t.column("emp_no", :"integer", **{:null=>false, :limit=>4})
          t.column("dept_no", :"integer", **{:null=>false, :auto_increment=>true, :limit=>4})
          t.column("from_date", :"date", **{:null=>false})
          t.column("to_date", :"date", **{:null=>false})
          t.index(["dept_no"], **<%= {:name=>"dept_no"} + cond(5.0, using: :btree) %>)
          t.index(["emp_no"], **<%= {:name=>"emp_no"} + cond(5.0, using: :btree) %>)
        end
      ERB

      expect(subject.dump).to match_ruby actual_dsl
      delta.migrate
      expect(subject.dump).to match_ruby expected_dsl
    }
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
ridgepole-0.8.13 spec/mysql/~dump_auto_increment/migrate_create_table_with_index_spec.rb
ridgepole-0.9.0.beta spec/mysql/~dump_auto_increment/migrate_create_table_with_index_spec.rb
ridgepole-0.8.12 spec/mysql/~dump_auto_increment/migrate_create_table_with_index_spec.rb
ridgepole-0.8.11 spec/mysql/~dump_auto_increment/migrate_create_table_with_index_spec.rb
ridgepole-0.8.10 spec/mysql/~dump_auto_increment/migrate_create_table_with_index_spec.rb
ridgepole-0.8.9 spec/mysql/~dump_auto_increment/migrate_create_table_with_index_spec.rb
ridgepole-0.8.8 spec/mysql/~dump_auto_increment/migrate_create_table_with_index_spec.rb