summaryrefslogtreecommitdiff
path: root/cpp/demo/Ice/latency/Client.cpp
diff options
context:
space:
mode:
authorMarc Laukien <marc@zeroc.com>2001-08-15 17:21:39 +0000
committerMarc Laukien <marc@zeroc.com>2001-08-15 17:21:39 +0000
commit7aff96f568e834c4c13f26a46843d5ecbb1d325d (patch)
treee801f83704b85d59f80f1516576c3f91290f6d31 /cpp/demo/Ice/latency/Client.cpp
parentfix (diff)
downloadice-7aff96f568e834c4c13f26a46843d5ecbb1d325d.tar.bz2
ice-7aff96f568e834c4c13f26a46843d5ecbb1d325d.tar.xz
ice-7aff96f568e834c4c13f26a46843d5ecbb1d325d.zip
IcePack ; restructuring
Diffstat (limited to 'cpp/demo/Ice/latency/Client.cpp')
-rw-r--r--cpp/demo/Ice/latency/Client.cpp115
1 files changed, 115 insertions, 0 deletions
diff --git a/cpp/demo/Ice/latency/Client.cpp b/cpp/demo/Ice/latency/Client.cpp
new file mode 100644
index 00000000000..9445e11f48a
--- /dev/null
+++ b/cpp/demo/Ice/latency/Client.cpp
@@ -0,0 +1,115 @@
+// **********************************************************************
+//
+// Copyright (c) 2001
+// MutableRealms, Inc.
+// Huntsville, AL, USA
+//
+// All Rights Reserved
+//
+// **********************************************************************
+
+#include <Ice/Ice.h>
+#include <Latency.h>
+#ifdef WIN32
+# include <sys/timeb.h>
+#else
+# include <sys/time.h>
+#endif
+
+using namespace std;
+
+int
+run(int argc, char* argv[], Ice::CommunicatorPtr communicator)
+{
+ Ice::PropertiesPtr properties = communicator->getProperties();
+ std::string ref = properties->getProperty("Latency.Ping");
+ Ice::ObjectPrx base = communicator->stringToProxy(ref);
+
+ PingPrx ping = PingPrx::checkedCast(base);
+ if (!ping)
+ {
+ cerr << argv[0] << ": invalid object reference" << endl;
+ return EXIT_FAILURE;
+ }
+
+ timeval tv1;
+#ifdef WIN32
+ struct _timeb tb1;
+ _ftime(&tb1);
+ tv1.tv_sec = tb1.time;
+ tv1.tv_usec = tb1.millitm * 1000;
+#else
+ gettimeofday(&tv1, 0);
+#endif
+
+ const int repetitions = 100000;
+ cout << "pinging server " << repetitions << " times (this may take a while)" << endl;
+ for (int i = 0; i < repetitions; ++i)
+ ping->ping();
+
+ timeval tv2;
+#ifdef WIN32
+ struct _timeb tb2;
+ _ftime(&tb2);
+ tv2.tv_sec = tb2.time;
+ tv2.tv_usec = tb2.millitm * 1000;
+#else
+ gettimeofday(&tv2, 0);
+#endif
+
+ timeval tv;
+
+ tv.tv_sec = tv2.tv_sec - tv1.tv_sec;
+ tv.tv_usec = tv2.tv_usec - tv1.tv_usec;
+
+ tv.tv_sec += tv.tv_usec / 1000000;
+ tv.tv_usec = tv.tv_usec % 1000000;
+
+ if (tv.tv_usec < 0)
+ {
+ tv.tv_usec += 1000000;
+ tv.tv_sec -= 1;
+ }
+
+ double total = (tv.tv_sec * 1000000.0 + tv.tv_usec) / 1000.0;
+ double perPing = total / repetitions;
+
+ cout << "time for " << repetitions << " pings: " << total << "ms" << endl;
+ cout << "time per ping: " << perPing << "ms" << endl;
+
+ return EXIT_SUCCESS;
+}
+
+int
+main(int argc, char* argv[])
+{
+ int status;
+ Ice::CommunicatorPtr communicator;
+
+ try
+ {
+ Ice::PropertiesPtr properties = Ice::loadProperties("config");
+ communicator = Ice::initializeWithProperties(argc, argv, properties);
+ status = run(argc, argv, communicator);
+ }
+ catch(const Ice::LocalException& ex)
+ {
+ cerr << ex << endl;
+ status = EXIT_FAILURE;
+ }
+
+ if (communicator)
+ {
+ try
+ {
+ communicator->destroy();
+ }
+ catch(const Ice::LocalException& ex)
+ {
+ cerr << ex << endl;
+ status = EXIT_FAILURE;
+ }
+ }
+
+ return status;
+}