Sha256: 5338e72cb023b8b0d114f7647da4178b8cafef52e3a593871363365c6960dc80

Contents?: true

Size: 1.39 KB

Versions: 4

Compression:

Stored size: 1.39 KB

Contents

# Copyright (c) 2011 - 2013, SoundCloud Ltd., Rany Keddo, Tobias Bielohlawek, Tobias
# Schmidt

require File.expand_path(File.dirname(__FILE__)) + '/unit_helper'

require 'lhm/table'
require 'lhm/migration'
require 'lhm/locked_switcher'

describe Lhm::LockedSwitcher do
  include UnitHelper

  before(:each) do
    @start       = Time.now
    @origin      = Lhm::Table.new("origin")
    @destination = Lhm::Table.new("destination")
    @migration   = Lhm::Migration.new(@origin, @destination, @start)
    @switcher    = Lhm::LockedSwitcher.new(@migration, nil)
  end

  describe "uncommitted" do
    it "should disable autocommit first" do
      @switcher.
        statements[0..1].
        must_equal([
          "set @lhm_auto_commit = @@session.autocommit",
          "set session autocommit = 0"
        ])
    end

    it "should reapply original autocommit settings at the end" do
      @switcher.
        statements[-1].
        must_equal("set session autocommit = @lhm_auto_commit")
    end
  end

  describe "switch" do
    it "should lock origin and destination table, switch, commit and unlock" do
      @switcher.
        switch.
        must_equal([
          "lock table `origin` write, `destination` write",
          "alter table `origin` rename `#{ @migration.archive_name }`",
          "alter table `destination` rename `origin`",
          "commit",
          "unlock tables"
        ])
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
lhm-2.1.0 spec/unit/locked_switcher_spec.rb
lhm-2.0.0 spec/unit/locked_switcher_spec.rb
lhm-1.3.0 spec/unit/locked_switcher_spec.rb
lhm-1.2.0 spec/unit/locked_switcher_spec.rb