Skip to content

Commit

Permalink
Merge branch '__rultor'
Browse files Browse the repository at this point in the history
  • Loading branch information
rultor committed Jan 11, 2019
2 parents b9f248e + ab2d8d6 commit 7b495e7
Show file tree
Hide file tree
Showing 7 changed files with 644 additions and 3 deletions.
320 changes: 320 additions & 0 deletions src/main/java/org/takes/servlet/HttpServletResponseFake.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,320 @@
/*
* The MIT License (MIT)
*
* Copyright (c) 2014-2018 Yegor Bugayenko
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included
* in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package org.takes.servlet;

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Collection;
import java.util.Locale;
import java.util.concurrent.atomic.AtomicReference;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletResponse;
import org.cactoos.io.InputOf;
import org.cactoos.io.LengthOf;
import org.cactoos.io.OutputTo;
import org.cactoos.io.TeeInput;
import org.cactoos.iterable.Filtered;
import org.cactoos.list.ListOf;
import org.takes.Response;
import org.takes.facets.cookies.RsWithCookie;
import org.takes.misc.EnglishLowerCase;
import org.takes.rs.RsWithHeader;
import org.takes.rs.RsWithStatus;
import org.takes.rs.RsWithoutHeader;

/**
* Fake HttpServletResponse (for unit tests).
*
* @since 1.14
* @checkstyle ClassDataAbstractionCouplingCheck (500 lines)
*/
@SuppressWarnings("PMD.TooManyMethods")
public final class HttpServletResponseFake implements HttpServletResponse {
/**
* A Takes response.
*/
private final AtomicReference<Response> response;

/**
* Ctor.
* @param resp A Takes Response object
*/
public HttpServletResponseFake(final Response resp) {
this.response = new AtomicReference<>(resp);
}

@Override
public void addCookie(final Cookie cookie) {
this.response.set(
new RsWithCookie(
this.response.get(),
cookie.getName(),
cookie.getValue()
)
);
}

@Override
public void setHeader(final String name, final String value) {
this.response.set(
new RsWithHeader(
new RsWithoutHeader(
this.response.get(),
name
),
name,
value
)
);
}

@Override
public void setStatus(final int code) {
this.response.set(
new RsWithStatus(
this.response.get(),
code
)
);
}

@Override
public void sendError(
final int code,
final String reason
) throws IOException {
this.response.set(
new RsWithStatus(
this.response.get(),
code,
reason
)
);
}

@Override
public Collection<String> getHeaders(final String header) {
final String prefix = String.format(
"%s:", new EnglishLowerCase(header)
);
try {
return new ListOf<>(
new Filtered<>(
hdr -> !new EnglishLowerCase(hdr).string()
.startsWith(prefix),
this.response.get().head()
)
);
} catch (final IOException ex) {
throw new IllegalStateException(ex);
}
}

@Override
public ServletOutputStream getOutputStream() throws IOException {
final ByteArrayOutputStream baos = new ByteArrayOutputStream();
new LengthOf(
new TeeInput(
new InputOf(this.response.get().body()),
new OutputTo(baos)
)
).intValue();
return new ServletOutputStreamTo(baos);
}

@Override
public String getHeader(final String header) {
throw new UnsupportedOperationException("#getHeaders()");
}

@Override
public boolean containsHeader(final String header) {
throw new UnsupportedOperationException("#containsHeader()");
}

@Override
public String encodeURL(final String url) {
throw new UnsupportedOperationException("#encodeURL()");
}

@Override
public String encodeRedirectURL(final String url) {
throw new UnsupportedOperationException("#encodeRedirectURL()");
}

/**
* Encode a URL.
* @deprecated It not should be used
* @param url URL to be encoded
* @return The encoded URL
*/
@Deprecated
public String encodeUrl(final String url) {
throw new UnsupportedOperationException("#encodeUrl()");
}

/**
* Encode a redirect URL.
* @deprecated It not should be used
* @param url URL to be encoded
* @return The encoded redirect URL
*/
@Deprecated
public String encodeRedirectUrl(final String url) {
throw new UnsupportedOperationException("#encodeRedirectUrl()");
}

@Override
public void sendError(final int code) throws IOException {
throw new UnsupportedOperationException("#sendError()");
}

@Override
public void sendRedirect(final String location) throws IOException {
throw new UnsupportedOperationException("#sendRedirect()");
}

@Override
public void setDateHeader(final String name, final long time) {
throw new UnsupportedOperationException("#setDateHeader()");
}

@Override
public void addDateHeader(final String name, final long date) {
throw new UnsupportedOperationException("#addDateHeader()");
}

@Override
public void addHeader(final String name, final String value) {
throw new UnsupportedOperationException("#addHeader()");
}

@Override
public void setIntHeader(final String name, final int value) {
throw new UnsupportedOperationException("#setIntHeader()");
}

@Override
public void addIntHeader(final String name, final int value) {
throw new UnsupportedOperationException("#addIntHeader()");
}

/**
* Set the response code status and reason.
* @deprecated It not should be used
* @param code The status code
* @param reason The reason originates this code
*/
@Deprecated
public void setStatus(final int code, final String reason) {
throw new UnsupportedOperationException("#setStatus()");
}

@Override
public int getStatus() {
throw new UnsupportedOperationException("#getStatus()");
}

@Override
public Collection<String> getHeaderNames() {
throw new UnsupportedOperationException("#getHeaderNames()");
}

@Override
public String getCharacterEncoding() {
throw new UnsupportedOperationException("#getCharacterEncoding()");
}

@Override
public String getContentType() {
throw new UnsupportedOperationException("#getContentType()");
}

@Override
public PrintWriter getWriter() throws IOException {
throw new UnsupportedOperationException("#getWriter()");
}

@Override
public void setCharacterEncoding(final String encoding) {
throw new UnsupportedOperationException("#setCharacterEncoding()");
}

@Override
public void setContentLength(final int length) {
throw new UnsupportedOperationException("#setContentLength()");
}

@Override
public void setContentLengthLong(final long length) {
throw new UnsupportedOperationException("#setContentLengthLong()");
}

@Override
public void setContentType(final String type) {
throw new UnsupportedOperationException("#setContentType()");
}

@Override
public void setBufferSize(final int size) {
throw new UnsupportedOperationException("#setBufferSize()");
}

@Override
public int getBufferSize() {
throw new UnsupportedOperationException("#getBufferSize()");
}

@Override
public void flushBuffer() throws IOException {
throw new UnsupportedOperationException("#flushBuffer()");
}

@Override
public void resetBuffer() {
throw new UnsupportedOperationException("#resetBuffer()");
}

@Override
public boolean isCommitted() {
throw new UnsupportedOperationException("#isCommited()");
}

@Override
public void reset() {
throw new UnsupportedOperationException("#reset()");
}

@Override
public void setLocale(final Locale locale) {
throw new UnsupportedOperationException("#setLocale()");
}

@Override
public Locale getLocale() {
throw new UnsupportedOperationException("#getLocale()");
}
}
3 changes: 0 additions & 3 deletions src/main/java/org/takes/servlet/ResponseOf.java
Original file line number Diff line number Diff line change
Expand Up @@ -39,9 +39,6 @@
* Takes response as servlet response.
*
* @since 2.0
* @todo #682:30min Servlet request and response adapters are not unit-tested.
* There should be tests for reading headers and body from servlet request
* and test for validating servlet response after applying takes request.
*/
final class ResponseOf {
/**
Expand Down
3 changes: 3 additions & 0 deletions src/main/java/org/takes/servlet/RqFrom.java
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,9 @@
* Request from {@link HttpServletRequest}.
*
* @since 2.0
* @todo #866:30min Servlet request adapter is not unit-tested.
* There should be tests for reading headers and body from servlet request.
* See https://github.com/yegor256/takes/pull/865 discussion for details.
*/
final class RqFrom implements Request {
/**
Expand Down
Loading

2 comments on commit 7b495e7

@0pdd
Copy link
Collaborator

@0pdd 0pdd commented on 7b495e7 Jan 11, 2019

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Puzzle 682-06e5396c disappeared from src/main/java/org/takes/servlet/ResponseOf.java, that's why I closed #866. Please, remember that the puzzle was not necessarily removed in this particular commit. Maybe it happened earlier, but we discovered this fact only now.

@0pdd
Copy link
Collaborator

@0pdd 0pdd commented on 7b495e7 Jan 11, 2019

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Puzzle 866-ccba7032 discovered in src/main/java/org/takes/servlet/RqFrom.java and submitted as #938. Please, remember that the puzzle was not necessarily added in this particular commit. Maybe it was added earlier, but we discovered it only now.

Please sign in to comment.