public class org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest extends org.apache.zookeeper.server.quorum.QuorumPeerTestBase
{
protected static final org.slf4j.Logger LOG;
public static final int CONNECTION_TIMEOUT;
public static final int SERVER_COUNT;
private org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt;
private int[] clientPorts;
private org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading[] qpMain;
public void <init>()
{
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest v;
v := @this: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest;
specialinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase: void <init>()>();
return;
}
public void setUp() throws java.lang.Exception
{
int[] v, v, v, v;
boolean v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading[] v, v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading v;
java.lang.StringBuilder v, v, v, v, v, v, v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v, v, v;
int v, v, v, v, v, v, v, v, v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$1 v;
java.lang.String v, v, v, v;
org.slf4j.Logger v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread v;
java.lang.Class v;
v := @this: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest;
v = <org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("STARTING quorum {}", v);
staticinvoke <org.apache.zookeeper.test.ClientBase: void setupTestEnv()>();
v = newarray (org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread)[3];
v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt> = v;
v = newarray (int)[3];
v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: int[] clientPorts> = v;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = 0;
label:
if v >= 3 goto label;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: int[] clientPorts>;
v = staticinvoke <org.apache.zookeeper.PortAssignment: int unique()>();
v[v] = v;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("server.");
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(int)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("=127.0.0.1:");
v = staticinvoke <org.apache.zookeeper.PortAssignment: int unique()>();
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(int)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(":");
v = staticinvoke <org.apache.zookeeper.PortAssignment: int unique()>();
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(int)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("\n");
v = v + 1;
goto label;
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("localSessionsEnabled=true\n");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("localSessionsUpgradingEnabled=true\n");
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v = newarray (org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading)[3];
v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading[] qpMain> = v;
v = 0;
label:
if v >= 3 goto label;
v = new org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading;
specialinvoke v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading: void <init>()>();
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading[] qpMain>;
v[v] = v;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
v = new org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$1;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: int[] clientPorts>;
v = v[v];
specialinvoke v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$1: void <init>(org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest,int,int,java.lang.String,boolean,org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading)>(v, v, v, v, 0, v);
v[v] = v;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
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.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: int[] clientPorts>;
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.server.quorum.SessionUpgradeQuorumTest: 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;
}
public void tearDown() throws java.lang.Exception
{
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest v;
org.slf4j.Logger v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v;
int v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread v;
java.lang.Class v;
java.lang.String v;
v := @this: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest;
v = <org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("STOPPING quorum {}", v);
v = 0;
label:
if v >= 3 goto label;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
v = v[v];
virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: void shutdown()>();
v = v + 1;
goto label;
label:
return;
}
public void testLocalSessionUpgradeSnapshot() throws java.io.IOException, java.lang.InterruptedException
{
org.apache.zookeeper.CreateMode v;
org.apache.zookeeper.server.quorum.QuorumPeer v, v, v;
byte[] v;
org.apache.zookeeper.ZooKeeper$States v, v, v;
java.lang.Integer v;
int[] v, v;
java.lang.Long v;
boolean v, v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading[] v, v;
org.apache.zookeeper.ZooKeeper v;
java.util.concurrent.ConcurrentHashMap v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading v, v;
org.apache.zookeeper.server.quorum.Follower v;
org.apache.zookeeper.server.quorum.LearnerZooKeeperServer v;
java.lang.Throwable v;
org.apache.zookeeper.server.ZKDatabase v;
long v;
java.util.ArrayList v, v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v, v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain v, v;
org.slf4j.Logger v, v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread v, v, v, v;
org.apache.zookeeper.server.quorum.Leader v;
v := @this: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest;
v = (int) -1;
v = v;
v = 2;
label:
if v < 0 goto label;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
v = v[v];
v = v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain main>;
v = v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain: org.apache.zookeeper.server.quorum.QuorumPeer quorumPeer>;
v = v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.quorum.Leader leader>;
if v != null goto label;
v = (int) -1;
if v != v goto label;
v = v;
label:
v = v - 1;
goto label;
label:
v = <org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.slf4j.Logger LOG>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("follower A is {}", v);
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading[] qpMain>;
v = v[v];
virtualinvoke v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading: void setDropCreateSession(boolean)>(1);
v = new org.apache.zookeeper.ZooKeeper;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: int[] clientPorts>;
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>;
specialinvoke v.<org.apache.zookeeper.ZooKeeper: void <init>(java.lang.String,int,org.apache.zookeeper.Watcher)>(v, v, v);
v = <org.apache.zookeeper.ZooKeeper$States: org.apache.zookeeper.ZooKeeper$States CONNECTED>;
staticinvoke <org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: void waitForOne(org.apache.zookeeper.ZooKeeper,org.apache.zookeeper.ZooKeeper$States)>(v, v);
v = virtualinvoke v.<org.apache.zookeeper.ZooKeeper: long getSessionId()>();
label:
v = newarray (byte)[2];
v = <org.apache.zookeeper.ZooDefs$Ids: java.util.ArrayList OPEN_ACL_UNSAFE>;
v = <org.apache.zookeeper.CreateMode: org.apache.zookeeper.CreateMode EPHEMERAL>;
virtualinvoke v.<org.apache.zookeeper.ZooKeeper: java.lang.String create(java.lang.String,byte[],java.util.List,org.apache.zookeeper.CreateMode)>("/node-1", v, v, v);
staticinvoke <org.junit.jupiter.api.Assertions: java.lang.Object fail(java.lang.String)>("expect to failed to upgrade session due to the TestQPMainDropSessionUpgrading is being used");
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Throwable)>("KeeperException when create ephemeral node.", v);
label:
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading[] qpMain>;
v = v[v];
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading: org.apache.zookeeper.server.quorum.QuorumPeer quorumPeer>;
v = v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.quorum.Follower follower>;
v = v.<org.apache.zookeeper.server.quorum.Follower: org.apache.zookeeper.server.quorum.LearnerZooKeeperServer zk>;
virtualinvoke v.<org.apache.zookeeper.server.quorum.LearnerZooKeeperServer: java.io.File takeSnapshot(boolean)>(1);
staticinvoke <java.lang.Thread: void sleep(long)>(500L);
v = 0;
label:
if v >= 3 goto label;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
v = v[v];
virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: void shutdown()>();
v = v + 1;
goto label;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = <org.apache.zookeeper.ZooKeeper$States: org.apache.zookeeper.ZooKeeper$States CONNECTING>;
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
v = <org.apache.zookeeper.ZooKeeper$States: org.apache.zookeeper.ZooKeeper$States CLOSED>;
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
specialinvoke v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: void waitForOne(org.apache.zookeeper.ZooKeeper,java.util.ArrayList)>(v, v);
v = 0;
label:
if v >= 3 goto label;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
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.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: int[] clientPorts>;
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.server.quorum.SessionUpgradeQuorumTest: 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 = 0;
label:
if v >= 3 goto label;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
v = v[v];
v = v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain main>;
v = v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain: org.apache.zookeeper.server.quorum.QuorumPeer quorumPeer>;
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.ZKDatabase getZkDb()>();
v = virtualinvoke v.<org.apache.zookeeper.server.ZKDatabase: java.util.concurrent.ConcurrentHashMap getSessionWithTimeOuts()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = virtualinvoke v.<java.util.concurrent.ConcurrentHashMap: boolean containsKey(java.lang.Object)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,long)>(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 \u should not have global session \u0001");
staticinvoke <org.junit.jupiter.api.Assertions: void assertFalse(boolean,java.lang.String)>(v, v);
v = v + 1;
goto label;
label:
virtualinvoke v.<org.apache.zookeeper.ZooKeeper: void close()>();
return;
catch org.apache.zookeeper.KeeperException from label to label with label;
}
public void testOnlyUpgradeSessionOnce() throws java.io.IOException, java.lang.InterruptedException, org.apache.zookeeper.KeeperException
{
org.apache.zookeeper.server.quorum.QuorumPeer v;
org.apache.zookeeper.ZooKeeper$States v;
long v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v;
int[] v;
int v, v;
java.lang.String v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain v;
org.apache.zookeeper.ZooKeeper v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread v;
org.apache.zookeeper.server.Request v, v, v, v;
org.apache.zookeeper.server.ZooKeeperServer v;
v := @this: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest;
v = new org.apache.zookeeper.ZooKeeper;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: int[] clientPorts>;
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.ZooKeeper$States: org.apache.zookeeper.ZooKeeper$States CONNECTED>;
staticinvoke <org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: void waitForOne(org.apache.zookeeper.ZooKeeper,org.apache.zookeeper.ZooKeeper$States)>(v, v);
v = virtualinvoke v.<org.apache.zookeeper.ZooKeeper: long getSessionId()>();
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
v = v[0];
v = v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain main>;
v = v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain: org.apache.zookeeper.server.quorum.QuorumPeer quorumPeer>;
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.ZooKeeperServer getActiveServer()>();
v = specialinvoke v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.Request createEphemeralRequest(java.lang.String,long)>("/data-1", v);
v = specialinvoke v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.Request createEphemeralRequest(java.lang.String,long)>("/data-2", v);
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumZooKeeperServer: org.apache.zookeeper.server.Request checkUpgradeSession(org.apache.zookeeper.server.Request)>(v);
staticinvoke <org.junit.jupiter.api.Assertions: void assertNotNull(java.lang.Object,java.lang.String)>(v, "failed to upgrade on a ephemeral create");
v = virtualinvoke v.<org.apache.zookeeper.server.quorum.QuorumZooKeeperServer: org.apache.zookeeper.server.Request checkUpgradeSession(org.apache.zookeeper.server.Request)>(v);
staticinvoke <org.junit.jupiter.api.Assertions: void assertNull(java.lang.Object,java.lang.String)>(v, "tried to upgrade again");
virtualinvoke v.<org.apache.zookeeper.ZooKeeper: void close()>();
return;
}
public void testCloseSessionWhileUpgradeOnLeader() throws java.io.IOException, org.apache.zookeeper.KeeperException, java.lang.InterruptedException
{
org.apache.zookeeper.server.quorum.QuorumPeer v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread v;
org.apache.zookeeper.server.quorum.Leader v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v;
int v, v, v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain v;
v := @this: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest;
v = (int) -1;
v = v;
v = 2;
label:
if v < 0 goto label;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
v = v[v];
v = v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain main>;
v = v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain: org.apache.zookeeper.server.quorum.QuorumPeer quorumPeer>;
v = v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.quorum.Leader leader>;
if v == null goto label;
v = v;
label:
v = v - 1;
goto label;
label:
if v <= 0 goto label;
specialinvoke v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: void makeSureEphemeralIsGone(int)>(v);
label:
return;
}
public void testCloseSessionWhileUpgradeOnLearner() throws java.io.IOException, org.apache.zookeeper.KeeperException, java.lang.InterruptedException
{
org.apache.zookeeper.server.quorum.QuorumPeer v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread v;
org.apache.zookeeper.server.quorum.Follower v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] v;
int v, v, v;
org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain v;
v := @this: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest;
v = (int) -1;
v = v;
v = 2;
label:
if v < 0 goto label;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread[] mt>;
v = v[v];
v = v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$MainThread: org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain main>;
v = v.<org.apache.zookeeper.server.quorum.QuorumPeerTestBase$TestQPMain: org.apache.zookeeper.server.quorum.QuorumPeer quorumPeer>;
v = v.<org.apache.zookeeper.server.quorum.QuorumPeer: org.apache.zookeeper.server.quorum.Follower follower>;
if v == null goto label;
v = v;
label:
v = v - 1;
goto label;
label:
if v <= 0 goto label;
specialinvoke v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: void makeSureEphemeralIsGone(int)>(v);
label:
return;
}
private void makeSureEphemeralIsGone(int) throws java.io.IOException, org.apache.zookeeper.KeeperException, java.lang.InterruptedException
{
org.apache.zookeeper.CreateMode v;
byte[] v;
org.apache.zookeeper.ZooKeeper$States v, v;
org.apache.zookeeper.data.Stat v;
java.util.ArrayList v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest v;
int[] v, v;
int v, v, v, v, v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$2 v;
java.lang.String v, v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading[] v;
org.apache.zookeeper.ZooKeeper v, v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading v;
v := @this: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest;
v := @parameter: int;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading[] qpMain>;
v = v[v];
virtualinvoke v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$TestQPMainDropSessionUpgrading: void setSubmitDelayMs(int)>(200);
v = new org.apache.zookeeper.ZooKeeper;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: int[] clientPorts>;
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>;
specialinvoke v.<org.apache.zookeeper.ZooKeeper: void <init>(java.lang.String,int,org.apache.zookeeper.Watcher)>(v, v, v);
v = <org.apache.zookeeper.ZooKeeper$States: org.apache.zookeeper.ZooKeeper$States CONNECTED>;
staticinvoke <org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: void waitForOne(org.apache.zookeeper.ZooKeeper,org.apache.zookeeper.ZooKeeper$States)>(v, v);
v = newarray (byte)[2];
v = <org.apache.zookeeper.ZooDefs$Ids: java.util.ArrayList OPEN_ACL_UNSAFE>;
v = <org.apache.zookeeper.CreateMode: org.apache.zookeeper.CreateMode EPHEMERAL>;
v = new org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$2;
specialinvoke v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest$2: void <init>(org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest)>(v);
virtualinvoke v.<org.apache.zookeeper.ZooKeeper: void create(java.lang.String,byte[],java.util.List,org.apache.zookeeper.CreateMode,org.apache.zookeeper.AsyncCallback$StringCallback,java.lang.Object)>("/node-1", v, v, v, v, null);
virtualinvoke v.<org.apache.zookeeper.ZooKeeper: void close()>();
v = new org.apache.zookeeper.ZooKeeper;
v = v.<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: int[] clientPorts>;
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>;
specialinvoke v.<org.apache.zookeeper.ZooKeeper: void <init>(java.lang.String,int,org.apache.zookeeper.Watcher)>(v, v, v);
v = <org.apache.zookeeper.ZooKeeper$States: org.apache.zookeeper.ZooKeeper$States CONNECTED>;
staticinvoke <org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: void waitForOne(org.apache.zookeeper.ZooKeeper,org.apache.zookeeper.ZooKeeper$States)>(v, v);
v = virtualinvoke v.<org.apache.zookeeper.ZooKeeper: org.apache.zookeeper.data.Stat exists(java.lang.String,boolean)>("/node-1", 0);
staticinvoke <org.junit.jupiter.api.Assertions: void assertNull(java.lang.Object)>(v);
virtualinvoke v.<org.apache.zookeeper.ZooKeeper: void close()>();
return;
}
private void waitForOne(org.apache.zookeeper.ZooKeeper, java.util.ArrayList) throws java.lang.InterruptedException
{
org.apache.zookeeper.ZooKeeper v;
org.slf4j.Logger v;
org.apache.zookeeper.ZooKeeper$States v, v;
java.lang.RuntimeException v;
java.util.ArrayList v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest v;
int v, v, v;
boolean v;
v := @this: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest;
v := @parameter: org.apache.zookeeper.ZooKeeper;
v := @parameter: java.util.ArrayList;
v = <org.apache.zookeeper.test.ClientBase: int CONNECTION_TIMEOUT>;
v = v / 500;
label:
v = virtualinvoke v.<org.apache.zookeeper.ZooKeeper: org.apache.zookeeper.ZooKeeper$States getState()>();
v = virtualinvoke v.<java.util.ArrayList: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = v;
v = v - 1;
if v != 0 goto label;
v = <org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.zookeeper.ZooKeeper: org.apache.zookeeper.ZooKeeper$States getState()>();
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("state is {}", v);
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.String)>("Waiting too long");
throw v;
label:
staticinvoke <java.lang.Thread: void sleep(long)>(500L);
goto label;
label:
return;
}
private org.apache.zookeeper.server.Request createEphemeralRequest(java.lang.String, long) throws java.io.IOException
{
org.apache.zookeeper.CreateMode v;
byte[] v, v;
org.apache.jute.BinaryOutputArchive v;
java.io.ByteArrayOutputStream v;
org.apache.zookeeper.proto.CreateRequest v;
long v;
java.nio.ByteBuffer v;
java.util.ArrayList v, v;
org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest v;
int v;
org.apache.zookeeper.server.RequestRecord v;
java.lang.String v, v;
org.apache.zookeeper.server.Request v;
v := @this: org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest;
v := @parameter: java.lang.String;
v := @parameter: long;
v = new java.io.ByteArrayOutputStream;
specialinvoke v.<java.io.ByteArrayOutputStream: void <init>()>();
v = staticinvoke <org.apache.jute.BinaryOutputArchive: org.apache.jute.BinaryOutputArchive getArchive(java.io.OutputStream)>(v);
v = new org.apache.zookeeper.proto.CreateRequest;
v = "data";
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 EPHEMERAL>;
v = virtualinvoke v.<org.apache.zookeeper.CreateMode: int toFlag()>();
specialinvoke v.<org.apache.zookeeper.proto.CreateRequest: void <init>(java.lang.String,byte[],java.util.List,int)>(v, v, v, v);
virtualinvoke v.<org.apache.zookeeper.proto.CreateRequest: void serialize(org.apache.jute.OutputArchive,java.lang.String)>(v, "request");
v = virtualinvoke v.<java.io.ByteArrayOutputStream: byte[] toByteArray()>();
v = staticinvoke <java.nio.ByteBuffer: java.nio.ByteBuffer wrap(byte[])>(v);
v = new org.apache.zookeeper.server.Request;
v = staticinvoke <org.apache.zookeeper.server.RequestRecord: org.apache.zookeeper.server.RequestRecord fromBytes(java.nio.ByteBuffer)>(v);
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
specialinvoke v.<org.apache.zookeeper.server.Request: void <init>(org.apache.zookeeper.server.ServerCnxn,long,int,int,org.apache.zookeeper.server.RequestRecord,java.util.List)>(null, v, 1, 15, v, v);
return v;
}
static void <clinit>()
{
int v;
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/zookeeper/server/quorum/SessionUpgradeQuorumTest;");
<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: org.slf4j.Logger LOG> = v;
v = <org.apache.zookeeper.test.ClientBase: int CONNECTION_TIMEOUT>;
<org.apache.zookeeper.server.quorum.SessionUpgradeQuorumTest: int CONNECTION_TIMEOUT> = v;
return;
}
}