Tanuj Khurana created PHOENIX-7765:
--------------------------------------

             Summary: NPE on first invocation of getClusterRoleRecord API
                 Key: PHOENIX-7765
                 URL: https://issues.apache.org/jira/browse/PHOENIX-7765
             Project: Phoenix
          Issue Type: Sub-task
            Reporter: Tanuj Khurana


The first invocation of getClusterRoleRecord API always errors out with a NPE. 
The retry succeeds. This is because the region server list is not initialized 
by default when initializing cqsi. 
{code:java}
2026-02-16 13:25:13,010 ERROR GetClusterRoleRecordUtil - Error in getting 
ClusterRoleRecord for testConnectionWhenActiveZKRestarts from url 
jdbc:phoenix+rpc:localhost\:58988org.apache.phoenix.exception.PhoenixIOException
    at 
org.apache.phoenix.util.ClientUtil.parseServerException(ClientUtil.java:72)  at 
org.apache.phoenix.util.GetClusterRoleRecordUtil.getClusterRoleRecord(GetClusterRoleRecordUtil.java:113)
     at 
org.apache.phoenix.util.GetClusterRoleRecordUtil.fetchClusterRoleRecord(GetClusterRoleRecordUtil.java:144)
   at 
org.apache.phoenix.jdbc.HighAvailabilityGroup.getClusterRoleRecordFromEndpoint(HighAvailabilityGroup.java:957)
       at 
org.apache.phoenix.jdbc.HighAvailabilityGroup.init(HighAvailabilityGroup.java:612)
   at 
org.apache.phoenix.jdbc.HighAvailabilityGroup.get(HighAvailabilityGroup.java:383)
    at 
org.apache.phoenix.jdbc.HighAvailabilityTestingUtility.lambda$getHighAvailibilityGroup$0(HighAvailabilityTestingUtility.java:1135)
   at 
org.apache.hadoop.hbase.GenericTestUtils.waitFor(GenericTestUtils.java:97)   at 
org.apache.phoenix.jdbc.HighAvailabilityTestingUtility.getHighAvailibilityGroup(HighAvailabilityTestingUtility.java:1132)
    at 
org.apache.phoenix.jdbc.FailoverPhoenixConnection2IT.setup(FailoverPhoenixConnection2IT.java:120)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)  at 
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)   
     at 
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)     at 
org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:59)
 at 
org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
  at 
org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:56)
   at 
org.junit.internal.runners.statements.RunBefores.invokeMethod(RunBefores.java:33)
    at 
org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:24)   
     at 
org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27)  at 
org.junit.rules.TestWatcher$1.evaluate(TestWatcher.java:61)  at 
org.junit.runners.ParentRunner$3.evaluate(ParentRunner.java:306)     at 
org.junit.runners.BlockJUnit4ClassRunner$1.evaluate(BlockJUnit4ClassRunner.java:100)
 at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:366)        at 
org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:103)
   at 
org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:63)
    at org.junit.runners.ParentRunner$4.run(ParentRunner.java:331)  at 
org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:79)      at 
org.junit.runners.ParentRunner.runChildren(ParentRunner.java:329)    at 
org.junit.runners.ParentRunner.access$100(ParentRunner.java:66)      at 
org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:293)     at 
org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)   
     at 
org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27)  at 
org.junit.rules.ExternalResource$1.evaluate(ExternalResource.java:54)        at 
org.junit.rules.ExternalResource$1.evaluate(ExternalResource.java:54)        at 
org.junit.rules.RunRules.evaluate(RunRules.java:20)  at 
org.junit.runners.ParentRunner$3.evaluate(ParentRunner.java:306)     at 
org.junit.runners.ParentRunner.run(ParentRunner.java:413)    at 
org.junit.runners.Suite.runChild(Suite.java:128)     at 
org.junit.runners.Suite.runChild(Suite.java:27)      at 
org.junit.runners.ParentRunner$4.run(ParentRunner.java:331)  at 
org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:79)      at 
org.junit.runners.ParentRunner.runChildren(ParentRunner.java:329)    at 
org.junit.runners.ParentRunner.access$100(ParentRunner.java:66)      at 
org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:293)     at 
org.junit.runners.ParentRunner$3.evaluate(ParentRunner.java:306)     at 
org.junit.runners.ParentRunner.run(ParentRunner.java:413)    at 
org.apache.maven.surefire.junitcore.JUnitCore.run(JUnitCore.java:55) at 
org.apache.maven.surefire.junitcore.JUnitCoreWrapper.createRequestAndRun(JUnitCoreWrapper.java:137)
  at 
org.apache.maven.surefire.junitcore.JUnitCoreWrapper.executeEager(JUnitCoreWrapper.java:107)
 at 
org.apache.maven.surefire.junitcore.JUnitCoreWrapper.execute(JUnitCoreWrapper.java:83)
       at 
org.apache.maven.surefire.junitcore.JUnitCoreWrapper.execute(JUnitCoreWrapper.java:75)
       at 
org.apache.maven.surefire.junitcore.JUnitCoreProvider.invoke(JUnitCoreProvider.java:158)
     at 
org.apache.maven.surefire.booter.ForkedBooter.runSuitesInProcess(ForkedBooter.java:456)
      at 
org.apache.maven.surefire.booter.ForkedBooter.execute(ForkedBooter.java:169) at 
org.apache.maven.surefire.booter.ForkedBooter.run(ForkedBooter.java:595)     at 
org.apache.maven.surefire.booter.ForkedBooter.main(ForkedBooter.java:581)Caused 
by: java.lang.NullPointerException   at 
org.apache.phoenix.util.GetClusterRoleRecordUtil.getClusterRoleRecord(GetClusterRoleRecordUtil.java:85)
      ... 55 more
 {code}



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to