diff options
author | Adam Kocoloski <kocolosk@apache.org> | 2009-06-30 17:02:24 +0000 |
---|---|---|
committer | Adam Kocoloski <kocolosk@apache.org> | 2009-06-30 17:02:24 +0000 |
commit | 111da624f716217fc9180a75f388a025f3c27d1f (patch) | |
tree | 23c20fb1fed5d3cb9dfea998bd3e559b5b4ebeb0 | |
parent | 57326fb4942281109d21fef403f51867c8f984f7 (diff) |
reset stats on POST /_restart and correct open_databases test. Closes COUCHDB-398
I rearranged the shutdown order from what was committed in the 0.9.x branch so
that the stats collector is still up when couch_server shuts down. This way the
messages to decrement the number of open_databases during the shutdown don't
fail with a badarg. The badarg is silently ignored in 0.9.x, but here we pattern
match with a true so we end up with lots of error reports.
You may see some spurious erlang error reports when running the test suite on
an SMP emulator, due to the use of public ets tables in the stats collector API.
git-svn-id: https://svn.apache.org/repos/asf/couchdb/trunk@789829 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r-- | share/www/script/test/stats.js | 2 | ||||
-rw-r--r-- | src/couchdb/couch_server_sup.erl | 6 |
2 files changed, 5 insertions, 3 deletions
diff --git a/share/www/script/test/stats.js b/share/www/script/test/stats.js index dc3edb1f..8a21dd88 100644 --- a/share/www/script/test/stats.js +++ b/share/www/script/test/stats.js @@ -64,7 +64,7 @@ couchTests.stats = function(debug) { db.createDb(); } - var open_databases = requestStatsTest("couchdb", "open_databases").max; + var open_databases = requestStatsTest("couchdb", "open_databases").current; T(open_databases > 0 && max >= open_databases, name); for(var i=0; i<max+1; i++) { diff --git a/src/couchdb/couch_server_sup.erl b/src/couchdb/couch_server_sup.erl index e59286f3..4c77dbe1 100644 --- a/src/couchdb/couch_server_sup.erl +++ b/src/couchdb/couch_server_sup.erl @@ -32,10 +32,12 @@ start_link(IniFiles) -> end. restart_core_server() -> - supervisor:terminate_child(couch_secondary_services, couch_server), supervisor:terminate_child(couch_primary_services, couch_server), + supervisor:terminate_child(couch_secondary_services, stats_aggregator), + supervisor:terminate_child(couch_secondary_services, stats_collector), supervisor:restart_child(couch_primary_services, couch_server), - supervisor:restart_child(couch_secondary_services, couch_server). + supervisor:restart_child(couch_secondary_services, stats_collector), + supervisor:restart_child(couch_secondary_services, stats_aggregator). couch_config_start_link_wrapper(IniFiles, FirstConfigPid) -> case is_process_alive(FirstConfigPid) of |