/*
* 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.proto.dataserver.Protocol;
import alluxio.proto.status.Status.PStatus;
import alluxio.util.proto.ProtoMessage;
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, PStatus.FAILED_PRECONDITION);
}
@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().setBlockId(1L).setOffset(offset).setLength(len)
.setPacketSize(PACKET_SIZE).build();
return new RPCProtoMessage(new ProtoMessage(readRequest), null);
}
}