Я пытаюсь протестировать простой проект MapReduce, используя MRUnit. Я устанавливаю вход для mapDriver, а затем вызываю mapDriver.runTest()
(я также пробовал с mapDriver.run()
, но выдает ту же ошибку).java.lang.NullPointerException с использованием MRUnit. Ошибка стандартной сериализации ключа
Я написал специальный ключ, который перегружает write(DataOutput out)
, readFields(DataInput in)
и compareTo(...)
Методы. При отладке ключ правильно записывает свои данные с помощью write(DataOutput out)
. Однако после того, как метод ключа readFields(DataInput in)
(который корректно извлекает данные, которые были ранее записаны с использованием write(DataOutput out)
), заканчивается, появляется ошибка ниже.
Я нашел здесь похожие записи и попробовал переопределить методы hashCode()
и equals()
безрезультатно. Требует ли MRUnit каких-либо дополнительных методов для переопределения при использовании пользовательских ключей? Этот пост больше всего похож на MRUnit with Avro NullPointerException in Serialization. Тем не менее, я не использую avro, и насколько мне известно, я использую сериализацию по умолчанию. Ура!
java.lang.NullPointerException
at org.apache.hadoop.mrunit.Serialization.copy(Serialization.java:61)
at org.apache.hadoop.mrunit.Serialization.copy(Serialization.java:81)
at org.apache.hadoop.mrunit.mapreduce.mock.MockContextWrapper$4.answer(MockContextWrapper.java:78)
at org.mockito.internal.stubbing.StubbedInvocationMatcher.answer(StubbedInvocationMatcher.java:31)
at org.mockito.internal.MockHandler.handle(MockHandler.java:97)
at org.mockito.internal.creation.MethodInterceptorFilter.intercept(MethodInterceptorFilter.java:47)
at org.apache.hadoop.mapreduce.Mapper$Context$$EnhancerByMockitoWithCGLIB$$f555e120.write(<generated>)
at model.RMSEEvaluation$Mapper.map(RMSEEvaluation.java:57)
at model.RMSEEvaluation$Mapper.map(RMSEEvaluation.java:1)
at org.apache.hadoop.mapreduce.Mapper.run(Mapper.java:144)
at org.apache.hadoop.mrunit.mapreduce.MapDriver.run(MapDriver.java:221)
at org.apache.hadoop.mrunit.MapDriverBase.runTest(MapDriverBase.java:150)
at org.apache.hadoop.mrunit.TestDriver.runTest(TestDriver.java:137)
at test.TestRMSEEvaluation.testSetValues(TestRMSEEvaluation.java:77)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at junit.framework.TestCase.runTest(TestCase.java:168)
at junit.framework.TestCase.runBare(TestCase.java:134)
at junit.framework.TestResult$1.protect(TestResult.java:110)
at junit.framework.TestResult.runProtected(TestResult.java:128)
at junit.framework.TestResult.run(TestResult.java:113)
at junit.framework.TestCase.run(TestCase.java:124)
at junit.framework.TestSuite.runTest(TestSuite.java:243)
at junit.framework.TestSuite.run(TestSuite.java:238)
at org.junit.internal.runners.JUnit38ClassRunner.run(JUnit38ClassRunner.java:83)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Можете ли вы опубликовать код для вашего ключа и версии Hadoop + MRUnit, вы используете –
Привет Крис, я нашел причину ошибки и отправил ответ. Я использую [Hadoop 2.0.0-alpha] (http://hadoop.apache.org/releases.html#23+May%2C+2012%3A+Release+2.0.0-alpha+available) и [MRUnit 0.9.0-Инкубация-hadoop2] (http://mrunit.apache.org/general/downloads.html). – Sam