mongo-ruby-driver/test/admin_test.rb

68 lines
1.8 KiB
Ruby
Raw Normal View History

require 'test/test_helper'
2009-01-07 20:36:12 +00:00
# NOTE: assumes Mongo is running
class AdminTest < Test::Unit::TestCase
include Mongo
2009-01-07 20:36:12 +00:00
@@db = Connection.new(ENV['MONGO_RUBY_DRIVER_HOST'] || 'localhost',
ENV['MONGO_RUBY_DRIVER_PORT'] || Connection::DEFAULT_PORT).db('ruby-mongo-test')
@@coll = @@db.collection('test')
2009-01-07 20:36:12 +00:00
def setup
# Insert some data to make sure the database itself exists.
@@coll.remove
@r1 = @@coll.insert('a' => 1) # collection not created until it's used
@@coll_full_name = 'ruby-mongo-test.test'
@admin = @@db.admin
2009-01-07 20:36:12 +00:00
end
def teardown
@admin.profiling_level = :off
@@coll.remove if @@coll
@@db.error
2009-01-07 20:36:12 +00:00
end
def test_default_profiling_level
assert_equal :off, @admin.profiling_level
end
def test_change_profiling_level
@admin.profiling_level = :slow_only
assert_equal :slow_only, @admin.profiling_level
@admin.profiling_level = :off
assert_equal :off, @admin.profiling_level
2009-03-02 15:49:27 +00:00
@admin.profiling_level = :all
assert_equal :all, @admin.profiling_level
begin
@admin.profiling_level = :medium
fail "shouldn't be able to do this"
rescue
end
2009-01-07 20:36:12 +00:00
end
2009-01-07 20:58:54 +00:00
def test_profiling_info
# Perform at least one query while profiling so we have something to see.
@admin.profiling_level = :all
@@coll.find()
@admin.profiling_level = :off
2009-01-07 20:58:54 +00:00
info = @admin.profiling_info
assert_kind_of Array, info
assert info.length >= 1
first = info.first
assert_kind_of String, first['info']
assert_kind_of Time, first['ts']
assert_kind_of Numeric, first['millis']
end
2009-01-07 21:12:01 +00:00
def test_validate_collection
doc = @admin.validate_collection(@@coll.name)
assert_not_nil doc
result = doc['result']
assert_not_nil result
assert_match /firstExtent/, result
2009-01-07 21:12:01 +00:00
end
2009-01-07 20:36:12 +00:00
end