[ 
https://issues.apache.org/jira/browse/ATLAS-296?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15000287#comment-15000287
 ] 

Shwetha G S commented on ATLAS-296:
-----------------------------------

+1, committed to master. Thanks Tom

> IllegalArgumentException during hive HiveHookIT integration tests.
> ------------------------------------------------------------------
>
>                 Key: ATLAS-296
>                 URL: https://issues.apache.org/jira/browse/ATLAS-296
>             Project: Atlas
>          Issue Type: Bug
>            Reporter: Tom Beerbower
>            Assignee: Tom Beerbower
>             Fix For: trunk
>
>         Attachments: ATLAS-296.patch
>
>
> In the hive-bridge tests (HiveHookIT), the following stacktrace is printed. 
> The tests succeed though.
> Introduced with patch for entity notification.  ATLAS-158.
> {code}
> 127.0.0.1 - - [10/Nov/2015:04:31:24 +0000] "OPTIONS 
> /api/atlas/entities?user.name=sshivalingamurthy HTTP/1.1" 200 3317 "-" 
> "Java/1.7.0_79"
> 2015-11-10 10:01:24.622:WARN:oejs.ServletHandler:qtp276244868-27: 
> /api/atlas/entities
> java.lang.IllegalArgumentException: Input String cannot be null cannot be null
>     at org.apache.atlas.ParamChecker.notNull(ParamChecker.java:34)
>     at org.apache.atlas.web.util.Servlets.escapeJsonString(Servlets.java:146)
>     at org.apache.atlas.web.util.Servlets.getErrorResponse(Servlets.java:125)
>     at org.apache.atlas.web.util.Servlets.getErrorResponse(Servlets.java:107)
>     at 
> org.apache.atlas.web.resources.EntityResource.submit(EntityResource.java:136)
>     at sun.reflect.GeneratedMethodAccessor119.invoke(Unknown Source)
>     at 
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
>     at java.lang.reflect.Method.invoke(Method.java:606)
>     at 
> com.sun.jersey.spi.container.JavaMethodInvokerFactory$1.invoke(JavaMethodInvokerFactory.java:60)
>     at 
> com.sun.jersey.server.impl.model.method.dispatch.AbstractResourceMethodDispatchProvider$ResponseOutInvoker._dispatch(AbstractResourceMethodDispatchProvider.java:205)
>     at 
> com.sun.jersey.server.impl.model.method.dispatch.ResourceJavaMethodDispatcher.dispatch(ResourceJavaMethodDispatcher.java:75)
>     at 
> com.sun.jersey.server.impl.uri.rules.HttpMethodRule.accept(HttpMethodRule.java:288)
>     at 
> com.sun.jersey.server.impl.uri.rules.ResourceClassRule.accept(ResourceClassRule.java:108)
>     at 
> com.sun.jersey.server.impl.uri.rules.RightHandPathRule.accept(RightHandPathRule.java:147)
>     at 
> com.sun.jersey.server.impl.uri.rules.RootResourceClassesRule.accept(RootResourceClassesRule.java:84)
>     at 
> com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1469)
>     at 
> com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1400)
>     at 
> com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1349)
>     at 
> com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1339)
>     at 
> com.sun.jersey.spi.container.servlet.WebComponent.service(WebComponent.java:409)
>     at 
> com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:558)
>     at 
> com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:733)
>     at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
>     at 
> com.google.inject.servlet.ServletDefinition.doServiceImpl(ServletDefinition.java:287)
>     at 
> com.google.inject.servlet.ServletDefinition.doService(ServletDefinition.java:277)
>     at 
> com.google.inject.servlet.ServletDefinition.service(ServletDefinition.java:182)
>     at 
> com.google.inject.servlet.ManagedServletPipeline.service(ManagedServletPipeline.java:91)
>     at org.apache.atlas.web.filters.AuditFilter.doFilter(AuditFilter.java:67)
>     at 
> com.google.inject.servlet.ManagedFilterPipeline.dispatch(ManagedFilterPipeline.java:119)
>     at com.google.inject.servlet.GuiceFilter$1.call(GuiceFilter.java:133)
>     at com.google.inject.servlet.GuiceFilter$1.call(GuiceFilter.java:130)
>     at 
> com.google.inject.servlet.GuiceFilter$Context.call(GuiceFilter.java:203)
>     at com.google.inject.servlet.GuiceFilter.doFilter(GuiceFilter.java:130)
>     at 
> org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1652)
>     at 
> org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:585)
>     at 
> org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143)
>     at 
> org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:577)
>     at 
> org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:223)
>     at 
> org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1127)
>     at 
> org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:515)
>     at 
> org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:185)
>     at 
> org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1061)
>     at 
> org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141)
>     at 
> org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:215)
>     at 
> org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:110)
>     at 
> org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)
>     at org.eclipse.jetty.server.Server.handle(Server.java:499)
>     at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:310)
>     at 
> org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:257)
>     at 
> org.eclipse.jetty.io.AbstractConnection$2.run(AbstractConnection.java:540)
>     at 
> org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:635)
>     at 
> org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:555)
>     at java.lang.Thread.run(Thread.java:745)
> 127.0.0.1 - - [10/Nov/2015:04:31:24 +0000] "POST /api/atlas/entities 
> HTTP/1.1" 500 4968 "-" "Java/1.7.0_79"
> {code}
> It looks like the serialization code for a Referenceable used by the 
> NotificationEntityChangeListener can generate a stack overflow if the 
> Referenceable contains a circular reference.
> Using the type system serialization 
> {{InstanceSerialization.toJson(referenceable, true)}} avoids the circular 
> reference by serializing the referenced Id rather than the entire object.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to