alluxio.worker.netty.DataServerBlockReadHandlerTest.java Source code

Java tutorial

Introduction

Here is the source code for alluxio.worker.netty.DataServerBlockReadHandlerTest.java

Source

/*
 * The Alluxio Open Foundation licenses this work under the Apache License, version 2.0
 * (the "License"). You may not use this work except in compliance with the License, which is
 * available at www.apache.org/licenses/LICENSE-2.0
 *
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
 * either express or implied, as more fully set forth in the License.
 *
 * See the NOTICE file distributed with this work for information regarding copyright ownership.
 */

package alluxio.worker.netty;

import alluxio.EmbeddedNoExceptionChannel;
import alluxio.network.protocol.RPCProtoMessage;
import alluxio.util.proto.ProtoMessage;
import alluxio.proto.dataserver.Protocol;
import alluxio.worker.block.BlockWorker;
import alluxio.worker.block.io.BlockReader;
import alluxio.worker.block.io.LocalFileBlockReader;

import io.netty.channel.embedded.EmbeddedChannel;
import io.netty.util.ResourceLeakDetector;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mockito;
import org.powermock.core.classloader.annotations.PrepareForTest;
import org.powermock.modules.junit4.PowerMockRunner;

@RunWith(PowerMockRunner.class)
@PrepareForTest({ LocalFileBlockReader.class })
public final class DataServerBlockReadHandlerTest extends DataServerReadHandlerTest {
    private BlockWorker mBlockWorker;
    private BlockReader mBlockReader;

    @Before
    public void before() throws Exception {
        ResourceLeakDetector.setLevel(ResourceLeakDetector.Level.ADVANCED);
        mBlockWorker = Mockito.mock(BlockWorker.class);
        Mockito.doNothing().when(mBlockWorker).accessBlock(Mockito.anyLong(), Mockito.anyLong());
        mChannel = new EmbeddedChannel(new DataServerBlockReadHandler(NettyExecutors.BLOCK_READER_EXECUTOR,
                mBlockWorker, FileTransferType.MAPPED));
        mChannelNoException = new EmbeddedNoExceptionChannel(new DataServerBlockReadHandler(
                NettyExecutors.BLOCK_READER_EXECUTOR, mBlockWorker, FileTransferType.MAPPED));
    }

    /**
     * Tests the {@link FileTransferType#TRANSFER} type.
     */
    @Test
    public void transferType() throws Exception {
        mChannel = new EmbeddedChannel(new DataServerBlockReadHandler(NettyExecutors.BLOCK_READER_EXECUTOR,
                mBlockWorker, FileTransferType.TRANSFER));

        long fileSize = PACKET_SIZE * 2;
        long checksumExpected = populateInputFile(fileSize, 0, fileSize - 1);

        BlockReader blockReader = Mockito.spy(mBlockReader);
        // Do not call close here so that we can check result. It will be closed explicitly.
        Mockito.doNothing().when(blockReader).close();
        Mockito.when(mBlockWorker.readBlockRemote(Mockito.anyLong(), Mockito.anyLong(), Mockito.anyLong()))
                .thenReturn(blockReader);
        mChannel.writeInbound(buildReadRequest(0, fileSize));
        checkAllReadResponses(mChannel, checksumExpected);
        mBlockReader.close();
    }

    /**
     * Tests read failure.
     */
    @Test
    public void readFailure() throws Exception {
        long fileSize = PACKET_SIZE * 10 + 1;
        populateInputFile(0, 0, fileSize - 1);
        mBlockReader.close();
        mChannelNoException.writeInbound(buildReadRequest(0, fileSize));
        Object response = waitForOneResponse(mChannelNoException);
        checkReadResponse(response, Protocol.Status.Code.INTERNAL);
    }

    @Override
    protected void mockReader(long start) throws Exception {
        mBlockReader = new LocalFileBlockReader(mFile);
        Mockito.when(mBlockWorker.readBlockRemote(Mockito.anyLong(), Mockito.anyLong(), Mockito.anyLong()))
                .thenReturn(mBlockReader);
    }

    @Override
    protected RPCProtoMessage buildReadRequest(long offset, long len) {
        Protocol.ReadRequest readRequest = Protocol.ReadRequest.newBuilder().setId(1L).setOffset(offset)
                .setLength(len).setLockId(1L).setType(Protocol.RequestType.ALLUXIO_BLOCK).build();
        return new RPCProtoMessage(new ProtoMessage(readRequest), null);
    }
}