Sha256: a2b5dedefc356122bb875df5243c0df290c8fb68cb686fad35e6b92f84ecd8c1
Contents?: true
Size: 1.57 KB
Versions: 9
Compression:
Stored size: 1.57 KB
Contents
# frozen_string_literal: true describe 'Ridgepole::Client#diff -> migrate' do before { subject.diff(actual_dsl).migrate } subject { client(table_options: table_options, dump_without_table_options: dump_without_table_options) } let(:warning_regexp) { /Table option changes are ignored/ } let(:dump_without_table_options) { false } let(:actual_dsl) do erbh(<<-ERB) create_table "employees", primary_key: "emp_no", force: :cascade, options: 'ENGINE=InnoDB DEFAULT CHARSET=utf8' do |t| end ERB end let(:expected_dsl) do erbh(<<-ERB) create_table :employees, primary_key: :emp_no, force: :cascade do |t| end ERB end context 'when change options (no change)' do let(:table_options) { 'ENGINE=InnoDB DEFAULT CHARSET=utf8' } it { expect(Ridgepole::Logger.instance).to_not receive(:warn).with(warning_regexp) delta = subject.diff(expected_dsl) expect(delta.differ?).to be_falsey } end context 'when change options (change)' do let(:table_options) { 'ENGINE=InnoDB DEFAULT CHARSET=utf8mb4' } it { expect(Ridgepole::Logger.instance).to receive(:warn).with(warning_regexp) delta = subject.diff(expected_dsl) expect(delta.differ?).to be_falsey } end context 'when dump_without_table_options => true' do let(:table_options) { 'ENGINE=InnoDB DEFAULT CHARSET=utf8mb4' } let(:dump_without_table_options) { true } it { expect(Ridgepole::Logger.instance).to_not receive(:warn) delta = subject.diff(expected_dsl) expect(delta.differ?).to be_falsey } end end
Version data entries
9 entries across 9 versions & 1 rubygems