/**
* Copyright 2005-2011 Noelios Technologies.
*
* The contents of this file are subject to the terms of one of the following
* open source licenses: LGPL 3.0 or LGPL 2.1 or CDDL 1.0 or EPL 1.0 (the
* "Licenses"). You can select the license that you prefer but you may not use
* this file except in compliance with one of these Licenses.
*
* You can obtain a copy of the LGPL 3.0 license at
* http://www.opensource.org/licenses/lgpl-3.0.html
*
* You can obtain a copy of the LGPL 2.1 license at
* http://www.opensource.org/licenses/lgpl-2.1.php
*
* You can obtain a copy of the CDDL 1.0 license at
* http://www.opensource.org/licenses/cddl1.php
*
* You can obtain a copy of the EPL 1.0 license at
* http://www.opensource.org/licenses/eclipse-1.0.php
*
* See the Licenses for the specific language governing permissions and
* limitations under the Licenses.
*
* Alternatively, you can obtain a royalty free commercial license with less
* limitations, transferable or non-transferable, directly at
* http://www.noelios.com/products/restlet-engine
*
* Restlet is a registered trademark of Noelios Technologies.
*/
package org.restlet.test.bench;
import java.util.logging.Level;
import org.restlet.Client;
import org.restlet.Context;
import org.restlet.data.Protocol;
import org.restlet.engine.ConnectorHelper;
import org.restlet.engine.Engine;
import org.restlet.representation.Representation;
import org.restlet.resource.ClientResource;
public class NioClient {
public static void main(String[] args) throws Exception {
// TraceHandler.register();
ConnectorHelper<Client> helper;
helper = new org.restlet.engine.connector.HttpClientHelper(null);
// helper = new org.restlet.ext.httpclient.HttpClientHelper(null);
// helper = new org.restlet.ext.net.HttpClientHelper(null);
Engine.getInstance().getRegisteredClients().add(0, helper);
Engine.setLogLevel(Level.FINE);
Client client = new Client(new Context(), Protocol.HTTP);
// client.getContext().getParameters().add("persistingConnections",
// "false");
client.getContext().getParameters().add("tracing", "false");
client.getContext().getParameters().add("minThreads", "1");
client.getContext().getParameters().add("lowThreads", "30");
client.getContext().getParameters().add("maxThreads", "40");
client.getContext().getParameters().add("maxQueued", "20");
client.getContext().getParameters().add("directBuffers", "false");
client.start();
// String uri =
// "http://www.restlet.org/downloads/2.1/restlet-jse-2.1snapshot.zip";
String uri = "http://127.0.0.1:9999/";
int iterations = 1000;
ClientResource cr = new ClientResource(uri);
cr.setRetryOnError(false);
cr.setNext(client);
Representation r = null;
// ClientResource fr = new ClientResource(
// "file://C/TEST/restlet-jse-2.0.5.zip");
System.out.println("Calling resource: " + uri + " " + iterations
+ " times");
long start = System.currentTimeMillis();
for (int i = 0; i < iterations; i++) {
// r = cr.post("Sample content posted");
r = cr.get();
// r.exhaust();
System.out.println(r.getText());
// System.out.println("Copying to the local file");
// fr.put(r);
// System.out.println("Copy done!");
}
long total = (System.currentTimeMillis() - start);
long avg = total / iterations;
System.out.println("Bench completed in " + total
+ " ms. Average time per call: " + avg + " ms");
}
}