@Override public AfterOperationEvent create(final IValueDeserializer deserializer) { return new AfterOperationEvent(deserializer); }
/** * {@inheritDoc} */ @Override public int hashCode() { int code = 0; code += ((int)this.getTimestamp()); code += ((int)this.getTraceId()); code += ((int)this.getOrderIndex()); code += this.getOperationSignature().hashCode(); code += this.getClassSignature().hashCode(); return code; }
/** * {@inheritDoc} */ @Override public void registerStrings(final IRegistry<String> stringRegistry) { // NOPMD (generated code) stringRegistry.get(this.getOperationSignature()); stringRegistry.get(this.getClassSignature()); } /**
/** * Tests the constructor and writeBytes(..) methods of {@link AfterOperationEvent}. */ @Test public void testSerializeDeserializeBinaryEquals() { final AfterOperationEvent event1 = new AfterOperationEvent(TSTAMP, TRACE_ID, ORDER_INDEX, FQ_OPERATION_SIGNATURE, FQ_CLASSNAME); Assert.assertEquals("Unexpected timestamp", TSTAMP, event1.getTimestamp()); Assert.assertEquals("Unexpected trace ID", TRACE_ID, event1.getTraceId()); Assert.assertEquals("Unexpected order index", ORDER_INDEX, event1.getOrderIndex()); Assert.assertEquals("Unexpected class name", FQ_CLASSNAME, event1.getClassSignature()); Assert.assertEquals("Unexpected operation signature", FQ_OPERATION_SIGNATURE, event1.getOperationSignature()); final WriterListener receiver = new WriterListener(); final IWriterRegistry<String> stringRegistry = new WriterRegistry(receiver); final ByteBuffer buffer = ByteBuffer.allocate(event1.getSize()); event1.serialize(BinaryValueSerializer.create(buffer, stringRegistry)); buffer.flip(); final AfterOperationEvent event2 = new AfterOperationEvent(BinaryValueDeserializer.create(buffer, receiver.getReaderRegistry())); Assert.assertEquals(event1, event2); Assert.assertEquals(0, event1.compareTo(event2)); Assert.assertTrue(UtilityClass.refersToSameOperationAs(event1, event2)); }
final AfterOperationEvent kiekerAfter = (AfterOperationEvent) kiekerRecord; buffer.put(AFTER_OPERATION_CLAZZ_ID); buffer.putLong(kiekerAfter.getTimestamp()); buffer.putLong(kiekerAfter.getTraceId()); buffer.putInt(kiekerAfter.getOrderIndex()); } else if (kiekerRecord instanceof HostApplicationMetaData) { final HostApplicationMetaData record = (HostApplicationMetaData) kiekerRecord;
this.eventQueue.add(event); } else if (event instanceof AfterOperationEvent) { while ((!this.beforeEventStack.getLast().getOperationSignature().equals(((AfterOperationEvent) event).getOperationSignature())) && (!(this.beforeEventStack.getLast().getClassSignature()).equals(((AfterOperationEvent) event).getClassSignature()))) { final BeforeOperationEvent beforeEvent = this.beforeEventStack.getLast(); final String opSignature = beforeEvent.getOperationSignature(); ((BeforeOperationObjectEvent) this.beforeEventStack.getLast()).getObjectId())); } else { this.eventQueue.add(new AfterOperationEvent(timestamp, traceID, orderIndex, opSignature, classSignature)); this.eventQueue.add(event); } else { final String opSignature = ((AfterOperationEvent) event).getOperationSignature(); final String classSignature = ((AfterOperationEvent) event).getClassSignature(); final long timestamp = event.getTimestamp(); final long traceID = event.getTraceId(); ((AfterOperationFailedEvent) event).getCause())); } else { this.eventQueue.add(new AfterOperationEvent(timestamp, traceID, orderIndex, opSignature, classSignature));
final AfterOperationEvent newEvent = new AfterOperationEvent(originalEvent.getTimestamp(), monitoredTrace.identifier, originalEvent.getOrderIndex(), originalEvent.getOperationSignature(), originalEvent.getClassSignature()); newEvent.setLoggingTimestamp(originalEvent.getLoggingTimestamp());
executionInformation.getEss(), beforeOperationEvent.getTimestamp(), afterOperationEvent.getTimestamp(), !(definiteCall || this.ignoreAssumedCalls), beforeOperationEvent instanceof BeforeConstructorEvent);
public void handleAfterOperationEvent(final AfterOperationEvent event) { this.hostnameRepository.dec(event.getTraceId()); }
final AfterOperationEvent kiekerAfter = (AfterOperationEvent) kiekerRecord; buffer.put(AFTER_OPERATION_CLAZZ_ID); buffer.putLong(kiekerAfter.getTimestamp()); buffer.putLong(kiekerAfter.getTraceId()); buffer.putInt(kiekerAfter.getOrderIndex()); } else if (kiekerRecord instanceof HostApplicationMetaData) { final HostApplicationMetaData record = (HostApplicationMetaData) kiekerRecord;
} else if (event instanceof AfterOperationEvent) { while ((!this.beforeEventStack.getLast().getOperationSignature() .equals(((AfterOperationEvent) event).getOperationSignature())) && (!(this.beforeEventStack.getLast().getClassSignature()) .equals(((AfterOperationEvent) event).getClassSignature()))) { final BeforeOperationEvent beforeEvent = this.beforeEventStack.getLast(); final String opSignature = beforeEvent.getOperationSignature(); } else { this.eventQueue.add( new AfterOperationEvent(timestamp, traceID, orderIndex, opSignature, classSignature)); this.eventQueue.add(event); } else { final String opSignature = ((AfterOperationEvent) event).getOperationSignature(); final String classSignature = ((AfterOperationEvent) event).getClassSignature(); final long timestamp = event.getTimestamp(); final long traceID = event.getTraceId(); } else { this.eventQueue.add( new AfterOperationEvent(timestamp, traceID, orderIndex, opSignature, classSignature));
private boolean refersToSameOperationAs(final AfterOperationEvent afterOperationEvent, final BeforeOperationEvent potentialBeforeEvent) { return afterOperationEvent.getOperationSignature().equals(potentialBeforeEvent.getOperationSignature()) && afterOperationEvent.getClassSignature().equals(potentialBeforeEvent.getClassSignature()); }
final AfterOperationEvent newEvent = new AfterOperationEvent(originalEvent.getTimestamp(), monitoredTrace.identifier, originalEvent.getOrderIndex(), originalEvent.getOperationSignature(), originalEvent.getClassSignature()); newEvent.setLoggingTimestamp(originalEvent.getLoggingTimestamp());
public void handleAfterOperationEventRecord(final AfterOperationEvent record) { final BeforeOperationEvent beforeEvent = this.stack.pop(); final long timestampDifference = record.getTimestamp() - beforeEvent.getTimestamp(); this.current.setDuration(Duration.of(timestampDifference, this.temporalUnit)); if (record instanceof AfterOperationFailedEvent) { final String failedCause = ((AfterOperationFailedEvent) record).getCause(); this.current.setFailed(true); this.current.setFailedCause(failedCause); } this.current = this.current.getParent(); // BETTER handle additional log checks // // if (TraceReconstructor.this.activateAdditionalLogChecks) { // if (!beforeEvent.getOperationSignature().equals(record.getOperationSignature())) { // TraceReconstructor.this.faultyTraceBuffers.add(this); // TraceReconstructor.this.traceBuffers.remove(this.traceID); // } // } // }
public Optional<Trace> handleAfterOperationEventRecord(final AfterOperationEvent event) { final long traceID = event.getTraceId(); final TraceReconstructionBuffer traceBuffer = this.traceBuffers.get(traceID); if (traceBuffer != null) { traceBuffer.handleAfterOperationEventRecord(event); if (traceBuffer.isTraceComplete()) { final Trace trace = traceBuffer.reconstructTrace(); this.traceBuffers.remove(traceID); return Optional.of(trace); } } else { this.danglingRecords++; } return Optional.empty(); }
/** * {@inheritDoc} * * @deprecated since 1.13. Use {@link #serialize(IValueSerializer)} with an array serializer instead. */ @Override @Deprecated public Object[] toArray() { return new Object[] { this.getTimestamp(), this.getTraceId(), this.getOrderIndex(), this.getOperationSignature(), this.getClassSignature() }; } /**
@Override public AfterOperationEvent create(final IValueDeserializer deserializer) throws RecordInstantiationException { return new AfterOperationEvent(deserializer); }
final CustomAfterOperationEvent receivedRecord = (CustomAfterOperationEvent) eventFromLog; Assert.assertEquals("Unexpected set of records - sent record does not match received record", (sentRecord.getTimestamp() + ", " + sentRecord.getTraceId() + ", " + sentRecord.getOrderIndex()), (receivedRecord.getTimestamp() + ", " + receivedRecord.getTraceId() + ", " + receivedRecord.getOrderIndex()));
private boolean refersToSameOperationAs(final AfterOperationEvent afterOperationEvent, final BeforeOperationEvent potentialBeforeEvent) { return afterOperationEvent.getOperationSignature().equals(potentialBeforeEvent.getOperationSignature()) && afterOperationEvent.getClassSignature().equals(potentialBeforeEvent.getClassSignature()); }
/** * {@inheritDoc} */ @Override public boolean equals(final Object obj) { if (obj == null) return false; if (obj == this) return true; if (obj.getClass() != this.getClass()) return false; final AfterOperationEvent castedRecord = (AfterOperationEvent) obj; if (this.getLoggingTimestamp() != castedRecord.getLoggingTimestamp()) return false; if (this.getTimestamp() != castedRecord.getTimestamp()) return false; if (this.getTraceId() != castedRecord.getTraceId()) return false; if (this.getOrderIndex() != castedRecord.getOrderIndex()) return false; if (!this.getOperationSignature().equals(castedRecord.getOperationSignature())) return false; if (!this.getClassSignature().equals(castedRecord.getClassSignature())) return false; return true; }