From 9de65a10d43f38ac7a583574e6b54d429e6b4fa5 Mon Sep 17 00:00:00 2001 From: Peter Thorson Date: Wed, 11 Jan 2012 12:20:51 -0600 Subject: [PATCH] very simple speed testing harness --- test/basic/Makefile | 3 +++ test/basic/uri_perf.cpp | 51 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 54 insertions(+) create mode 100644 test/basic/uri_perf.cpp diff --git a/test/basic/Makefile b/test/basic/Makefile index 42e410ab1d..84353c118b 100644 --- a/test/basic/Makefile +++ b/test/basic/Makefile @@ -16,6 +16,9 @@ endif tests: parsing.cpp $(CXX) $(CFLAGS) $^ -o $@ $(LDFLAGS) +perf: uri_perf.cpp + $(CXX) $(CFLAGS) $^ -o $@ $(LDFLAGS) + %.o: %.cpp $(CXX) -c $(CFLAGS) -o $@ $^ diff --git a/test/basic/uri_perf.cpp b/test/basic/uri_perf.cpp new file mode 100644 index 0000000000..f87ecbfdb0 --- /dev/null +++ b/test/basic/uri_perf.cpp @@ -0,0 +1,51 @@ +/* + * 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 +#include + +#include + +#include "../../src/uri.hpp" + +int main() { + boost::posix_time::ptime start = boost::posix_time::microsec_clock::local_time(); + + long m = 100000; + long n = 3; + + for (long i = 0; i < m; i++) { + websocketpp::uri uri1("wss://thor-websocket.zaphoyd.net:9002/foo/bar/baz?a=b&c=d"); + websocketpp::uri uri2("ws://[::1]"); + websocketpp::uri uri3("ws://localhost:9000/chat"); + } + boost::posix_time::ptime end = boost::posix_time::microsec_clock::local_time(); + boost::posix_time::time_period period(start,end); + int ms = period.length().total_milliseconds(); + + std::cout << "Created " << m*n << " URIs in " << ms << "ms" << " (" << (m*n)/(ms/1000.0) << "/s)" << std::endl; +} +