public class org.apache.zookeeper.server.quorum.RaceConditionTest extends org.apache.zookeeper.server.quorum.QuorumPeerTestBase
{
protected static final org.slf4j.Logger LOG;
private static int SERVER_COUNT;
private org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt;
public void <init>()
{
org.apache.zookeeper.server.quorum.RaceConditionTest v;
v := @this: org.apache.zookeeper.server.quorum.RaceConditionTest;
specialinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase: void <init>()>();
return;
}
public void testRaceConditionBetweenLeaderAndAckRequestProcessor() throws java.lang.Exception
{
org.apache.zookeeper.server.quorum.QuorumPeer v;
java.lang.String[] v;
long v, v;
byte v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v, v, v;
int v, v;
java.lang.String v, v, v;
boolean v, v, v;
org.apache.zookeeper.server.quorum.RaceConditionTest v;
v := @this: org.apache.zookeeper.server.quorum.RaceConditionTest;
v = specialinvoke v.<org.apache.zookeeper.server.quorum.RaceConditionTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] startQuorum()>();
v.<org.apache.zookeeper.server.quorum.RaceConditionTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt> = v;
v = v.<org.apache.zookeeper.server.quorum.RaceConditionTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
v = specialinvoke v.<org.apache.zookeeper.server.quorum.RaceConditionTest: org.apache.zookeeper.server.quorum.QuorumPeer getLeader(org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[])>(v);
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: long getCurrentEpoch()>();
staticinvoke <org.junit.jupiter.api.Assertions: void assertNotNull(java.lang.Object,java.lang.String)>(v, "Leader should not be null");
v = v.<org.apache.zookeeper.server.quorum.RaceConditionTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
specialinvoke v.<org.apache.zookeeper.server.quorum.RaceConditionTest: void shutdownFollowers(org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[])>(v);
v = newarray (java.lang.String)[2];
v[0] = "leaderelection";
v[1] = "following";
v = staticinvoke <org.apache.zookeeper.test.ClientBase: boolean waitForServerState(org.apache.zookeeper.server.quorum.QuorumPeer,int,java.lang.String[])>(v, 15000, v);
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: int getClientPort()>();
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);
staticinvoke <org.junit.jupiter.api.Assertions: void assertTrue(boolean,java.lang.String)>(v, "Failed to bring up the old leader server");
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;
label:
v = 1;
goto label;
label:
v = 0;
label:
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: java.lang.String getServerState()>();
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[])>("Leader failed to transition to new state. Current state is \u0001");
staticinvoke <org.junit.jupiter.api.Assertions: void assertTrue(boolean,java.lang.String)>(v, v);
return;
}
public void tearDown()
{
org.slf4j.Logger v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread v;
org.apache.zookeeper.server.quorum.RaceConditionTest v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v, v;
java.lang.InterruptedException v;
int v, v;
v := @this: org.apache.zookeeper.server.quorum.RaceConditionTest;
v = v.<org.apache.zookeeper.server.quorum.RaceConditionTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
if null == v goto label;
v = 0;
label:
v = <org.apache.zookeeper.server.quorum.RaceConditionTest: int SERVER_COUNT>;
if v >= v goto label;
label:
v = v.<org.apache.zookeeper.server.quorum.RaceConditionTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
v = v[v];
virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: void shutdown()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.zookeeper.server.quorum.RaceConditionTest: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Quorum Peer interrupted while shutting it down", v);
label:
v = v + 1;
goto label;
label:
return;
catch java.lang.InterruptedException from label to label with label;
}
private org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] startQuorum() throws java.io.IOException
{
org.apache.zookeeper.server.quorum.RaceConditionTest$1 v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v;
int[] v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v;
boolean v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread v;
org.apache.zookeeper.server.quorum.RaceConditionTest v;
java.lang.StringBuilder v;
v := @this: org.apache.zookeeper.server.quorum.RaceConditionTest;
v = <org.apache.zookeeper.server.quorum.RaceConditionTest: int SERVER_COUNT>;
v = newarray (int)[v];
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = 0;
label:
v = <org.apache.zookeeper.server.quorum.RaceConditionTest: int SERVER_COUNT>;
if v >= v 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 = <org.apache.zookeeper.server.quorum.RaceConditionTest: int SERVER_COUNT>;
v = newarray (org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread)[v];
v = 0;
label:
v = <org.apache.zookeeper.server.quorum.RaceConditionTest: int SERVER_COUNT>;
if v >= v goto label;
v = new org.apache.zookeeper.server.quorum.RaceConditionTest$1;
v = v[v];
specialinvoke v.<org.apache.zookeeper.server.quorum.RaceConditionTest$1: void <init>(org.apache.zookeeper.server.quorum.RaceConditionTest,int,int,java.lang.String,boolean)>(v, 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:
v = <org.apache.zookeeper.server.quorum.RaceConditionTest: int SERVER_COUNT>;
if v >= v 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:
return v;
}
private org.apache.zookeeper.server.quorum.QuorumPeer getLeader(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.server.quorum.RaceConditionTest 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.server.quorum.RaceConditionTest;
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 v == null 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 void shutdownFollowers(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.server.quorum.RaceConditionTest 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.server.quorum.RaceConditionTest;
v := @parameter: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[];
v = 0;
label:
v = lengthof v;
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: org.apache.zookeeper.server.quorum.QuorumPeer getQuorumPeer()>();
if v == null goto label;
v = <org.apache.zookeeper.server.quorum.QuorumPeer$ServerState: org.apache.zookeeper.server.quorum.QuorumPeer$ServerState FOLLOWING>;
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.RaceConditionTest$CustomQuorumPeer: org.apache.zookeeper.server.quorum.QuorumPeer$ServerState getPeerState()>();
if v != v goto label;
virtualinvoke v.<org.apache.zookeeper.server.quorum.RaceConditionTest$CustomQuorumPeer: void setStopPing(boolean)>(1);
label:
v = v + 1;
goto label;
label:
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/zookeeper/server/quorum/RaceConditionTest;");
<org.apache.zookeeper.server.quorum.RaceConditionTest: org.slf4j.Logger LOG> = v;
<org.apache.zookeeper.server.quorum.RaceConditionTest: int SERVER_COUNT> = 3;
return;
}
}