Как написать тестовый пример mrunit для (нескольких картографов и одного редуктора) драйвера MMR

   I am new to BigData I have written a MR program and trying to write test cases for it using MRUnit from https://dzone.com/articles/testing-mapreduce-mrunit

Но моя программа MR имеет 2 преобразователя и 1 редуктор, поэтому я не могу создать объект драйвера с помощью

newMapReduceDriver()          
newMapReduceDriver(mapper,reducer)           
newMapReduceDriver(mapper,reducer,combiner)

или же

newMultipleInputMapReduceDriver()
newMultipleInputMapReduceDriver(combiner,reducer)
newMultipleInputMapReduceDriver(reducer) 

Пожалуйста, предложите любой другой способ, что я делаю что-то не так. Заранее спасибо

Вот код

public class UC_RJoinerTool extends Configured implements Tool{

    public int run(String[] args) throws Exception {
        if(args == null || args.length < 4 ){
            System.err.println("Usage: <User file Input Path> <Comments file Input Path> <Output Path> <Inner/Right Outer/Full join>");
            ToolRunner.printGenericCommandUsage(System.err);
            return -1;
        }  else {

            Job job = Job.getInstance(getConf(), "Mapping Users with Comments");
            job.setJarByClass(UC_RJoinerTool.class);
            Path userInputPath = new Path(args[0]);
            Path commentsInputPath = new Path(args[1]);
            Path outPutPath = new Path(args[2]);
            String joinTypeInput = args[3];

            MultipleInputs.addInputPath(job, userInputPath, TextInputFormat.class,UserDotXmlMapper.class);
            MultipleInputs.addInputPath(job, commentsInputPath, TextInputFormat.class,CommentsDotXmlMapper.class);
            FileOutputFormat.setOutputPath(job,new Path(args[1]));
            //When you are using TextInputFormat explicitly say the map key and value types
            job.setMapOutputKeyClass(Text.class);
            job.setMapOutputValueClass(Text.class);

            job.getConfiguration().set("joinType",joinTypeInput);
            job.setReducerClass(UserCommentsReducer.class);
            job.setOutputKeyClass(Text.class);
            job.setOutputValueClass(Text.class);
            FileOutputFormat.setOutputPath(job, outPutPath);

            return job.waitForCompletion(true)?0:1;
        }
    }

    public static void main(String[] args)throws Exception {
        int exitCode = ToolRunner.run(new UC_RJoinerTool(),args);
        System.exit(exitCode);
    }
}

Мой юнит testCase Code

public class UCJoinTest {
    private MapDriver<LongWritable,Text,Text,Text> mapUsersDriver,mapCommentsDriver;    
    private ReduceDriver<Text, Text, Text,Text> reduceUCDriver;
    //private MapReduceDriver<LongWritable,Text,Text, Text, Text,Text> mapReduceUCDriver;
    private MultipleInputsMapReduceDriver<LongWritable,Text,Text,Text> mapReduceUCDriver;

private MapDriver<LongWritable, Text, LongWritable,Text> mapSortDriver;
private ReduceDriver<LongWritable,Text,Text,Text> reduceSortDriver;
private MapReduceDriver<LongWritable,Text,LongWritable,Text,Text,Text> mapReduceSortDriver;

@Before
public void setUp() throws Exception {
    final UserDotXmlMapper usersMapper = new UserDotXmlMapper();
    final CommentsDotXmlMapper CommentsMapper = new CommentsDotXmlMapper();
    final UserCommentsReducer ucReducer = new UserCommentsReducer();

    final ReputationSorterMapper sortMapper = new ReputationSorterMapper();
    final ReputationSorterReducer sortReducer = new ReputationSorterReducer();

    mapUsersDriver = MapDriver.newMapDriver(usersMapper);
    mapCommentsDriver = MapDriver.newMapDriver(CommentsMapper);     
    reduceUCDriver = ReduceDriver.newReduceDriver(ucReducer);

    mapReduceUCDriver = MapReduceDriver.newMapReduceDriver(usersMapper,CommentsMapper,ucReducer);
    mapReduceUCDriver = MultipleInputsMapReduceDriver.newMultipleInputMapReduceDriver(usersMapper,CommentsMapper,ucReducer);         

    mapSortDriver = MapDriver.newMapDriver(sortMapper); 
    reduceSortDriver = ReduceDriver.newReduceDriver(sortReducer);
    mapReduceSortDriver = MapReduceDriver.newMapReduceDriver(sortMapper,sortReducer);
}


public class CommentsDotXmlMapper extends Mapper<LongWritable,Text,Text,Text>{
}
public class UserDotXmlMapper extends Mapper<LongWritable,Text,Text,Text>{
}
public class UserCommentsReducer extends Reducer<Text, Text, Text,Text>{
}  

По какой-то причине Stackowerflow не позволил мне опубликовать вопрос, поэтому я добавляю этот комментарий, игнорируйте его

0 ответов

Другие вопросы по тегам