Sha256: 6fd9cf949229e88265f17c9d6fa0516d925596c4c54e12be482fbcacec5f0bfe

Contents?: true

Size: 1.49 KB

Versions: 22

Compression:

Stored size: 1.49 KB

Contents

require File.join(File.dirname(File.expand_path(__FILE__)), "spec_helper")

describe "server_logging extension" do
  before do
    @o = Object.new
    def @o.logs; @logs || []; end
    def @o.log; logs.length.must_equal 1; logs.first.length.must_equal 1; logs.shift.first; end
    def @o.to_ary; [self]; end
    def @o.method_missing(m, *args); (@logs ||= []) << args; end
    @db = Sequel::mock(:servers=>{:read_only=>{}, :b=>{}}, :logger=>@o).extension(:server_logging)
  end

  it "should include shard when logging" do
    @db[:a].all
    @o.log.must_include "server: read_only) SELECT * FROM a"
    @db[:a].insert
    @o.log.must_include "server: default) INSERT INTO a DEFAULT VALUES"
    @db[:a].server(:b).all
    @o.log.must_include "server: b) SELECT * FROM a"
  end

  it "should not include shard when not logging connection info" do
    @db.log_connection_info = false
    @db[:a].all
    log = @o.log
    log.wont_include "server: read_only) SELECT * FROM a"
    log.must_include "SELECT * FROM a"
  end

  it "should not turn on logging connction info if it was turned off" do
    @db.log_connection_info = false
    @db.extension :server_logging
    @db[:a].all
    log = @o.log
    log.wont_include "server: read_only) SELECT * FROM a"
    log.must_include "SELECT * FROM a"
  end

  it "should remove mapping when disconnecting" do
    c = @db.synchronize{|c1| c1}
    @db.disconnect
    @db.send(:log_connection_execute, c, "SELECT * FROM a")
    @o.log.must_include "server: ) SELECT * FROM a"
  end
end

Version data entries

22 entries across 20 versions & 2 rubygems

Version Path
sequel-4.49.0 spec/extensions/server_logging_spec.rb
sequel-4.48.0 spec/extensions/server_logging_spec.rb
tdiary-5.0.5 vendor/bundle/gems/tdiary-5.0.4/vendor/bundle/gems/sequel-4.44.0/spec/extensions/server_logging_spec.rb
tdiary-5.0.5 vendor/bundle/gems/sequel-4.47.0/spec/extensions/server_logging_spec.rb
tdiary-5.0.5 vendor/bundle/gems/sequel-4.44.0/spec/extensions/server_logging_spec.rb
sequel-4.47.0 spec/extensions/server_logging_spec.rb
sequel-4.46.0 spec/extensions/server_logging_spec.rb
sequel-4.45.0 spec/extensions/server_logging_spec.rb
tdiary-5.0.4 vendor/bundle/gems/sequel-4.44.0/spec/extensions/server_logging_spec.rb
sequel-4.44.0 spec/extensions/server_logging_spec.rb
sequel-4.43.0 spec/extensions/server_logging_spec.rb
sequel-4.42.1 spec/extensions/server_logging_spec.rb
sequel-4.42.0 spec/extensions/server_logging_spec.rb
sequel-4.41.0 spec/extensions/server_logging_spec.rb
sequel-4.40.0 spec/extensions/server_logging_spec.rb
sequel-4.39.0 spec/extensions/server_logging_spec.rb
tdiary-5.0.2 vendor/bundle/gems/sequel-4.37.0/spec/extensions/server_logging_spec.rb
sequel-4.38.0 spec/extensions/server_logging_spec.rb
sequel-4.37.0 spec/extensions/server_logging_spec.rb
sequel-4.36.0 spec/extensions/server_logging_spec.rb