/* $Id$ * * Copyright 2007-2008 Cisco Systems Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); you may not * use this file except in compliance with the License. You may obtain a copy * of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations * under the License. */ using System; using etch.examples.perf.types.Perf; using Etch.Support; using Etch.Util; namespace etch.examples.perf { ///Main implementation for PerfClient. public class MainPerfClient : PerfHelper.PerfClientFactory, PerfHelper.PerfServerFactory { ///Main for PerfClient ///Command Line Arguments public static void Main(String[] args) { const string uri = "tcp://localhost:4004"; bool startListener = false; const int maxWaitTime = 4000; Transport listener; if (startListener) { listener = PerfHelper.NewListener(uri, null, new MainPerfClient()); listener.TransportControl(TransportConsts.START_AND_WAIT_UP, maxWaitTime); } else { listener = null; } MainPerfClient implFactory = new MainPerfClient(); // run a preliminary test { RemotePerfServer server = PerfHelper.NewServer(uri, null, implFactory); // Connect to the service server._StartAndWaitUp(maxWaitTime); Assertion.Check(server.add(2, 3) == 5, "server.add(2, 3) == 5"); Assertion.Check(server.add(3, 4) == 7, "server.add( 3, 4 ) == 7"); Assertion.Check(server.sum(new int[] {1, 2, 3}) == 6, "server.sum( new int[] { 1, 2, 3 } ) == 6"); Assertion.Check(server.sum(new int[] {2, 3, 4}) == 9, "server.sum( new int[] { 2, 3, 4 } ) == 9"); server.report(18, "starting"); server.report(19, "stopping"); Point r = server.dist(new Point(1, 2), new Point(3, 5)); Assertion.Check(r.x == 2, "r.x == 2"); Assertion.Check(r.y == 3, "r.y == 3"); r = server.dist(new Point(10, 9), new Point(4, 5)); Assertion.Check(r.x == -6, "r.x == -6"); Assertion.Check(r.y == -4, "r.y == -4"); DateTime t0 = DateTime.Now; long adj = 3600000L; DateTime? t1 = server.add2(t0, adj); TimeSpan ts = t1.Value - t0; //Console.WriteLine("ts = {0}", ts.Ticks); Assertion.Check(IsNearly(ts.Ticks / 10000, adj, 1), String.Format("server.add2( {0}, {1} ) => {2} [bogus!]", t0, adj, t1)); t1 = server.add2(t0, -adj); ts = t1.Value - t0; //Console.WriteLine("ts = {0}", ts.Ticks); Assertion.Check(IsNearly(ts.Ticks / 10000, -adj, 1), String.Format("server.add2( {0}, {1} ) => {2} [bogus!]", t0, -adj, t1)); server.report2(DateTime.Now, 20, "begin"); server.report2(DateTime.Now, 21, "end"); // Disconnect from the service server._StopAndWaitDown(maxWaitTime); } const int runtime = 60; const int trials = 3; //const bool full = false; new PerfTest( "add", runtime, trials, delegate(long n) { RemotePerfServer server = PerfHelper.NewServer( uri, null, implFactory ); server._StartAndWaitUp( maxWaitTime ); while (n-- > 0) server.add( 1000000000, 2000000000 ); server._StopAndWaitDown( maxWaitTime ); }).Run(); if (listener != null) listener.TransportControl(TransportConsts.STOP_AND_WAIT_DOWN, maxWaitTime); Console.WriteLine("done"); } private static bool IsNearly(long a, long b, long diff) { return Math.Abs(a - b) <= diff; } ///Return a new instance of PerfClient. ///Reference to remote service ///Client Implementation public PerfClient NewPerfClient(RemotePerfServer server) { return new ImplPerfClient(server); } public PerfServer NewPerfServer(RemotePerfClient client) { return new ImplPerfServer(client); } } }