Skip to content

Commit

Permalink
Cleaned up id prefix.
Browse files Browse the repository at this point in the history
  • Loading branch information
Dennis J. McWherter Jr committed Oct 14, 2016
1 parent 4374c78 commit 6ed9cd4
Show file tree
Hide file tree
Showing 4 changed files with 22 additions and 38 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,6 @@ public class RequestLog {
private static final List<String> LOGINFO_ORDER = generateLogInfoOrder(LOGINFO_ORDER_STRING);

private String logId;
private String idPrefix;
private LogBlock info;
private TimedPhase mostRecentTimer;
private final Map<String, TimedPhase> times;
Expand All @@ -79,7 +78,6 @@ private RequestLog() {
mapper.registerModule((new JodaModule()).addSerializer(Interval.class, new ToStringSerializer()));
mapper.registerModule(new Jdk8Module().configureAbsentsAsNulls(false));
MDC.remove(ID_KEY);
idPrefix = "";
}

/**
Expand All @@ -94,7 +92,6 @@ private RequestLog(RequestLog rl) {
times = new LinkedHashMap<>(rl.times);
threadIds = new LinkedHashSet<>(rl.threadIds);
MDC.put(ID_KEY, logId);
idPrefix = "";
}

/**
Expand Down Expand Up @@ -155,7 +152,6 @@ private void clear() {
times.clear();
threadIds.clear();
MDC.remove(ID_KEY);
idPrefix = "";
}

/**
Expand Down Expand Up @@ -185,7 +181,6 @@ private void init() {
threadIds.clear();
threadIds.add(Thread.currentThread().getName());
MDC.put(ID_KEY, logId);
idPrefix = "";
}

/**
Expand Down Expand Up @@ -402,20 +397,19 @@ public static String getId() {
if (current.info == null) {
current.init();
}
return current.idPrefix + current.logId;
return current.logId;
}

/**
* Set id prefix.
*
* @param idPrefix Prefix for queryId sent to druid
*/
public static void setIdPrefix(String idPrefix) {
public static void addIdPrefix(String idPrefix) {
RequestLog current = RLOG.get();
if (current.info == null) {
current.init();
}
current.idPrefix = (idPrefix == null) ? "" : idPrefix;
String newId = idPrefix + getId();
current.logId = newId;
MDC.put(ID_KEY, newId);
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ public class BardLoggingFilter implements ContainerRequestFilter, ContainerRespo
@Override
public void filter(ContainerRequestContext request) throws IOException {

RequestLog.setIdPrefix(request.getHeaders().getFirst(X_REQUEST_ID_HEADER));
RequestLog.addIdPrefix(request.getHeaders().getFirst(X_REQUEST_ID_HEADER));
RequestLog.startTiming(TOTAL_TIMER);
RequestLog.startTiming(this);
RequestLog.record(new Preface(request));
Expand All @@ -110,7 +110,7 @@ public void filter(ContainerRequestContext request) throws IOException {
@Override
public void filter(ContainerRequestContext request, ContainerResponseContext response)
throws IOException {
RequestLog.setIdPrefix(request.getHeaders().getFirst(X_REQUEST_ID_HEADER));
RequestLog.addIdPrefix(request.getHeaders().getFirst(X_REQUEST_ID_HEADER));
RequestLog.startTiming(this);
StringBuilder debugMsgBuilder = new StringBuilder();

Expand Down Expand Up @@ -171,7 +171,7 @@ public void filter(ContainerRequestContext request, ContainerResponseContext res
*/
@Override
public void filter(ClientRequestContext request) throws IOException {
RequestLog.setIdPrefix(request.getStringHeaders().getFirst(X_REQUEST_ID_HEADER));
RequestLog.addIdPrefix(request.getStringHeaders().getFirst(X_REQUEST_ID_HEADER));
RequestLog.startTiming(CLIENT_TOTAL_TIMER);
request.setProperty(PROPERTY_NANOS, System.nanoTime());
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import org.slf4j.LoggerFactory
import spock.lang.Specification
import spock.lang.Timeout

import javax.ws.rs.core.MultivaluedHashMap
import javax.ws.rs.core.MultivaluedMap
import javax.ws.rs.core.Response

Expand Down Expand Up @@ -71,6 +72,10 @@ abstract class BaseDataServletComponentSpec extends Specification {
populatePhysicalTableAvailability()
}

MultivaluedHashMap<String, String> getAdditionalHeaders() {
return [:]
}

/**
* Populates the interval availability of the physical tables.
* <p>
Expand Down Expand Up @@ -206,7 +211,7 @@ abstract class BaseDataServletComponentSpec extends Specification {
}

// Make the call
Response response = httpCall.request().get()
Response response = httpCall.request().headers(getAdditionalHeaders()).get()
if (response.status != 200) {
LOG.error( "*** *** Response status: ${response.status}: ${response.readEntity(String)}")
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,11 @@ import com.yahoo.bard.webservice.util.JsonSlurper
import com.yahoo.bard.webservice.util.JsonSortStrategy
import com.yahoo.bard.webservice.web.filters.BardLoggingFilter

import javax.ws.rs.core.Response
import javax.ws.rs.core.MultivaluedHashMap


class DruidQueryIdSpec extends BaseDataServletComponentSpec {
def prefixId = "abcdef"
static def testedDruidQuery = false

@Override
def setup() {
Expand All @@ -27,8 +26,7 @@ class DruidQueryIdSpec extends BaseDataServletComponentSpec {

@Override
Class<?>[] getResourceClasses() {
[ DataServlet.class
, BardLoggingFilter.class ]
[ DataServlet.class, BardLoggingFilter.class ]
}

@Override
Expand All @@ -40,16 +38,16 @@ class DruidQueryIdSpec extends BaseDataServletComponentSpec {
Map<String, List<String>> getQueryParams() {
[
"metrics": ["width","depth"],
"dateTime": ["2014-06-02%2F2014-06-30"],
"dateTime": ["2014-06-02/2014-06-30"],
"sort": ["width|desc","depth|asc"]
]
}

@Override
boolean compareResult(String result, String expectedResult, JsonSortStrategy sortStrategy = JsonSortStrategy.SORT_MAPS) {
if (!testedDruidQuery) {
JsonSlurper slurper = new JsonSlurper(sortStrategy)
def parsedJson = slurper.parseText(result)
JsonSlurper slurper = new JsonSlurper(sortStrategy)
def parsedJson = slurper.parseText(result)
if (parsedJson.context != null) {
testedDruidQuery = true
return parsedJson.context.queryId.startsWith(prefixId)
}
Expand All @@ -76,20 +74,7 @@ class DruidQueryIdSpec extends BaseDataServletComponentSpec {
}

@Override
Response makeAbstractRequest(Closure queryParams=this.&getQueryParams) {
// Set target of call
def httpCall = jtb.getHarness().target(getTarget())

// Add query params to call
queryParams().each { String key, List<String> values ->
httpCall = httpCall.queryParam(key, values.join(","))
}

// Make the call
Response response = httpCall.request().header("X-Request-ID", prefixId).get()
if (response.status != 200) {
LOG.error( "*** *** Response status: ${response.status}: ${response.readEntity(String)}")
}
response
MultivaluedHashMap<String, String> getAdditionalHeaders() {
return ["x-request-id": prefixId]
}
}

0 comments on commit 6ed9cd4

Please sign in to comment.