1
0
Fork 0
mirror of https://github.com/fog/fog.git synced 2022-11-09 13:51:43 -05:00
fog--fog/benchs/fog_vs.rb

107 lines
2.6 KiB
Ruby
Raw Normal View History

require 'rubygems'
2009-09-01 02:16:53 -04:00
require 'aws/s3'
2009-07-10 02:22:02 -04:00
require 'benchmark'
require 'right_aws'
2009-09-01 02:16:53 -04:00
require File.join(File.dirname(__FILE__), '..', 'lib', 'fog')
data = File.open(File.expand_path('~/.fog')).read
config = YAML.load(data)[:default]
fog = Fog::AWS::S3.new(
:aws_access_key_id => config[:aws_access_key_id],
:aws_secret_access_key => config[:aws_secret_access_key]
)
raws = RightAws::S3Interface.new(
config[:aws_access_key_id],
config[:aws_secret_access_key]
)
raws.logger.level = 3 # ERROR
2009-09-01 02:16:53 -04:00
awss3 = AWS::S3::Base.establish_connection!(
:access_key_id => config[:aws_access_key_id],
:secret_access_key => config[:aws_secret_access_key],
2009-09-01 02:16:53 -04:00
:persistent => true
)
2009-07-10 17:58:29 -04:00
TIMES = 10
2009-06-09 15:09:40 -04:00
2009-06-23 03:16:08 -04:00
Benchmark.bmbm(25) do |bench|
bench.report('fog.put_bucket') do
2009-07-10 17:58:29 -04:00
TIMES.times do |x|
fog.put_bucket("fogbench#{x}")
end
end
bench.report('raws.create_bucket') do
2009-07-10 17:58:29 -04:00
TIMES.times do |x|
raws.create_bucket("rawsbench#{x}")
end
end
2009-09-01 02:16:53 -04:00
bench.report('awss3::Bucket.create') do
TIMES.times do |x|
AWS::S3::Bucket.create("awss3bench#{x}")
end
end
bench.report('fog.put_object') do
2009-06-09 15:09:40 -04:00
TIMES.times do |x|
2009-07-10 17:58:29 -04:00
TIMES.times do |y|
file = File.open(File.dirname(__FILE__) + '/../spec/lorem.txt', 'r')
fog.put_object("fogbench#{x}", "lorem_#{y}", file)
end
2009-06-09 15:09:40 -04:00
end
end
bench.report('raws.put') do
2009-06-09 15:09:40 -04:00
TIMES.times do |x|
2009-07-10 17:58:29 -04:00
TIMES.times do |y|
file = File.open(File.dirname(__FILE__) + '/../spec/lorem.txt', 'r')
raws.put("rawsbench#{x}", "lorem_#{y}", file)
end
2009-06-09 15:09:40 -04:00
end
end
2009-09-01 02:16:53 -04:00
bench.report('awss3::S3Object.create') do
TIMES.times do |x|
TIMES.times do |y|
file = File.open(File.dirname(__FILE__) + '/../spec/lorem.txt', 'r')
AWS::S3::S3Object.create("lorem_#{y}", file, "awss3bench#{x}")
end
end
end
bench.report('fog.delete_object') do
2009-06-09 15:09:40 -04:00
TIMES.times do |x|
2009-07-10 17:58:29 -04:00
TIMES.times do |y|
fog.delete_object("fogbench#{x}", "lorem_#{y}")
end
2009-06-09 15:09:40 -04:00
end
end
bench.report('raws.delete') do
2009-06-09 15:09:40 -04:00
TIMES.times do |x|
2009-07-10 17:58:29 -04:00
TIMES.times do |y|
raws.delete("rawsbench#{x}", "lorem_#{y}")
end
2009-06-09 15:09:40 -04:00
end
end
2009-09-01 02:16:53 -04:00
bench.report('awss3::S3Object.delete') do
TIMES.times do |x|
TIMES.times do |y|
AWS::S3::S3Object.delete("lorem_#{y}", "awss3bench#{x}")
end
end
end
bench.report('fog.delete_bucket') do
2009-07-10 17:58:29 -04:00
TIMES.times do |x|
fog.delete_bucket("fogbench#{x}")
end
end
bench.report('raws.delete_bucket') do
2009-07-10 17:58:29 -04:00
TIMES.times do |x|
raws.delete_bucket("rawsbench#{x}")
end
end
2009-09-01 02:16:53 -04:00
bench.report('awss3::Bucket.delete') do
TIMES.times do |x|
AWS::S3::Bucket.delete("awss3bench#{x}")
end
end
end