/* * Copyright (c) 2011, Peter Thorson. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * Neither the name of the WebSocket++ Project nor the * names of its contributors may be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * */ #include "stress_handler.hpp" using wsperf::stress_handler; // Construct a message_test from a wscmd command /* Reads values from the wscmd object into member variables. The cmd object is * passed to the parent constructor for extracting values common to all test * cases. * * Any of the constructors may throw a `case_exception` if required parameters * are not found or default values don't make sense. * * Values that message_test checks for: * * uri=[string]; * Example: uri=ws://localhost:9000; * URI of the server to connect to * * token=[string]; * Example: token=foo; * String value that will be returned in the `token` field of all test related * messages. A separate token should be sent for each unique test. * * quantile_count=[integer]; * Example: quantile_count=10; * How many histogram quantiles to return in the test results * * rtts=[bool]; * Example: rtts:true; * Whether or not to return the full list of round trip times for each message * primarily useful for debugging. */ stress_handler::stress_handler(wscmd::cmd& cmd) : m_current_connections(0) , m_max_connections(0) , m_total_connections(0) , m_failed_connections(0) { } void stress_handler::on_open(connection_ptr con) { { boost::lock_guard lock(m_lock); m_current_connections++; m_total_connections++; if (m_current_connections > m_max_connections) { m_max_connections = m_current_connections; } } start(con); } void stress_handler::on_close(connection_ptr con) { boost::lock_guard lock(m_lock); m_current_connections--; // TODO: log close reason? } void stress_handler::on_fail(connection_ptr con) { boost::lock_guard lock(m_lock); m_failed_connections++; // TODO: log failure reason } void stress_handler::start(connection_ptr con) {} std::string stress_handler::get_data() const { std::stringstream data; data << "{"; { boost::lock_guard lock(m_lock); data << "\"current_connections\":" << m_current_connections; data << ",\"max_connections\":" << m_max_connections; data << ",\"total_connections\":" << m_total_connections; data << ",\"failed_connections\":" << m_failed_connections; } data << "}"; return data.str(); }