Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Logging: Allow deferred formatting for trace and spanId #3661

Merged
merged 5 commits into from
Nov 29, 2018
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -65,8 +65,8 @@ public LogEntry apply(com.google.logging.v2.LogEntry pb) {
private final HttpRequest httpRequest;
private final Map<String, String> labels;
private final Operation operation;
private final String trace;
private final String spanId;
private final Object trace;
private final Object spanId;
private final SourceLocation sourceLocation;
private final Payload<?> payload;

Expand All @@ -84,8 +84,8 @@ public static class Builder {
private HttpRequest httpRequest;
private Map<String, String> labels = new HashMap<>();
private Operation operation;
private String trace;
private String spanId;
private Object trace;
private Object spanId;
private SourceLocation sourceLocation;
private Payload<?> payload;

Expand Down Expand Up @@ -225,7 +225,7 @@ public Builder setOperation(Operation operation) {
* Sets the resource name of the trace associated with the log entry, if any. If it contains a
* relative resource name, the name is assumed to be relative to `//tracing.googleapis.com`.
*/
public Builder setTrace(String trace) {
public Builder setTrace(Object trace) {
this.trace = trace;
return this;
}
Expand All @@ -234,7 +234,7 @@ public Builder setTrace(String trace) {
/**
* Sets the ID of the trace span associated with the log entry, if any.
*/
public Builder setSpanId(String spanId) {
public Builder setSpanId(Object spanId) {
chingor13 marked this conversation as resolved.
Show resolved Hide resolved
this.spanId = spanId;
return this;
}
Expand Down Expand Up @@ -372,15 +372,17 @@ public Operation getOperation() {
* relative resource name, the name is assumed to be relative to `//tracing.googleapis.com`.
*/
public String getTrace() {
return trace;
// For backwards compatibility return null when trace not set instead of "null".
return trace == null ? null : String.valueOf(trace);
}


/**
* Returns the ID of the trace span associated with the log entry, if any.
*/
public String getSpanId() {
return spanId;
// For backwards compatibility return null when spanId not set instead of "null".
return spanId == null ? null : String.valueOf(spanId);
}


Expand All @@ -407,7 +409,7 @@ public <T extends Payload> T getPayload() {
@Override
public int hashCode() {
return Objects.hash(logName, resource, timestamp, receiveTimestamp, severity, insertId,
httpRequest, labels, operation, trace, spanId, sourceLocation, payload);
httpRequest, labels, operation, getTrace(), getSpanId(), sourceLocation, payload);
}

@Override
Expand All @@ -428,8 +430,8 @@ public boolean equals(Object obj) {
&& Objects.equals(httpRequest, other.httpRequest)
&& Objects.equals(labels, other.labels)
&& Objects.equals(operation, other.operation)
&& Objects.equals(trace, other.trace)
&& Objects.equals(spanId, other.spanId)
&& Objects.equals(getTrace(), other.getTrace())
&& Objects.equals(getSpanId(), other.getSpanId())
&& Objects.equals(sourceLocation, other.sourceLocation)
&& Objects.equals(payload, other.payload);
}
Expand Down Expand Up @@ -500,10 +502,10 @@ com.google.logging.v2.LogEntry toPb(String projectId) {
builder.setOperation(operation.toPb());
}
if (trace != null) {
builder.setTrace(trace);
builder.setTrace(getTrace());
}
if (spanId != null) {
builder.setSpanId(spanId);
builder.setSpanId(getSpanId());
}
if (sourceLocation != null) {
builder.setSourceLocation(sourceLocation.toPb());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,19 @@ public class LogEntryTest {
ImmutableMap.of("key1", "value1", "key2", "value2");
private static final Operation OPERATION = Operation.of("id", "producer");
private static final String TRACE = "trace";
private static final Object TRACE_FORMATTER = new Object() {
@Override
public String toString() {
return TRACE;
}
};
private static final String SPAN_ID = "spanId";
private static final Object SPAN_ID_FORMATTER = new Object() {
@Override
public String toString() {
return SPAN_ID;
}
};
private static final SourceLocation SOURCE_LOCATION = new SourceLocation.Builder()
.setFile("file")
.setLine(42L)
Expand All @@ -71,8 +83,8 @@ public class LogEntryTest {
.setHttpRequest(HTTP_REQUEST)
.setLabels(LABELS)
.setOperation(OPERATION)
.setTrace(TRACE)
.setSpanId(SPAN_ID)
.setTrace(TRACE_FORMATTER)
.setSpanId(SPAN_ID_FORMATTER)
.setSourceLocation(SOURCE_LOCATION)
.build();
private static final LogEntry JSON_ENTRY = LogEntry.newBuilder(JSON_PAYLOAD)
Expand All @@ -85,8 +97,8 @@ public class LogEntryTest {
.setHttpRequest(HTTP_REQUEST)
.setLabels(LABELS)
.setOperation(OPERATION)
.setTrace(TRACE)
.setSpanId(SPAN_ID)
.setTrace(TRACE_FORMATTER)
.setSpanId(SPAN_ID_FORMATTER)
.setSourceLocation(SOURCE_LOCATION)
.build();
private static final LogEntry PROTO_ENTRY = LogEntry.newBuilder(PROTO_PAYLOAD)
Expand All @@ -99,8 +111,8 @@ public class LogEntryTest {
.setHttpRequest(HTTP_REQUEST)
.setLabels(LABELS)
.setOperation(OPERATION)
.setTrace(TRACE)
.setSpanId(SPAN_ID)
.setTrace(TRACE_FORMATTER)
.setSpanId(SPAN_ID_FORMATTER)
.setSourceLocation(SOURCE_LOCATION)
.build();

Expand Down