/** * Licensed to DigitalPebble Ltd under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * DigitalPebble 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 com.digitalpebble.stormcrawler; import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; import org.apache.storm.spout.ISpoutOutputCollector; import org.apache.storm.task.IOutputCollector; import org.apache.storm.tuple.Tuple; import org.apache.storm.utils.Utils; public class TestOutputCollector implements IOutputCollector, ISpoutOutputCollector { private List<Tuple> acked = new ArrayList<>(); private List<Tuple> failed = new ArrayList<>(); private Map<String, List<List<Object>>> emitted = new HashMap<>(); @Override public void reportError(Throwable error) { } @Override public List<Integer> emit(String streamId, Collection<Tuple> anchors, List<Object> tuples) { addEmittedTuple(streamId, tuples); // No idea what to return return null; } @Override public void emitDirect(int taskId, String streamId, Collection<Tuple> anchors, List<Object> tuple) { } @Override public void ack(Tuple input) { acked.add(input); } @Override public void fail(Tuple input) { failed.add(input); } public List<List<Object>> getEmitted() { return getEmitted(Utils.DEFAULT_STREAM_ID); } public List<List<Object>> getEmitted(String streamId) { List<List<Object>> streamTuples = emitted.get(streamId); if (streamTuples == null) { return Collections.emptyList(); } else { return streamTuples; } } public List<Tuple> getAckedTuples() { return acked; } public List<Tuple> getFailedTuples() { return failed; } @Override public List<Integer> emit(String streamId, List<Object> tuple, Object messageId) { addEmittedTuple(streamId, tuple); return null; } @Override public void emitDirect(int taskId, String streamId, List<Object> tuple, Object messageId) { addEmittedTuple(streamId, tuple); } private void addEmittedTuple(String streamId, List<Object> tuple) { List<List<Object>> streamTuples = emitted.get(streamId); if (streamTuples == null) { streamTuples = new ArrayList<>(); emitted.put(streamId, streamTuples); } streamTuples.add(tuple); } @Override public long getPendingCount() { // TODO Auto-generated method stub return 0; } @Override public void resetTimeout(Tuple arg0) { // TODO Auto-generated method stub } }