All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ratpack.test.handling.HandlingResult Maven / Gradle / Ivy

/*
 * Copyright 2013 the original author or authors.
 *
 * 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 ratpack.test.handling;

import ratpack.api.Nullable;
import ratpack.http.Headers;
import ratpack.http.Status;
import ratpack.registry.Registry;

import java.nio.file.Path;

/**
 * Represents the result of testing one or more handlers.
 *
 * @see ratpack.test.handling.RequestFixture
 */
public interface HandlingResult {

  /**
   * The response body, as bytes.
   * 

* This does not include file or rendered responses. * See {@link #getSentFile()} and {@link #rendered(Class)}. * * @return the response body, as bytes, or {@code null} if no response was sent. */ @Nullable byte[] getBodyBytes(); /** * The response body, interpreted as a utf8 string. *

* This does not include file or rendered responses. * See {@link #getSentFile()} and {@link #rendered(Class)}. * * @return the response body, interpreted as a utf8 string, or {@code null} if no response was sent. */ @Nullable String getBodyText(); /** * The client error raised if any, unless a custom client error handler is in use. *

* If no client error was “raised”, will be {@code null}. *

* If a custom client error handler is used (either by specification in the request fixture or insertion by an upstream handler), this will always be {@code null}. * In such a case, this result effectively indicates what the custom client error handler did as its implementation. * * @return the client error code, or {@code null}. */ @Nullable Integer getClientError(); /** * The throwable thrown or given to {@link ratpack.handling.Context#error(Throwable)}, unless a custom error handler is in use. *

* If no throwable was “raised”, a new {@link ratpack.test.handling.HandlerExceptionNotThrownException} is raised. *

* If a custom error handler is used (either by specification in the request fixture or insertion by an upstream handler), * this will always raise a new {@link ratpack.test.handling.HandlerExceptionNotThrownException} * In such a case, this result effectively indicates what the custom error handler did as its implementation. * * @param type The expected type of the exception captured. * @param The expected type of the exception captured. * @return the “unhandled” throwable that occurred, or raise {@link ratpack.test.handling.HandlerExceptionNotThrownException} */ @Nullable T exception(Class type); /** * The final response headers. * * @return the final response headers */ Headers getHeaders(); /** * The final state of the context registry. * * @return the final state of the context registry */ Registry getRegistry(); /** * The final state of the request registry. * * @return the final state of the reqest registry */ Registry getRequestRegistry(); /** * Indicates whether the result of invoking the handler was that it invoked one of the {@link ratpack.http.Response#sendFile} methods. *

* This does not include files rendered with {@link ratpack.handling.Context#render(Object)}. * * @return the file given to one of the {@link ratpack.http.Response#sendFile} methods, or {@code null} if none of these methods were called */ @Nullable Path getSentFile(); /** * The response status information. *

* Indicates the state of the context's {@link ratpack.http.Response#getStatus()} after invoking the handler. * If the result is a sent response, this indicates the status of the response. * * @return the response status */ Status getStatus(); /** * Indicates whether the result of invoking the handler was that it delegated to a downstream handler. * * @return whether the handler delegated to a downstream handler */ boolean isCalledNext(); /** * Indicates the the handler(s) invoked one of the {@link ratpack.http.Response#send} methods. * * @return whether one of the {@link ratpack.http.Response#send} methods was invoked */ boolean isSentResponse(); // This is not named right, as it doesn't include sending files /** * The object that was rendered to the response. *

* The exact object that was given to {@link ratpack.handling.Context#render(Object)}. * The value must be assignment compatible with given type token. * If it is not, an {@link AssertionError} will be thrown. * * @param type the expect type of the rendered object * @param the expect type of the rendered object * @return the rendered object, or {@code null} if no object was rendered * @throws AssertionError if the rendered object cannot be cast to the given type */ @Nullable T rendered(Class type) throws AssertionError; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy