Например, для отладки свинья udfs это работает: http://ben-tech.blogspot.ie/2011/08/how-to-debug-pig-udfs-in-eclipse.html
У меня есть сценарий улья, в котором я использую свой udaf, который терпит неудачу, поэтому я хотел бы пройти через udf-код.Как улей udf, udaf, udtfs, написанных в java, отлаживается в идее, таком как eclipse?
2
A
ответ
2
JUNIT можно отладить от Eclipse IDE., так как его класс java.
Рассмотрите этот UDF.
Пример 1
class SimpleHelloWorldUDFExample extends UDF {
public Text evaluate(Text input) {
if(input == null) return null;
return new Text("Hello " + input.toString());
}
}
Junit метод испытаний было бы, как это ...
@Test
public void testUDFNullCheck() {
SimpleHelloWorldUDFExample example = new SimpleHelloWorldUDFExample();
Assert.assertNull(example.evaluate(null));
}
Пример 2
package com.hive.udftest
import java.util.List;
import org.apache.hadoop.hive.ql.exec.UDFArgumentException;
import org.apache.hadoop.hive.ql.exec.UDFArgumentLengthException;
import org.apache.hadoop.hive.ql.metadata.HiveException;
import org.apache.hadoop.hive.ql.udf.generic.GenericUDF;
import org.apache.hadoop.hive.serde2.objectinspector.ListObjectInspector;
import org.apache.hadoop.hive.serde2.objectinspector.ObjectInspector;
import org.apache.hadoop.hive.serde2.objectinspector.primitive.PrimitiveObjectInspectorFactory;
import org.apache.hadoop.hive.serde2.objectinspector.primitive.StringObjectInspector;
class HiveUDFTest extends GenericUDF {
ListObjectInspector listOI;
StringObjectInspector elementOI;
@Override
public String getDisplayString(String[] arg0) {
return "arrayContainsExample()"; // this should probably be better
}
@Override
public ObjectInspector initialize(ObjectInspector[] arguments) throws UDFArgumentException {
if (arguments.length != 2) {
throw new UDFArgumentLengthException("arrayContainsExample only takes 2 arguments: List<T>, T");
}
// 1. Check we received the right object types.
ObjectInspector a = arguments[0];
ObjectInspector b = arguments[1];
if (!(a instanceof ListObjectInspector) || !(b instanceof StringObjectInspector)) {
throw new UDFArgumentException("first argument must be a list/array, second argument must be a string");
}
this.listOI = (ListObjectInspector) a;
this.elementOI = (StringObjectInspector) b;
// 2. Check that the list contains strings
if(!(listOI.getListElementObjectInspector() instanceof StringObjectInspector)) {
throw new UDFArgumentException("first argument must be a list of strings");
}
// the return type of our function is a boolean, so we provide the correct object inspector
return PrimitiveObjectInspectorFactory.javaBooleanObjectInspector;
}
@Override
public Object evaluate(DeferredObject[] arguments) throws HiveException {
// get the list and string from the deferred objects using the object inspectors
List<String> list = (List<String>) this.listOI.getList(arguments[0].get());
String arg = elementOI.getPrimitiveJavaObject(arguments[1].get());
// check for nulls
if (list == null || arg == null) {
return null;
}
// see if our list contains the value we need
for(String s: list) {
if (arg.equals(s)) return new Boolean(true);
}
return new Boolean(false);
}
}
Junit тест будет
package com.hive.udftest
import java.util.ArrayList;
import java.util.List;
import junit.framework.Assert;
import org.apache.hadoop.hive.ql.metadata.HiveException;
import org.apache.hadoop.hive.ql.udf.generic.GenericUDF.DeferredJavaObject;
import org.apache.hadoop.hive.ql.udf.generic.GenericUDF.DeferredObject;
import org.apache.hadoop.hive.serde2.objectinspector.ObjectInspector;
import org.apache.hadoop.hive.serde2.objectinspector.ObjectInspectorFactory;
import org.apache.hadoop.hive.serde2.objectinspector.primitive.JavaBooleanObjectInspector;
import org.apache.hadoop.hive.serde2.objectinspector.primitive.PrimitiveObjectInspectorFactory;
import org.junit.Test;
public class HiveUDFTestTest {
@Test
public void testComplexUDFReturnsCorrectValues() throws HiveException {
// set up the models we need
HiveUDFTest example = new HiveUDFTest();
ObjectInspector stringOI = PrimitiveObjectInspectorFactory.javaStringObjectInspector;
ObjectInspector listOI = ObjectInspectorFactory.getStandardListObjectInspector(stringOI);
JavaBooleanObjectInspector resultInspector = (JavaBooleanObjectInspector) example.initialize(new ObjectInspector[]{listOI, stringOI});
// create the actual UDF arguments
List<String> list = new ArrayList<String>();
list.add("a");
list.add("b");
list.add("c");
// test our results
// the value exists
Object result = example.evaluate(new DeferredObject[]{new DeferredJavaObject(list), new DeferredJavaObject("a")});
Assert.assertEquals(true, resultInspector.get(result));
// the value doesn't exist
Object result2 = example.evaluate(new DeferredObject[]{new DeferredJavaObject(list), new DeferredJavaObject("d")});
Assert.assertEquals(false, resultInspector.get(result2));
// arguments are null
Object result3 = example.evaluate(new DeferredObject[]{new DeferredJavaObject(null), new DeferredJavaObject(null)});
Assert.assertNull(result3);
}
}
аналогичным образом UDAF, UDTF, а также ...
0
Вот хороший блог, с образцом TestCase.
http://www.spryinc.com/blog/making-use-aspectj-test-hive-udtfs
+0
Ссылка только ответы не очень хорошие. поскольку ссылки могут быть мертвы в любое время. пожалуйста, добавьте важные детали в ответ здесь. : Обзор –
Смежные вопросы
- 1. Hive UDAF: Кастинг вывод не-Java улей UDAF на карте
- 2. Как составить улей UDF
- 3. JRI from Hive UDF/UDAF
- 4. Невозможно добавить UDF в улей
- 5. Hadoop улей UDF терпит неудачу
- 6. Разбор JSON с улей UDF в Scala
- 7. Java-источники в идее
- 8. Улей: UDF и GROUP BY
- 9. Улей UDF для SOAP XPath?
- 10. Hive UDF, которые используют улей таблицу
- 11. Написание улей UDF с использованием jRuby
- 12. Как очистить кеш проекта в идее Intellij, например, Eclipse?
- 13. Как узнать код Java, если VM отлаживается?
- 14. NullPointException in Hive UDAF
- 15. Проблема в управлении улей UDF написано в питоне
- 16. Как отлаживается код Silverlight
- 17. Как отлаживается ассоциация akka?
- 18. Java, как позвонить в UDF искры 1.4.1
- 19. когда отлаживается работа для java
- 20. Как использовать куки в идее проекта?
- 21. Улей: как рассчитать разницу в секундах?
- 22. Как восстановить родительскую папку модулей в Идее
- 23. Как сгенерировать wsdl-клиент в идее intelij
- 24. Как создать jar пакета java в идее intelliJ
- 25. отлаживается в режиме освобождения?
- 26. Как получить подсказки пользователей в идее Intellij для пользовательских входов?
- 27. Почему не отлаживается работа при использовании библиотек Guava в Eclipse?
- 28. Как назвать улей UDF, написанный на Java, используя Pyspark из Hive Context
- 29. Java-зависимости в Pig UDF
- 30. Как написать UDF Python для пользовательской функции сгенерированной функции в кусте
Под моим ответом было полезно? –
Это то, что я сделал https://yibingshi1977.wordpress.com/2012/12/27/debug-hive-in-eclipse/, также см. Https://issues.apache.org/jira/browse/HIVE-2665 также opts нужен экспорт, так как другой sh будет ребенком – shrewquest
в порядке. Но мы делаем ниже junit также и то, что мы делали и тестировали в HIVE. Если вы хотите, я могу дать вам больше образцов тестовых примеров с UDF, которые могут расширить GenericUDF, а также –