public class org.apache.zookeeper.test.NonRecoverableErrorTest extends org.apache.zookeeper.server.quorum.QuorumPeerTestBase
{
private static final java.lang.String NODE_PATH;
public void <init>()
{
org.apache.zookeeper.test.NonRecoverableErrorTest v;
v := @this: org.apache.zookeeper.test.NonRecoverableErrorTest;
specialinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase: void <init>()>();
return;
}
public void testZooKeeperServiceAvailableOnLeader() throws java.lang.Exception
{
org.apache.zookeeper.CreateMode v, v, v;
org.apache.zookeeper.server.quorum.QuorumPeer v, v;
byte[] v, v, v;
org.apache.zookeeper.test.NonRecoverableErrorTest v;
org.apache.zookeeper.ZooKeeper v;
java.lang.Exception v;
java.lang.StringBuilder v;
org.apache.zookeeper.server.ZKDatabase v, v;
long v;
org.apache.zookeeper.test.ClientBase$CountdownWatcher v;
java.util.ArrayList v, v, v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread v, v, v;
java.io.File v, v;
org.apache.zookeeper.server.ZooKeeperServer v, v, v, v;
int[] v;
org.apache.zookeeper.test.NonRecoverableErrorTest$1 v;
boolean v, v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.zookeeper.test.NonRecoverableErrorTest;
v = newarray (int)[3];
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = 0;
label:
if v >= 3 goto label;
v = staticinvoke <org.apache.zookeeper.PortAssignment: int unique()>();
v[v] = v;
v = staticinvoke <org.apache.zookeeper.PortAssignment: int unique()>();
v = staticinvoke <org.apache.zookeeper.PortAssignment: int unique()>();
v = v[v];
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,int,int,int)>(v, v, v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("server.\u0001=127.0.0.1:\u0001:\u0001:participant;127.0.0.1:\u0001");
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001\n");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v = newarray (org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread)[3];
v = 0;
label:
if v >= 3 goto label;
v = new org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread;
v = v[v];
specialinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: void <init>(int,int,java.lang.String,boolean)>(v, v, v, 0);
v[v] = v;
v = v[v];
virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: void start()>();
v = v + 1;
goto label;
label:
v = 0;
label:
if v >= 3 goto label;
v = v[v];
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("127.0.0.1:\u0001");
v = <org.apache.zookeeper.test.ClientBase: int CONNECTION_TIMEOUT>;
v = staticinvoke <org.apache.zookeeper.test.ClientBase: boolean waitForServerUp(java.lang.String,long)>(v, v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("waiting for server \u being up");
staticinvoke <org.junit.jupiter.api.Assertions: void assertTrue(boolean,java.lang.String)>(v, v);
v = v + 1;
goto label;
label:
v = new org.apache.zookeeper.test.ClientBase$CountdownWatcher;
specialinvoke v.<org.apache.zookeeper.test.ClientBase$CountdownWatcher: void <init>()>();
v = new org.apache.zookeeper.ZooKeeper;
v = v[0];
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("127.0.0.1:\u0001");
v = <org.apache.zookeeper.test.ClientBase: int CONNECTION_TIMEOUT>;
specialinvoke v.<org.apache.zookeeper.ZooKeeper: void <init>(java.lang.String,int,org.apache.zookeeper.Watcher)>(v, v, v);
v = <org.apache.zookeeper.test.ClientBase: int CONNECTION_TIMEOUT>;
virtualinvoke v.<org.apache.zookeeper.test.ClientBase$CountdownWatcher: void waitForConnected(long)>(v);
v = "originalData";
v = virtualinvoke v.<java.lang.String: byte[] getBytes()>();
v = <org.apache.zookeeper.ZooDefs$Ids: java.util.ArrayList OPEN_ACL_UNSAFE>;
v = <org.apache.zookeeper.CreateMode: org.apache.zookeeper.CreateMode PERSISTENT>;
virtualinvoke v.<org.apache.zookeeper.ZooKeeper: java.lang.String create(java.lang.String,byte[],java.util.List,org.apache.zookeeper.CreateMode)>("/noLeaderIssue", v, v, v);
v = specialinvoke v.<org.apache.zookeeper.test.NonRecoverableErrorTest: org.apache.zookeeper.server.quorum.QuorumPeer getLeaderQuorumPeer(org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[])>(v);
staticinvoke <org.junit.jupiter.api.Assertions: void assertNotNull(java.lang.Object,java.lang.String)>(v, "Leader must have been elected by now");
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.ZooKeeperServer getActiveServer()>();
v = virtualinvoke v.<org.apache.zookeeper.server.ZooKeeperServer: org.apache.zookeeper.server.persistence.FileTxnSnapLog getTxnLogFactory()>();
v = new org.apache.zookeeper.test.NonRecoverableErrorTest$1;
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File getDataDir()>();
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File getSnapDir()>();
specialinvoke v.<org.apache.zookeeper.test.NonRecoverableErrorTest$1: void <init>(org.apache.zookeeper.test.NonRecoverableErrorTest,java.io.File,java.io.File)>(v, v, v);
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.ZooKeeperServer getActiveServer()>();
v = virtualinvoke v.<org.apache.zookeeper.server.ZooKeeperServer: org.apache.zookeeper.server.ZKDatabase getZKDatabase()>();
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: long getCurrentEpoch()>();
v = new org.apache.zookeeper.server.ZKDatabase;
specialinvoke v.<org.apache.zookeeper.server.ZKDatabase: void <init>(org.apache.zookeeper.server.persistence.FileTxnSnapLog)>(v);
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.ZooKeeperServer getActiveServer()>();
virtualinvoke v.<org.apache.zookeeper.server.ZooKeeperServer: void setZKDatabase(org.apache.zookeeper.server.ZKDatabase)>(v);
label:
v = specialinvoke v.<org.apache.zookeeper.test.NonRecoverableErrorTest: java.lang.String uniqueZnode()>();
v = virtualinvoke v.<java.lang.String: byte[] getBytes()>();
v = <org.apache.zookeeper.ZooDefs$Ids: java.util.ArrayList OPEN_ACL_UNSAFE>;
v = <org.apache.zookeeper.CreateMode: org.apache.zookeeper.CreateMode PERSISTENT>;
virtualinvoke v.<org.apache.zookeeper.ZooKeeper: java.lang.String create(java.lang.String,byte[],java.util.List,org.apache.zookeeper.CreateMode)>(v, v, v, v);
staticinvoke <org.junit.jupiter.api.Assertions: java.lang.Object fail(java.lang.String)>("IOException is expected due to error injected to transaction log commit");
label:
goto label;
label:
v := @caughtexception;
label:
virtualinvoke v.<org.apache.zookeeper.test.ClientBase$CountdownWatcher: void reset()>();
specialinvoke v.<org.apache.zookeeper.test.NonRecoverableErrorTest: void waitForNewLeaderElection(org.apache.zookeeper.server.quorum.QuorumPeer,long)>(v, v);
v = 0;
label:
if v >= 3 goto label;
v = v[v];
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("127.0.0.1:\u0001");
v = <org.apache.zookeeper.test.ClientBase: int CONNECTION_TIMEOUT>;
v = staticinvoke <org.apache.zookeeper.test.ClientBase: boolean waitForServerUp(java.lang.String,long)>(v, v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("waiting for server \u being up");
staticinvoke <org.junit.jupiter.api.Assertions: void assertTrue(boolean,java.lang.String)>(v, v);
v = v + 1;
goto label;
label:
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.ZooKeeperServer getActiveServer()>();
virtualinvoke v.<org.apache.zookeeper.server.ZooKeeperServer: void setZKDatabase(org.apache.zookeeper.server.ZKDatabase)>(v);
v = specialinvoke v.<org.apache.zookeeper.test.NonRecoverableErrorTest: org.apache.zookeeper.server.quorum.QuorumPeer getLeaderQuorumPeer(org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[])>(v);
staticinvoke <org.junit.jupiter.api.Assertions: void assertNotNull(java.lang.Object,java.lang.String)>(v, "New leader must have been elected by now");
v = specialinvoke v.<org.apache.zookeeper.test.NonRecoverableErrorTest: java.lang.String uniqueZnode()>();
v = <org.apache.zookeeper.test.ClientBase: int CONNECTION_TIMEOUT>;
virtualinvoke v.<org.apache.zookeeper.test.ClientBase$CountdownWatcher: void waitForConnected(long)>(v);
v = virtualinvoke v.<java.lang.String: byte[] getBytes()>();
v = <org.apache.zookeeper.ZooDefs$Ids: java.util.ArrayList OPEN_ACL_UNSAFE>;
v = <org.apache.zookeeper.CreateMode: org.apache.zookeeper.CreateMode PERSISTENT>;
v = virtualinvoke v.<org.apache.zookeeper.ZooKeeper: java.lang.String create(java.lang.String,byte[],java.util.List,org.apache.zookeeper.CreateMode)>(v, v, v, v);
staticinvoke <org.junit.jupiter.api.Assertions: void assertEquals(java.lang.Object,java.lang.Object,java.lang.String)>(v, v, "Failed to create znode");
virtualinvoke v.<org.apache.zookeeper.ZooKeeper: void close()>();
v = 0;
label:
if v >= 3 goto label;
v = v[v];
virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: void shutdown()>();
v = v + 1;
goto label;
label:
return;
catch java.lang.Exception from label to label with label;
}
private void waitForNewLeaderElection(org.apache.zookeeper.server.quorum.QuorumPeer, long) throws java.io.IOException, java.lang.InterruptedException
{
org.apache.zookeeper.server.quorum.QuorumPeer v;
org.slf4j.Logger v;
long v, v, v;
org.apache.zookeeper.test.NonRecoverableErrorTest v;
byte v;
int v;
v := @this: org.apache.zookeeper.test.NonRecoverableErrorTest;
v := @parameter: org.apache.zookeeper.server.quorum.QuorumPeer;
v := @parameter: long;
v = <org.apache.zookeeper.test.NonRecoverableErrorTest: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>("Waiting for new LE cycle..");
v = 100;
label:
if v <= 0 goto label;
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: long getCurrentEpoch()>();
v = v cmp v;
if v != 0 goto label;
staticinvoke <java.lang.Thread: void sleep(long)>(100L);
label:
v = v - 1;
goto label;
label:
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: long getCurrentEpoch()>();
staticinvoke <org.junit.jupiter.api.Assertions: void assertNotEquals(long,long,java.lang.String)>(v, v, "New LE cycle must have triggered");
return;
}
private org.apache.zookeeper.server.quorum.QuorumPeer getLeaderQuorumPeer(org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[])
{
org.apache.zookeeper.server.quorum.QuorumPeer v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread v;
org.apache.zookeeper.test.NonRecoverableErrorTest v;
org.apache.zookeeper.server.quorum.QuorumPeer$ServerState v, v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v;
int v, v;
v := @this: org.apache.zookeeper.test.NonRecoverableErrorTest;
v := @parameter: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[];
v = lengthof v;
v = v - 1;
label:
if v < 0 goto label;
v = v[v];
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: org.apache.zookeeper.server.quorum.QuorumPeer getQuorumPeer()>();
if null == v goto label;
v = <org.apache.zookeeper.server.quorum.QuorumPeer$ServerState: org.apache.zookeeper.server.quorum.QuorumPeer$ServerState LEADING>;
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.quorum.QuorumPeer$ServerState getPeerState()>();
if v != v goto label;
return v;
label:
v = v - 1;
goto label;
label:
return null;
}
private java.lang.String uniqueZnode()
{
java.lang.String v, v;
java.util.UUID v;
org.apache.zookeeper.test.NonRecoverableErrorTest v;
v := @this: org.apache.zookeeper.test.NonRecoverableErrorTest;
v = staticinvoke <java.util.UUID: java.util.UUID randomUUID()>();
v = virtualinvoke v.<java.util.UUID: java.lang.String toString()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("/noLeaderIssue/\u0001");
return v;
}
}