public class org.apache.kafkaesque.clients.producer.MockProducer extends java.lang.Object implements org.apache.kafkaesque.clients.producer.Producer
{
private final org.apache.kafkaesque.common.Cluster cluster;
private final org.apache.kafkaesque.clients.producer.Partitioner partitioner;
private final java.util.List sent;
private final java.util.List uncommittedSends;
private final java.util.Deque completions;
private final java.util.Map offsets;
private final java.util.List consumerGroupOffsets;
private java.util.Map uncommittedConsumerGroupOffsets;
private final org.apache.kafkaesque.common.serialization.Serializer keySerializer;
private final org.apache.kafkaesque.common.serialization.Serializer valueSerializer;
private boolean autoComplete;
private boolean closed;
private boolean transactionInitialized;
private boolean transactionInFlight;
private boolean transactionCommitted;
private boolean transactionAborted;
private boolean producerFenced;
private boolean producerFencedOnClose;
private boolean sentOffsets;
private long commitCount;
private java.util.Map mockMetrics;
public void <init>(org.apache.kafkaesque.common.Cluster, boolean, org.apache.kafkaesque.clients.producer.Partitioner, org.apache.kafkaesque.common.serialization.Serializer, org.apache.kafkaesque.common.serialization.Serializer)
{
org.apache.kafkaesque.clients.producer.Partitioner v;
org.apache.kafkaesque.common.Cluster v;
java.util.HashMap v, v, v;
org.apache.kafkaesque.clients.producer.MockProducer v;
java.util.ArrayList v, v, v;
java.util.ArrayDeque v;
org.apache.kafkaesque.common.serialization.Serializer v, v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: org.apache.kafkaesque.common.Cluster;
v := @parameter: boolean;
v := @parameter: org.apache.kafkaesque.clients.producer.Partitioner;
v := @parameter: org.apache.kafkaesque.common.serialization.Serializer;
v := @parameter: org.apache.kafkaesque.common.serialization.Serializer;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: long commitCount> = 0L;
v.<org.apache.kafkaesque.clients.producer.MockProducer: org.apache.kafkaesque.common.Cluster cluster> = v;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean autoComplete> = v;
v.<org.apache.kafkaesque.clients.producer.MockProducer: org.apache.kafkaesque.clients.producer.Partitioner partitioner> = v;
v.<org.apache.kafkaesque.clients.producer.MockProducer: org.apache.kafkaesque.common.serialization.Serializer keySerializer> = v;
v.<org.apache.kafkaesque.clients.producer.MockProducer: org.apache.kafkaesque.common.serialization.Serializer valueSerializer> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map offsets> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List sent> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List uncommittedSends> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List consumerGroupOffsets> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map uncommittedConsumerGroupOffsets> = v;
v = new java.util.ArrayDeque;
specialinvoke v.<java.util.ArrayDeque: void <init>()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Deque completions> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map mockMetrics> = v;
return;
}
public void <init>(boolean, org.apache.kafkaesque.common.serialization.Serializer, org.apache.kafkaesque.common.serialization.Serializer)
{
org.apache.kafkaesque.clients.producer.internals.DefaultPartitioner v;
org.apache.kafkaesque.common.Cluster v;
org.apache.kafkaesque.clients.producer.MockProducer v;
org.apache.kafkaesque.common.serialization.Serializer v, v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: boolean;
v := @parameter: org.apache.kafkaesque.common.serialization.Serializer;
v := @parameter: org.apache.kafkaesque.common.serialization.Serializer;
v = staticinvoke <org.apache.kafkaesque.common.Cluster: org.apache.kafkaesque.common.Cluster empty()>();
v = new org.apache.kafkaesque.clients.producer.internals.DefaultPartitioner;
specialinvoke v.<org.apache.kafkaesque.clients.producer.internals.DefaultPartitioner: void <init>()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void <init>(org.apache.kafkaesque.common.Cluster,boolean,org.apache.kafkaesque.clients.producer.Partitioner,org.apache.kafkaesque.common.serialization.Serializer,org.apache.kafkaesque.common.serialization.Serializer)>(v, v, v, v, v);
return;
}
public void <init>(boolean, org.apache.kafkaesque.clients.producer.Partitioner, org.apache.kafkaesque.common.serialization.Serializer, org.apache.kafkaesque.common.serialization.Serializer)
{
org.apache.kafkaesque.clients.producer.Partitioner v;
org.apache.kafkaesque.common.Cluster v;
org.apache.kafkaesque.clients.producer.MockProducer v;
org.apache.kafkaesque.common.serialization.Serializer v, v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: boolean;
v := @parameter: org.apache.kafkaesque.clients.producer.Partitioner;
v := @parameter: org.apache.kafkaesque.common.serialization.Serializer;
v := @parameter: org.apache.kafkaesque.common.serialization.Serializer;
v = staticinvoke <org.apache.kafkaesque.common.Cluster: org.apache.kafkaesque.common.Cluster empty()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void <init>(org.apache.kafkaesque.common.Cluster,boolean,org.apache.kafkaesque.clients.producer.Partitioner,org.apache.kafkaesque.common.serialization.Serializer,org.apache.kafkaesque.common.serialization.Serializer)>(v, v, v, v, v);
return;
}
public void <init>()
{
org.apache.kafkaesque.common.Cluster v;
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = staticinvoke <org.apache.kafkaesque.common.Cluster: org.apache.kafkaesque.common.Cluster empty()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void <init>(org.apache.kafkaesque.common.Cluster,boolean,org.apache.kafkaesque.clients.producer.Partitioner,org.apache.kafkaesque.common.serialization.Serializer,org.apache.kafkaesque.common.serialization.Serializer)>(v, 0, null, null, null);
return;
}
public void initTransactions()
{
java.lang.IllegalStateException v;
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyProducerState()>();
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInitialized>;
if v == 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("MockProducer has already been initialized for transactions.");
throw v;
label:
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInitialized> = 1;
return;
}
public void beginTransaction() throws org.apache.kafkaesque.common.errors.ProducerFencedException
{
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyProducerState()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyTransactionsInitialized()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInFlight> = 1;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionCommitted> = 0;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionAborted> = 0;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean sentOffsets> = 0;
return;
}
public void sendOffsetsToTransaction(java.util.Map, java.lang.String) throws org.apache.kafkaesque.common.errors.ProducerFencedException
{
java.util.HashMap v;
org.apache.kafkaesque.clients.producer.MockProducer v;
java.util.Map v, v, v;
int v;
java.lang.Object v;
java.lang.String v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: java.util.Map;
v := @parameter: java.lang.String;
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyProducerState()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyTransactionsInitialized()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyNoTransactionInFlight()>();
v = interfaceinvoke v.<java.util.Map: int size()>();
if v != 0 goto label;
return;
label:
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map uncommittedConsumerGroupOffsets>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = v;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map uncommittedConsumerGroupOffsets>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean sentOffsets> = 1;
return;
}
public void sendOffsetsToTransaction(java.util.Map, org.apache.kafkaesque.clients.consumer.ConsumerGroupMetadata) throws org.apache.kafkaesque.common.errors.ProducerFencedException
{
org.apache.kafkaesque.clients.consumer.ConsumerGroupMetadata v;
java.util.Map v;
java.lang.String v;
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: java.util.Map;
v := @parameter: org.apache.kafkaesque.clients.consumer.ConsumerGroupMetadata;
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<org.apache.kafkaesque.clients.consumer.ConsumerGroupMetadata: java.lang.String groupId()>();
virtualinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void sendOffsetsToTransaction(java.util.Map,java.lang.String)>(v, v);
return;
}
public void commitTransaction() throws org.apache.kafkaesque.common.errors.ProducerFencedException
{
java.util.HashMap v;
long v, v;
org.apache.kafkaesque.clients.producer.MockProducer v;
java.util.List v, v, v, v;
java.util.Map v, v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyProducerState()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyTransactionsInitialized()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyNoTransactionInFlight()>();
virtualinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void flush()>();
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List sent>;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List uncommittedSends>;
interfaceinvoke v.<java.util.List: boolean addAll(java.util.Collection)>(v);
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map uncommittedConsumerGroupOffsets>;
v = interfaceinvoke v.<java.util.Map: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List consumerGroupOffsets>;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map uncommittedConsumerGroupOffsets>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List uncommittedSends>;
interfaceinvoke v.<java.util.List: void clear()>();
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map uncommittedConsumerGroupOffsets> = v;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionCommitted> = 1;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionAborted> = 0;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInFlight> = 0;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: long commitCount>;
v = v + 1L;
v.<org.apache.kafkaesque.clients.producer.MockProducer: long commitCount> = v;
return;
}
public void abortTransaction() throws org.apache.kafkaesque.common.errors.ProducerFencedException
{
java.util.List v;
org.apache.kafkaesque.clients.producer.MockProducer v;
java.util.Map v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyProducerState()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyTransactionsInitialized()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyNoTransactionInFlight()>();
virtualinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void flush()>();
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List uncommittedSends>;
interfaceinvoke v.<java.util.List: void clear()>();
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map uncommittedConsumerGroupOffsets>;
interfaceinvoke v.<java.util.Map: void clear()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionCommitted> = 0;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionAborted> = 1;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInFlight> = 0;
return;
}
private synchronized void verifyProducerState()
{
java.lang.IllegalStateException v;
org.apache.kafkaesque.common.errors.ProducerFencedException v;
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v, v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean closed>;
if v == 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("MockProducer is already closed.");
throw v;
label:
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean producerFenced>;
if v == 0 goto label;
v = new org.apache.kafkaesque.common.errors.ProducerFencedException;
specialinvoke v.<org.apache.kafkaesque.common.errors.ProducerFencedException: void <init>(java.lang.String)>("MockProducer is fenced.");
throw v;
label:
return;
}
private void verifyTransactionsInitialized()
{
java.lang.IllegalStateException v;
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInitialized>;
if v != 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("MockProducer hasn\'t been initialized for transactions.");
throw v;
label:
return;
}
private void verifyNoTransactionInFlight()
{
java.lang.IllegalStateException v;
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInFlight>;
if v != 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("There is no open transaction.");
throw v;
label:
return;
}
public synchronized java.util.concurrent.Future send(org.apache.kafkaesque.clients.producer.ProducerRecord)
{
java.util.concurrent.Future v;
org.apache.kafkaesque.clients.producer.ProducerRecord v;
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: org.apache.kafkaesque.clients.producer.ProducerRecord;
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.concurrent.Future send(org.apache.kafkaesque.clients.producer.ProducerRecord,org.apache.kafkaesque.clients.producer.Callback)>(v, null);
return v;
}
public synchronized java.util.concurrent.Future send(org.apache.kafkaesque.clients.producer.ProducerRecord, org.apache.kafkaesque.clients.producer.Callback)
{
java.lang.IllegalStateException v;
org.apache.kafkaesque.clients.producer.ProducerRecord v;
org.apache.kafkaesque.common.TopicPartition v;
org.apache.kafkaesque.common.errors.ProducerFencedException v;
org.apache.kafkaesque.common.Cluster v, v;
long v;
java.util.Deque v;
org.apache.kafkaesque.clients.producer.MockProducer v;
org.apache.kafkaesque.clients.producer.internals.FutureRecordMetadata v;
java.lang.Long v, v;
int v;
org.apache.kafkaesque.common.KafkaException v;
org.apache.kafkaesque.common.utils.Time v;
java.lang.String v, v;
boolean v, v, v, v, v;
org.apache.kafkaesque.clients.producer.Callback v;
org.apache.kafkaesque.clients.producer.RecordMetadata v;
java.util.List v, v, v;
org.apache.kafkaesque.clients.producer.MockProducer$Completion v;
org.apache.kafkaesque.clients.producer.internals.ProduceRequestResult v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: org.apache.kafkaesque.clients.producer.ProducerRecord;
v := @parameter: org.apache.kafkaesque.clients.producer.Callback;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean closed>;
if v == 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("MockProducer is already closed.");
throw v;
label:
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean producerFenced>;
if v == 0 goto label;
v = new org.apache.kafkaesque.common.KafkaException;
v = new org.apache.kafkaesque.common.errors.ProducerFencedException;
specialinvoke v.<org.apache.kafkaesque.common.errors.ProducerFencedException: void <init>(java.lang.String)>("Fenced");
specialinvoke v.<org.apache.kafkaesque.common.KafkaException: void <init>(java.lang.String,java.lang.Throwable)>("MockProducer is fenced.", v);
throw v;
label:
v = 0;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: org.apache.kafkaesque.common.Cluster cluster>;
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.ProducerRecord: java.lang.String topic()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.Cluster: java.util.List partitionsForTopic(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: org.apache.kafkaesque.common.Cluster cluster>;
v = specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: int partition(org.apache.kafkaesque.clients.producer.ProducerRecord,org.apache.kafkaesque.common.Cluster)>(v, v);
label:
v = new org.apache.kafkaesque.common.TopicPartition;
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.ProducerRecord: java.lang.String topic()>();
specialinvoke v.<org.apache.kafkaesque.common.TopicPartition: void <init>(java.lang.String,int)>(v, v);
v = new org.apache.kafkaesque.clients.producer.internals.ProduceRequestResult;
specialinvoke v.<org.apache.kafkaesque.clients.producer.internals.ProduceRequestResult: void <init>(org.apache.kafkaesque.common.TopicPartition)>(v);
v = new org.apache.kafkaesque.clients.producer.internals.FutureRecordMetadata;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(0L);
v = <org.apache.kafkaesque.common.utils.Time: org.apache.kafkaesque.common.utils.Time SYSTEM>;
specialinvoke v.<org.apache.kafkaesque.clients.producer.internals.FutureRecordMetadata: void <init>(org.apache.kafkaesque.clients.producer.internals.ProduceRequestResult,long,long,java.lang.Long,int,int,org.apache.kafkaesque.common.utils.Time)>(v, 0L, -1L, v, 0, 0, v);
v = specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: long nextOffset(org.apache.kafkaesque.common.TopicPartition)>(v);
v = new org.apache.kafkaesque.clients.producer.MockProducer$Completion;
v = new org.apache.kafkaesque.clients.producer.RecordMetadata;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(0L);
specialinvoke v.<org.apache.kafkaesque.clients.producer.RecordMetadata: void <init>(org.apache.kafkaesque.common.TopicPartition,long,long,long,java.lang.Long,int,int)>(v, 0L, v, -1L, v, 0, 0);
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer$Completion: void <init>(long,org.apache.kafkaesque.clients.producer.RecordMetadata,org.apache.kafkaesque.clients.producer.internals.ProduceRequestResult,org.apache.kafkaesque.clients.producer.Callback)>(v, v, v, v);
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInFlight>;
if v != 0 goto label;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List sent>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List uncommittedSends>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean autoComplete>;
if v == 0 goto label;
virtualinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer$Completion: void complete(java.lang.RuntimeException)>(null);
goto label;
label:
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Deque completions>;
interfaceinvoke v.<java.util.Deque: void addLast(java.lang.Object)>(v);
label:
return v;
}
private long nextOffset(org.apache.kafkaesque.common.TopicPartition)
{
org.apache.kafkaesque.common.TopicPartition v;
long v, v, v;
org.apache.kafkaesque.clients.producer.MockProducer v;
java.lang.Long v, v;
java.util.Map v, v, v;
java.lang.Object v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: org.apache.kafkaesque.common.TopicPartition;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map offsets>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map offsets>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(1L);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
return 0L;
label:
v = virtualinvoke v.<java.lang.Long: long longValue()>();
v = v + 1L;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map offsets>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = virtualinvoke v.<java.lang.Long: long longValue()>();
return v;
}
public synchronized void flush()
{
java.util.Deque v;
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyProducerState()>();
label:
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Deque completions>;
v = interfaceinvoke v.<java.util.Deque: boolean isEmpty()>();
if v != 0 goto label;
virtualinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean completeNext()>();
goto label;
label:
return;
}
public java.util.List partitionsFor(java.lang.String)
{
java.util.List v;
org.apache.kafkaesque.common.Cluster v;
java.lang.String v;
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: java.lang.String;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: org.apache.kafkaesque.common.Cluster cluster>;
v = virtualinvoke v.<org.apache.kafkaesque.common.Cluster: java.util.List partitionsForTopic(java.lang.String)>(v);
return v;
}
public java.util.Map metrics()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
java.util.Map v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map mockMetrics>;
return v;
}
public void setMockMetrics(org.apache.kafkaesque.common.MetricName, org.apache.kafkaesque.common.Metric)
{
org.apache.kafkaesque.common.Metric v;
org.apache.kafkaesque.common.MetricName v;
java.util.Map v;
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: org.apache.kafkaesque.common.MetricName;
v := @parameter: org.apache.kafkaesque.common.Metric;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map mockMetrics>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
return;
}
public void close()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
java.time.Duration v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = staticinvoke <java.time.Duration: java.time.Duration ofMillis(long)>(0L);
virtualinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void close(java.time.Duration)>(v);
return;
}
public void close(java.time.Duration)
{
java.time.Duration v;
org.apache.kafkaesque.common.errors.ProducerFencedException v;
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: java.time.Duration;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean producerFencedOnClose>;
if v == 0 goto label;
v = new org.apache.kafkaesque.common.errors.ProducerFencedException;
specialinvoke v.<org.apache.kafkaesque.common.errors.ProducerFencedException: void <init>(java.lang.String)>("MockProducer is fenced.");
throw v;
label:
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean closed> = 1;
return;
}
public boolean closed()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean closed>;
return v;
}
public synchronized void fenceProducer()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyProducerState()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyTransactionsInitialized()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean producerFenced> = 1;
return;
}
public void fenceProducerOnClose()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyProducerState()>();
specialinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: void verifyTransactionsInitialized()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean producerFencedOnClose> = 1;
return;
}
public boolean transactionInitialized()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInitialized>;
return v;
}
public boolean transactionInFlight()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInFlight>;
return v;
}
public boolean transactionCommitted()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionCommitted>;
return v;
}
public boolean transactionAborted()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionAborted>;
return v;
}
public boolean flushed()
{
java.util.Deque v;
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Deque completions>;
v = interfaceinvoke v.<java.util.Deque: boolean isEmpty()>();
return v;
}
public boolean sentOffsets()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean sentOffsets>;
return v;
}
public long commitCount()
{
long v;
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: long commitCount>;
return v;
}
public synchronized java.util.List history()
{
java.util.List v;
org.apache.kafkaesque.clients.producer.MockProducer v;
java.util.ArrayList v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = new java.util.ArrayList;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List sent>;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
return v;
}
public synchronized java.util.List consumerGroupOffsetsHistory()
{
java.util.List v;
org.apache.kafkaesque.clients.producer.MockProducer v;
java.util.ArrayList v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = new java.util.ArrayList;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List consumerGroupOffsets>;
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
return v;
}
public synchronized void clear()
{
java.util.List v, v, v;
java.util.Map v;
java.util.Deque v;
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List sent>;
interfaceinvoke v.<java.util.List: void clear()>();
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List uncommittedSends>;
interfaceinvoke v.<java.util.List: void clear()>();
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Deque completions>;
interfaceinvoke v.<java.util.Deque: void clear()>();
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.List consumerGroupOffsets>;
interfaceinvoke v.<java.util.List: void clear()>();
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Map uncommittedConsumerGroupOffsets>;
interfaceinvoke v.<java.util.Map: void clear()>();
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInitialized> = 0;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionInFlight> = 0;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionCommitted> = 0;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean transactionAborted> = 0;
v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean producerFenced> = 0;
return;
}
public synchronized boolean completeNext()
{
org.apache.kafkaesque.clients.producer.MockProducer v;
boolean v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer: boolean errorNext(java.lang.RuntimeException)>(null);
return v;
}
public synchronized boolean errorNext(java.lang.RuntimeException)
{
java.lang.Object v;
java.lang.RuntimeException v;
java.util.Deque v;
org.apache.kafkaesque.clients.producer.MockProducer v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: java.lang.RuntimeException;
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: java.util.Deque completions>;
v = interfaceinvoke v.<java.util.Deque: java.lang.Object pollFirst()>();
if v == null goto label;
virtualinvoke v.<org.apache.kafkaesque.clients.producer.MockProducer$Completion: void complete(java.lang.RuntimeException)>(v);
return 1;
label:
return 0;
}
private int partition(org.apache.kafkaesque.clients.producer.ProducerRecord, org.apache.kafkaesque.common.Cluster)
{
byte[] v, v;
org.apache.kafkaesque.clients.producer.ProducerRecord v;
org.apache.kafkaesque.common.Cluster v;
java.lang.Integer v;
org.apache.kafkaesque.clients.producer.MockProducer v;
int v, v, v, v, v;
java.lang.String v, v;
org.apache.kafkaesque.common.header.Headers v, v;
org.apache.kafkaesque.common.serialization.Serializer v, v;
org.apache.kafkaesque.clients.producer.Partitioner v;
java.lang.IllegalArgumentException v;
java.util.List v;
java.lang.Object v, v, v, v;
v := @this: org.apache.kafkaesque.clients.producer.MockProducer;
v := @parameter: org.apache.kafkaesque.clients.producer.ProducerRecord;
v := @parameter: org.apache.kafkaesque.common.Cluster;
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.ProducerRecord: java.lang.Integer partition()>();
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.ProducerRecord: java.lang.String topic()>();
if v == null goto label;
v = virtualinvoke v.<org.apache.kafkaesque.common.Cluster: java.util.List partitionsForTopic(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
if v < 0 goto label;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
if v < v goto label;
label:
v = new java.lang.IllegalArgumentException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Integer,int)>(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[])>("Invalid partition given with record: \u is not in the range [0...\u].");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
return v;
label:
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: org.apache.kafkaesque.common.serialization.Serializer keySerializer>;
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.ProducerRecord: org.apache.kafkaesque.common.header.Headers headers()>();
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.ProducerRecord: java.lang.Object key()>();
v = interfaceinvoke v.<org.apache.kafkaesque.common.serialization.Serializer: byte[] serialize(java.lang.String,org.apache.kafkaesque.common.header.Headers,java.lang.Object)>(v, v, v);
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: org.apache.kafkaesque.common.serialization.Serializer valueSerializer>;
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.ProducerRecord: org.apache.kafkaesque.common.header.Headers headers()>();
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.ProducerRecord: java.lang.Object value()>();
v = interfaceinvoke v.<org.apache.kafkaesque.common.serialization.Serializer: byte[] serialize(java.lang.String,org.apache.kafkaesque.common.header.Headers,java.lang.Object)>(v, v, v);
v = v.<org.apache.kafkaesque.clients.producer.MockProducer: org.apache.kafkaesque.clients.producer.Partitioner partitioner>;
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.ProducerRecord: java.lang.Object key()>();
v = virtualinvoke v.<org.apache.kafkaesque.clients.producer.ProducerRecord: java.lang.Object value()>();
v = interfaceinvoke v.<org.apache.kafkaesque.clients.producer.Partitioner: int partition(java.lang.String,java.lang.Object,byte[],java.lang.Object,byte[],org.apache.kafkaesque.common.Cluster)>(v, v, v, v, v, v);
return v;
}
}