Package org.apache.avro

Source Code of org.apache.avro.TestBulkData$BulkDataImpl

/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements.  See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership.  The ASF licenses this file
* to you 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.
*/
package org.apache.avro;

import org.apache.avro.specific.SpecificRequestor;
import org.apache.avro.specific.SpecificResponder;
import org.apache.avro.ipc.HttpServer;
import org.apache.avro.ipc.HttpTransceiver;
import org.apache.avro.ipc.Server;
import org.apache.avro.ipc.Transceiver;

import org.junit.AfterClass;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;

import java.io.IOException;
import java.net.URL;
import java.nio.ByteBuffer;
import java.util.Random;

import org.apache.avro.test.BulkData;

public class TestBulkData {
  private static final long COUNT =
    Integer.parseInt(System.getProperty("test.count", "10"));
  private static final int SIZE =
    Integer.parseInt(System.getProperty("test.size", "65536"));

  private static final ByteBuffer DATA = ByteBuffer.allocate(SIZE);
  {
    Random rand = new Random();
    DATA.limit(DATA.capacity());
    DATA.position(0);
    rand.nextBytes(DATA.array());
  }

  public static class BulkDataImpl implements BulkData {
    public ByteBuffer read() { return DATA.duplicate(); }
    public Void write(ByteBuffer data) {
      Assert.assertEquals(SIZE, data.remaining());
      return null;
    }
  }

  private static Server server;
  private static Transceiver client;
  private static BulkData proxy;

  @Before
  public void startServer() throws Exception {
    if (server != null) return;
    server =
      new HttpServer(new SpecificResponder(BulkData.class, new BulkDataImpl()),
                     0);
    server.start();
    client =
      new HttpTransceiver(new URL("http://127.0.0.1:"+server.getPort()+"/"));
    proxy = (BulkData)SpecificRequestor.getClient(BulkData.class, client);
  }

  @Test
  public void testRead() throws IOException {
    for (int i = 0; i < COUNT; i++)
      Assert.assertEquals(SIZE, proxy.read().remaining());
  }

  @Test
  public void testWrite() throws IOException {
    for (int i = 0; i < COUNT; i++)
      proxy.write(DATA.duplicate());
  }

  @AfterClass
  public static void stopServer() throws Exception {
    server.close();
  }

  public static void main(String[] args) throws Exception {
    TestBulkData test = new TestBulkData();
    test.startServer();
    System.out.println("READ");
    long start = System.currentTimeMillis();
    test.testRead();
    printStats(start);
    System.out.println("WRITE");
    start = System.currentTimeMillis();
    test.testWrite();
    printStats(start);
    test.stopServer();
  }

  private static void printStats(long start) {
    double seconds = (System.currentTimeMillis()-start)/1000.0;
    System.out.println("seconds = "+(int)seconds);
    System.out.println("requests/second = "+(int)(COUNT/seconds));
    double megabytes = (COUNT*SIZE)/(1024*1024.0);
    System.out.println("MB = "+(int)megabytes);
    System.out.println("MB/second = "+ (int)(megabytes/seconds));
  }

}
TOP

Related Classes of org.apache.avro.TestBulkData$BulkDataImpl

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.