raise SkipTest unless $node["services"].include?("couchdb") require 'json' class TestCouchdb < LeapTest def setup end # # check to make sure we can get welcome response from local couchdb # def test_01_is_running assert_get(couchdb_url) do |body| assert_match /"couchdb":"Welcome"/, body, "Could not get welcome message from #{couchdb_url}. Probably couchdb is not running." end pass end # # compare the configured nodes to the nodes that are actually listed in bigcouch # def test_02_nodes_are_in_replication_database url = couchdb_backend_url("/nodes/_all_docs") neighbors = assert_property('couch.bigcouch.neighbors') neighbors << assert_property('domain.full') neighbors.sort! assert_get(url) do |body| response = JSON.parse(body) nodes_in_db = response['rows'].collect{|row| row['id'].sub(/^bigcouch@/, '')}.sort assert_equal neighbors, nodes_in_db, "The couchdb replication node list is wrong (/nodes/_all_docs)" end pass end # # all configured nodes are in 'cluster_nodes' # all nodes online and communicating are in 'all_nodes' # # this seems backward to me, so it might be the other way around. # def test_03_replica_membership url = couchdb_url("/_membership") assert_get(url) do |body| response = JSON.parse(body) nodes_configured_but_not_available = response['cluster_nodes'] - response['all_nodes'] nodes_available_but_not_configured = response['all_nodes'] - response['cluster_nodes'] if nodes_configured_but_not_available.any? warn "These nodes are configured but not available:", nodes_configured_but_not_available end if nodes_available_but_not_configured.any? warn "These nodes are available but not configured:", nodes_available_but_not_configured end if response['cluster_nodes'] == response['all_nodes'] pass end end end def test_04_acl_users_exist acl_users = ['_design/_auth', 'leap_mx', 'nickserver', 'soledad', 'tapicero', 'webapp'] url = couchdb_backend_url("/_users/_all_docs") assert_get(url) do |body| response = JSON.parse(body) assert_equal 6, response['total_rows'] actual_users = response['rows'].map{|row| row['id'].sub(/^org.couchdb.user:/, '') } assert_equal acl_users, actual_users end pass end def test_05_databases_exist dbs_that_should_exist = ["customers","identities","keycache","sessions","shared","tickets","tokens","users"] dbs_that_should_exist.each do |db_name| assert_get(couchdb_url("/"+db_name)) do |body| assert response = JSON.parse(body) assert_equal db_name, response['db_name'] end end pass end private def couchdb_url(path="", port=nil) @port ||= begin assert_property 'couch.port' $node['couch']['port'] end @password ||= begin assert_property 'couch.users.admin.password' $node['couch']['users']['admin']['password'] end "http://admin:#{@password}@localhost:#{port || @port}#{path}" end def couchdb_backend_url(path="") couchdb_url(path, "5986") # TODO: admin port is hardcoded for now but should be configurable. end end