[
https://issues.apache.org/jira/browse/PHOENIX-7765?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Lokesh Khurana reassigned PHOENIX-7765:
---------------------------------------
Assignee: Lokesh Khurana
> 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
> Assignee: Lokesh Khurana
> Priority: Major
>
> 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)