com.google.jstestdriver.HttpServer.java Source code

Java tutorial

Introduction

Here is the source code for com.google.jstestdriver.HttpServer.java

Source

/*
 * Copyright 2009 Google 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.google.jstestdriver;

import com.google.gson.JsonElement;
import com.google.inject.Inject;
import com.google.jstestdriver.util.StopWatch;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.*;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLEncoder;
import java.util.Iterator;
import java.util.Map;

/**
 * @author jeremiele@google.com (Jeremie Lenfant-Engelmann)
 */
public class HttpServer implements Server {
    private static final Logger logger = LoggerFactory.getLogger(HttpServer.class);
    private static final String UTF8_ENCODING = "UTF-8";
    private final StopWatch stopWatch;

    @Inject
    public HttpServer(StopWatch stopWatch) {
        this.stopWatch = stopWatch;
    }

    @Override
    public String fetch(String url) {
        stopWatch.start("fetch %s", url);
        HttpURLConnection connection = null;
        logger.trace("Fetching {}", url);

        try {
            connection = (HttpURLConnection) new URL(url).openConnection();
            connection.connect();
            String response = toString(connection.getInputStream());
            logger.trace("Fetch response {}", response);
            return response;
        } catch (MalformedURLException e) {
            throw new RuntimeException(e);
        } catch (IOException e) {
            throw new RuntimeException(e);
        } finally {
            if (connection != null) {
                connection.disconnect();
            }
            stopWatch.stop("fetch %s", url);
        }
    }

    public void ping(String url) {
        HttpURLConnection connection = null;
        logger.trace("Pinging {}", url);

        try {
            connection = (HttpURLConnection) new URL(url).openConnection();

            connection.connect();
            connection.getInputStream();
            logger.trace("Pinged {}", url);
        } catch (MalformedURLException e) {
            throw new RuntimeException(e);
        } catch (IOException e) {
            throw new RuntimeException(e);
        } finally {
            if (connection != null) {
                connection.disconnect();
            }
        }
    }

    private String toString(InputStream inputStream) throws IOException {
        StringBuilder sb = new StringBuilder();
        Reader reader = new InputStreamReader(inputStream, UTF8_ENCODING);
        int ch;

        while ((ch = reader.read()) != -1) {
            sb.append((char) ch);
        }
        reader.close();
        return sb.toString();
    }

    @Override
    public String post(String url, Map<String, String> params) {
        stopWatch.start("post %s", url);
        HttpURLConnection connection = null;

        try {
            logger.trace("Post url:{} \nParams:\n{} \n", url, params);
            String paramsString = convertParamsToString(params);

            connection = (HttpURLConnection) new URL(url).openConnection();
            connection.setRequestMethod("POST");
            connection.setDoOutput(true);
            connection.setDoInput(true);
            connection.setRequestProperty("Content-Type",
                    "application/x-www-form-urlencoded; charset=" + UTF8_ENCODING);
            connection.setRequestProperty("Content-Length",
                    Integer.toString(paramsString.getBytes(UTF8_ENCODING).length));
            OutputStreamWriter oWriter = new OutputStreamWriter(connection.getOutputStream());

            oWriter.write(paramsString);
            oWriter.close();
            connection.connect();
            String response = toString(connection.getInputStream());
            logger.trace("Post response:\n{}", response);
            return response;
        } catch (IOException e) {
            throw new RuntimeException("Connection error", e);
        } finally {
            if (connection != null) {
                connection.disconnect();
            }
            stopWatch.stop("post %s", url);
        }
    }

    @Override
    public String postJson(String url, JsonElement json) {
        stopWatch.start("postJson %s", url);
        HttpURLConnection connection = null;
        try {
            logger.trace("Post url:{}\nJSON:\n{}\n", url, json);
            String jsonString = json.toString();
            connection = (HttpURLConnection) new URL(url).openConnection();
            connection.setRequestMethod("POST");
            connection.setDoOutput(true);
            connection.setDoInput(true);
            connection.setRequestProperty("Content-Type", "application/jsonrequest");
            connection.setRequestProperty("Content-Length", Integer.toString(jsonString.getBytes().length));
            OutputStreamWriter oWriter = new OutputStreamWriter(connection.getOutputStream());
            oWriter.write(jsonString);
            oWriter.close();
            connection.connect();
            String response = toString(connection.getInputStream());
            logger.trace("Post response:\n{}\n", response);
            return response;
        } catch (IOException e) {
            throw new RuntimeException("Connection error on: " + connection, e);
        } finally {
            if (connection != null) {
                connection.disconnect();
            }
            stopWatch.stop("postJson %s", url);
        }
    }

    public String convertParamsToString(Map<String, String> params) throws UnsupportedEncodingException {
        StringBuilder sb = new StringBuilder();
        Iterator<Map.Entry<String, String>> iterator = params.entrySet().iterator();

        // TODO(corysmith): WTF? Figure out what's going on....

        if (iterator.hasNext()) {
            Map.Entry<String, String> entry = iterator.next();

            sb.append(String.format("%s=%s", URLEncoder.encode(entry.getKey(), "UTF-8"),
                    URLEncoder.encode(entry.getValue(), "UTF-8")));
            while (iterator.hasNext()) {
                entry = iterator.next();
                sb.append(String.format("&%s=%s", URLEncoder.encode(entry.getKey(), "UTF-8"),
                        URLEncoder.encode(entry.getValue(), "UTF-8")));
            }
        }
        return sb.toString();
    }

    @Override
    public String startSession(String baseUrl, String id) {
        return fetch(baseUrl + "/fileSet?id=" + id + "&session=start");
    }

    @Override
    public void stopSession(String baseUrl, String id, String sessionId) {
        fetch(baseUrl + "/fileSet?id=" + id + "&session=stop" + "&sessionId=" + sessionId);
    }
}