require "spec/helper/all" DELAY = 0.25 QUERY = "select sleep(#{DELAY})" describe EventMachine::Synchrony::ConnectionPool do it "should queue requests if pool size is exceeded" do EventMachine.run do db = EventMachine::Synchrony::ConnectionPool.new(size: 1) do EventMachine::MySQL.new(host: "localhost") end Fiber.new { start = now multi = EventMachine::Synchrony::Multi.new multi.add :a, db.aquery(QUERY) multi.add :b, db.aquery(QUERY) res = multi.perform (now - start.to_f).should be_within(DELAY * 2 * 0.15).of(DELAY * 2) res.responses[:callback].size.should == 2 res.responses[:errback].size.should == 0 EventMachine.stop }.resume end end it "should execute multiple async pool requests within same fiber" do EventMachine.run do db = EventMachine::Synchrony::ConnectionPool.new(size: 2) do EventMachine::MySQL.new(host: "localhost") end Fiber.new { start = now multi = EventMachine::Synchrony::Multi.new multi.add :a, db.aquery(QUERY) multi.add :b, db.aquery(QUERY) res = multi.perform (now - start.to_f).should be_within(DELAY * 0.15).of(DELAY) res.responses[:callback].size.should == 2 res.responses[:errback].size.should == 0 EventMachine.stop }.resume end end it "should share connection pool between different fibers" do EventMachine.run do db = EventMachine::Synchrony::ConnectionPool.new(size: 2) do EventMachine::MySQL.new(host: "localhost") end Fiber.new { start = now results = [] fiber = Fiber.current 2.times do |n| Fiber.new { results.push db.query(QUERY) fiber.transfer if results.size == 2 }.resume end # wait for workers Fiber.yield (now - start.to_f).should be_within(DELAY * 0.15).of(DELAY) results.size.should == 2 EventMachine.stop }.resume end end it "should share connection pool between different fibers & async requests" do EventMachine.run do db = EventMachine::Synchrony::ConnectionPool.new(size: 5) do EventMachine::MySQL.new(host: "localhost") end Fiber.new { start = now results = [] fiber = Fiber.current 2.times do |n| Fiber.new { multi = EventMachine::Synchrony::Multi.new multi.add :a, db.aquery(QUERY) multi.add :b, db.aquery(QUERY) results.push multi.perform fiber.transfer if results.size == 3 }.resume end Fiber.new { # execute a synchronous requests results.push db.query(QUERY) fiber.transfer if results.size == 3 }.resume # wait for workers Fiber.yield (now - start.to_f).should be_within(DELAY * 0.15).of(DELAY) results.size.should == 3 EventMachine.stop }.resume end end end