Package org.jboss.arquillian.warp.impl.server.execution

Source Code of org.jboss.arquillian.warp.impl.server.execution.WarpRequestProcessor

/**
* JBoss, Home of Professional Open Source
* Copyright 2012, Red Hat Middleware LLC, and individual contributors
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* 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 org.jboss.arquillian.warp.impl.server.execution;

import java.io.IOException;
import java.util.logging.Level;
import java.util.logging.Logger;

import javax.servlet.http.HttpServletResponse;

import org.jboss.arquillian.core.api.Event;
import org.jboss.arquillian.core.api.annotation.Inject;
import org.jboss.arquillian.core.api.annotation.Observes;
import org.jboss.arquillian.test.spi.TestResult;
import org.jboss.arquillian.test.spi.TestResult.Status;
import org.jboss.arquillian.warp.impl.server.event.EnrichHttpResponse;
import org.jboss.arquillian.warp.impl.server.event.ExecuteWarp;
import org.jboss.arquillian.warp.impl.server.event.ProcessWarpRequest;
import org.jboss.arquillian.warp.impl.server.event.RequestProcessingFinished;
import org.jboss.arquillian.warp.impl.server.event.RequestProcessingStarted;
import org.jboss.arquillian.warp.impl.shared.ResponsePayload;
import org.jboss.arquillian.warp.spi.WarpCommons;

public class WarpRequestProcessor {

    private Logger log = Logger.getLogger(WarpRequestProcessor.class.getName());

    @Inject
    private Event<RequestProcessingStarted> requestProcessingStarted;

    @Inject
    private Event<RequestProcessingFinished> requestProcessingFinished;

    @Inject
    private Event<EnrichHttpResponse> enrichHttpResponse;

    @Inject
    private Event<ExecuteWarp> executeWarp;

    @Inject
    private Event<TestResult> testResult;

    public void processWarpRequest(@Observes ProcessWarpRequest event, HttpServletResponse response,
            ResponsePayload responsePayload) throws IOException {

        requestProcessingStarted.fire(new RequestProcessingStarted());

        try {
            executeWarp.fire(new ExecuteWarp());

        } catch (Throwable e) {
            testResult.fire(new TestResult(Status.FAILED, e));
        }

        if (responsePayload.getTestResult() != null) {
            if (responsePayload.getTestResult().getThrowable() != null) {
                if (WarpCommons.debugMode()) {
                    log.log(Level.SEVERE, "exception was thrown during Warp execution", responsePayload.getTestResult().getThrowable());
                }
            }
        } else {
            responsePayload.setTestResult(new TestResult(Status.PASSED));
        }

        try {
            enrichHttpResponse.fire(new EnrichHttpResponse());
        } catch (Exception e) {
            log.log(Level.SEVERE, "Warp failed to enrich HTTP response", e);
        }

        requestProcessingFinished.fire(new RequestProcessingFinished());
    }

}
TOP

Related Classes of org.jboss.arquillian.warp.impl.server.execution.WarpRequestProcessor

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.