Uploaded image for project: 'Atlas'
  1. Atlas
  2. ATLAS-296

IllegalArgumentException during hive HiveHookIT integration tests.

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Resolved
    • Major
    • Resolution: Fixed
    • 0.6-incubating
    • 0.6-incubating
    • None
    • None

    Description

      In the hive-bridge tests (HiveHookIT), the following stacktrace is printed. The tests succeed though.

      Introduced with patch for entity notification. ATLAS-158.

      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"
      
      

      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.

      Attachments

        1. ATLAS-296.patch
          6 kB
          Tom Beerbower

        Activity

          People

            tbeerbower Tom Beerbower
            tbeerbower Tom Beerbower
            Votes:
            0 Vote for this issue
            Watchers:
            2 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: