/*
* #!
* %
* Copyright (C) 2014 - 2016 Humboldt-Universität zu Berlin
* %
* 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.
* #_
*/
package de.hub.cs.dbis.lrb.operators;
import static org.mockito.Matchers.anyString;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import java.io.BufferedReader;
import java.io.FileReader;
import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.List;
import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.powermock.api.mockito.PowerMockito;
import org.powermock.core.classloader.annotations.PrepareForTest;
import org.powermock.modules.junit4.PowerMockRunner;
import backtype.storm.spout.SpoutOutputCollector;
import backtype.storm.task.TopologyContext;
import backtype.storm.tuple.Fields;
import backtype.storm.tuple.Values;
import backtype.storm.utils.Utils;
import de.hub.cs.dbis.aeolus.testUtils.TestDeclarer;
import de.hub.cs.dbis.aeolus.testUtils.TestSpoutOutputCollector;
import de.hub.cs.dbis.aeolus.utils.TimestampMerger;
/**
* @author mjsax
*/
@RunWith(PowerMockRunner.class)
@PrepareForTest(FileReaderSpout.class)
public class FileReaderSpoutTest {
@Test
public void test() throws Exception {
FileReader fileReaderMock = PowerMockito.mock(FileReader.class);
PowerMockito.whenNew(FileReader.class).withArguments("xway").thenReturn(fileReaderMock);
BufferedReader bufferedReaderMock = PowerMockito.mock(BufferedReader.class);
PowerMockito.whenNew(BufferedReader.class).withArguments(fileReaderMock).thenReturn(bufferedReaderMock);
final String line = "type,73647,dummy-attributes";
when(bufferedReaderMock.readLine()).thenReturn(line).thenReturn(null);
FileReaderSpout spout = new FileReaderSpout();
List<Integer> taskMock = new LinkedList<Integer>();
taskMock.add(new Integer(0));
TopologyContext contextMock = mock(TopologyContext.class);
when(contextMock.getComponentTasks(anyString())).thenReturn(taskMock);
when(new Integer(contextMock.getThisTaskIndex())).thenReturn(new Integer(0));
HashMap<Object, Object> dummyConf = new HashMap<Object, Object>();
TestSpoutOutputCollector collector = new TestSpoutOutputCollector();
spout.open(dummyConf, contextMock, new SpoutOutputCollector(collector));
spout.nextTuple();
spout.nextTuple();
spout.nextTuple();
Assert.assertEquals(1, collector.output.size());
Assert.assertEquals(new Values(new Long(73647), line), collector.output.get(Utils.DEFAULT_STREAM_ID)
.removeFirst());
Assert.assertEquals(0, collector.output.get(Utils.DEFAULT_STREAM_ID).size());
Assert.assertNull(collector.output.get(TimestampMerger.FLUSH_STREAM_ID));
spout.deactivate();
Assert.assertEquals(1, collector.output.get(TimestampMerger.FLUSH_STREAM_ID).size());
Assert.assertEquals(new Values((Object)null), collector.output.get(TimestampMerger.FLUSH_STREAM_ID).get(0));
}
@Test
public void testDeclareOutputFields() {
FileReaderSpout spout = new FileReaderSpout();
TestDeclarer declarer = new TestDeclarer();
spout.declareOutputFields(declarer);
final int numberOfOutputStreams = 2;
Assert.assertEquals(numberOfOutputStreams, declarer.streamIdBuffer.size());
Assert.assertEquals(numberOfOutputStreams, declarer.schemaBuffer.size());
Assert.assertEquals(numberOfOutputStreams, declarer.directBuffer.size());
HashMap<String, Fields> expectedStreams = new HashMap<String, Fields>();
expectedStreams.put(null, new Fields("ts", "rawTuple"));
expectedStreams.put(TimestampMerger.FLUSH_STREAM_ID, new Fields("ts"));
Assert.assertEquals(expectedStreams.keySet(), new HashSet<String>(declarer.streamIdBuffer));
for(int i = 0; i < numberOfOutputStreams; ++i) {
Assert.assertEquals(expectedStreams.get(declarer.streamIdBuffer.get(i)).toList(), declarer.schemaBuffer
.get(i).toList());
Assert.assertEquals(new Boolean(false), declarer.directBuffer.get(i));
}
}
}