Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
upsert / spec / logger_spec.rb
Size: Mime:
require 'spec_helper'
describe Upsert do
  MUTEX_FOR_PERFORM = Mutex.new
  describe "logger" do
    it "logs where you tell it" do
      begin
        old_logger = Upsert.logger
        io = StringIO.new
        MUTEX_FOR_PERFORM.synchronize do
          Upsert.logger = Logger.new(io)

          Upsert.logger.warn "hello"

          io.rewind
          io.read.chomp.should == 'hello'
        end
      ensure
        Upsert.logger = old_logger
      end
    end

    it "logs queries" do
      old_logger = Upsert.logger
      begin
        io = StringIO.new
        MUTEX_FOR_PERFORM.synchronize do
          Upsert.logger = Logger.new(io)

          u = Upsert.new($conn, :pets)
          u.row(:name => 'Jerry')

          io.rewind
          log = io.read.chomp
          case u.connection.class.name
          when /sqlite/i
            log.should =~ /insert or ignore/i
          when /mysql/i
            log.should =~ /call #{Upsert::MergeFunction::NAME_PREFIX}_pets_SEL_name/i
          when /p.*g/i
            # [54ae2eea857] Possibly much more useful debug output
            # TODO: Should check for both upsert and non-upsert log output
            log.should =~ /selector:|SHOW server_version/i
          else
            raise "not sure"
          end
        end
      ensure
        Upsert.logger = old_logger
      end
    end
  end
end