blob: 4e178036fcafa6b0b9bcd5be55f2ed59180b6d96 [file] [log] [blame]
/*
* Copyright 2013-present Facebook, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License. You may obtain
* a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
package com.facebook.buck.httpserver;
import static org.easymock.EasyMock.expect;
import static org.hamcrest.Matchers.containsString;
import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertThat;
import com.facebook.buck.httpserver.TracesHelper.TraceAttributes;
import com.google.common.base.Optional;
import org.easymock.EasyMockSupport;
import org.eclipse.jetty.server.Handler;
import org.eclipse.jetty.server.Request;
import org.junit.Test;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.StringWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class TraceHandlerDelegateTest extends EasyMockSupport {
@Test
public void testHandleGet() throws IOException, ServletException {
Request baseRequest = createMock(Request.class);
expect(baseRequest.getPathInfo()).andReturn("/abcdef");
baseRequest.setHandled(true);
HttpServletRequest request = createMock(HttpServletRequest.class);
HttpServletResponse response = createMock(HttpServletResponse.class);
response.setStatus(200);
response.setContentType("text/html; charset=utf-8");
StringWriter stringWriter = new StringWriter();
PrintWriter printWriter = new PrintWriter(stringWriter);
expect(response.getWriter()).andReturn(printWriter);
response.flushBuffer();
TracesHelper tracesHelper = createMock(TracesHelper.class);
expect(tracesHelper.getTraceAttributesFor("abcdef")).andReturn(
new TraceAttributes(Optional.of("buck build buck"), 2000L));
Handler traceHandler = new TemplateHandler(new TraceHandlerDelegate(tracesHelper));
replayAll();
traceHandler.handle("/trace/abcdef",
baseRequest,
request,
response);
verifyAll();
String expectedScriptTag = "<script src=\"/tracedata/abcdef?callback=onTracesLoaded\">";
String html = stringWriter.toString();
assertThat(html, containsString(expectedScriptTag));
assertThat(html, containsString("buck build buck"));
}
@Test
public void testMalformedPathInfoReturnsError() throws IOException {
Request baseRequest = createMock(Request.class);
expect(baseRequest.getPathInfo()).andReturn("/..upADirectory");
// Nothing on the helper should be invoked because the handler will error-out first.
TracesHelper tracesHelper = createMock(TracesHelper.class);
replayAll();
TraceHandlerDelegate traceHandler = new TraceHandlerDelegate(tracesHelper);
assertNull(traceHandler.getDataForRequest(baseRequest));
verifyAll();
}
}