describe 'Ridgepole::Client#diff -> migrate' do context 'when change column (add comment)' do let(:actual_dsl) do erbh(<<-ERB) create_table "employee_clubs", force: :cascade do |t| t.integer "emp_no", null: false t.integer "club_id", null: false t.string "string", null: false t.text "text", <%= i cond(5.0, limit: 65535) %>, null: false end ERB end let(:expected_dsl) do erbh(<<-ERB) create_table "employee_clubs", force: :cascade do |t| t.integer "emp_no", null: false, comment: "any comment" t.integer "club_id", null: false, comment: "any comment2" t.string "string", null: false, comment: "any comment3" t.text "text", <%= i cond(5.0, limit: 65535) %>, null: false, comment: "any comment4" end ERB end before { subject.diff(actual_dsl).migrate } subject { client } it { delta = subject.diff(expected_dsl) expect(delta.differ?).to be_truthy expect(subject.dump).to match_ruby actual_dsl delta.migrate expect(subject.dump).to match_ruby expected_dsl } end context 'when change column (delete comment)' do let(:actual_dsl) do erbh(<<-ERB) create_table "employee_clubs", force: :cascade do |t| t.integer "emp_no", null: false, comment: "any comment" t.integer "club_id", null: false, comment: "any comment2" t.string "string", null: false, comment: "any comment3" t.text "text", <%= i cond(5.0, limit: 65535) %>, null: false, comment: "any comment4" end ERB end let(:expected_dsl) do erbh(<<-ERB) create_table "employee_clubs", force: :cascade do |t| t.integer "emp_no", null: false t.integer "club_id", null: false t.string "string", null: false t.text "text", <%= i cond(5.0, limit: 65535) %>, null: false end ERB end before { subject.diff(actual_dsl).migrate } subject { client } it { delta = subject.diff(expected_dsl) expect(delta.differ?).to be_truthy expect(subject.dump).to match_ruby actual_dsl delta.migrate expect(subject.dump).to match_ruby expected_dsl } end context 'when change column (change comment)' do let(:actual_dsl) do erbh(<<-ERB) create_table "employee_clubs", force: :cascade do |t| t.integer "emp_no", null: false, comment: "any comment" t.integer "club_id", null: false, comment: "any comment2" t.string "string", null: false, comment: "any comment3" t.text "text", <%= i cond(5.0, limit: 65535) %>, null: false, comment: "any comment4" end ERB end let(:expected_dsl) do erbh(<<-ERB) create_table "employee_clubs", force: :cascade do |t| t.integer "emp_no", null: false, comment: "other comment" t.integer "club_id", null: false, comment: "other comment2" t.string "string", null: false, comment: "other comment3" t.text "text", <%= i cond(5.0, limit: 65535) %>, null: false, comment: "other comment4" end ERB end before { subject.diff(actual_dsl).migrate } subject { client } it { delta = subject.diff(expected_dsl) expect(delta.differ?).to be_truthy expect(subject.dump).to match_ruby actual_dsl delta.migrate expect(subject.dump).to match_ruby expected_dsl } end context 'when change column (no change comment)' do let(:actual_dsl) do erbh(<<-ERB) create_table "employee_clubs", force: :cascade do |t| t.integer "emp_no", null: false, comment: "any comment" t.integer "club_id", null: false, comment: "any comment2" t.string "string", null: false, comment: "any comment3" t.text "text", <%= i cond(5.0, limit: 65535) %>, null: false, comment: "any comment4" end ERB end before { subject.diff(actual_dsl).migrate } subject { client } it { delta = subject.diff(actual_dsl) expect(delta.differ?).to be_falsey expect(subject.dump).to match_ruby actual_dsl delta.migrate expect(subject.dump).to match_ruby actual_dsl } end context 'when create table (with comment)' do let(:expected_dsl) do erbh(<<-ERB) create_table "employee_clubs", force: :cascade, comment: "table comment" do |t| t.integer "emp_no", null: false, comment: "other comment" t.integer "club_id", null: false, comment: "other comment2" t.string "string", null: false, comment: "other comment3" t.text "text", <%= i cond(5.0, limit: 65535) %>, null: false, comment: "other comment4" end ERB end subject { client } it { delta = subject.diff(expected_dsl) expect(delta.differ?).to be_truthy expect(subject.dump.strip).to be_empty delta.migrate expect(subject.dump).to match_ruby expected_dsl } end context 'when drop table (with comment)' do let(:actual_dsl) do erbh(<<-ERB) create_table "employee_clubs", force: :cascade, comment: "table comment" do |t| t.integer "emp_no", null: false, comment: "other comment" t.integer "club_id", null: false, comment: "other comment2" t.string "string", null: false, comment: "other comment3" t.text "text", <%= i cond(5.0, limit: 65535) %>, null: false, comment: "other comment4" end ERB end before { subject.diff(actual_dsl).migrate } subject { client } it { delta = subject.diff('') expect(delta.differ?).to be_truthy expect(subject.dump).to match_ruby actual_dsl delta.migrate expect(subject.dump).to be_empty } end end