require "rubygems" require "benchmark" $LOAD_PATH[0,0] = File.join(File.dirname(__FILE__), '..', 'lib') require 'mongo' host = ENV['MONGO_RUBY_DRIVER_HOST'] || 'localhost' port = ENV['MONGO_RUBY_DRIVER_PORT'] || XGen::Mongo::Driver::Mongo::DEFAULT_PORT puts "Connecting to #{host}:#{port}" db = XGen::Mongo::Driver::Mongo.new(host, port).db('ruby-mongo-examples-complex') coll = db.collection('test') coll.clear OBJS_COUNT = 100 TEST_COUNT = 100 puts "Generating benchmark data" msgs = %w{hola hello aloha ciao} arr = OBJS_COUNT.times.map {|x| { :number => x, :rndm => (rand(5)+1), :msg => msgs[rand(4)] }} puts "Running benchmark" Benchmark.bmbm do |results| results.report("single object inserts: ") { TEST_COUNT.times { coll.clear arr.each {|x| coll.insert(x)} } } results.report("multiple object insert: ") { TEST_COUNT.times { coll.clear coll.insert(arr) } } end coll.clear