/** * The MIT License (MIT) * * Copyright (c) 2014-2017 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.rq; import java.io.IOException; import java.util.Arrays; import java.util.Collections; import org.hamcrest.MatcherAssert; import org.hamcrest.Matchers; import org.junit.Test; import org.takes.HttpException; /** * Test case for {@link RqHref.Base}. * @author Yegor Bugayenko (yegor256@gmail.com) * @version $Id: ca76f096585935c82ec98eb4cd0a2e39c2f2d6db $ * @since 0.1 */ public final class RqHrefTest { /** * RqHref.Base can parse a query. * @throws IOException If some problem inside */ @Test public void parsesHttpQuery() throws IOException { MatcherAssert.assertThat( new RqHref.Base( new RqFake( Arrays.asList( "GET /h?a=3", "Host: www.example.com", "Content-type: text/plain" ), "" ) ).href().toString(), Matchers.equalTo("http://www.example.com/h?a=3") ); } /** * RqHref.Base should throw {@link HttpException} when parsing * Request without Request-Line. * @throws IOException If some problem inside */ @Test(expected = HttpException.class) public void failsOnAbsentRequestLine() throws IOException { new RqHref.Base( new RqSimple(Collections.<String>emptyList(), null) ).href(); } /** * RqHref.Base should throw {@link HttpException} when parsing * Request with illegal Request-Line. * @throws IOException If some problem inside */ @Test(expected = HttpException.class) public void failsOnIllegalRequestLine() throws IOException { new RqHref.Base( new RqFake( Arrays.asList( "GIVE/contacts", "Host: 2.example.com" ), "" ) ).href(); } /** * RqHref.Base can extract params. * @throws IOException If some problem inside */ @Test public void extractsParams() throws IOException { MatcherAssert.assertThat( new RqHref.Base( new RqFake( Arrays.asList( "GET /hello?a=3&b=7&c&d=9%28x%29&ff", "Host: a.example.com", "Content-type: text/xml" ), "" ) ).href().param("d"), Matchers.hasItem("9(x)") ); } /** * RqHref.Base can extract first params. * @throws IOException If some problem inside */ @Test public void extractsFirstParam() throws IOException { MatcherAssert.assertThat( new RqHref.Base( new RqFake( Arrays.asList( "GET /hello?since=343", "Host: f.example.com" ), "" ) ).href().param("since"), Matchers.hasItem("343") ); } /** * RqHref.Smart can extract home URI. * @throws IOException If some problem inside */ @Test public void extractsHome() throws IOException { MatcherAssert.assertThat( new RqHref.Smart( new RqHref.Base( new RqFake( Arrays.asList( "GET /bye?extra=343", "Host: ddd.example.com" ), "" ) ) ).home(), Matchers.hasToString("http://ddd.example.com/") ); } /** * RqHref.Smart can extract param with default value. * @throws IOException If some problem inside */ @Test public void extractsParamByDefault() throws IOException { MatcherAssert.assertThat( new RqHref.Smart( new RqHref.Base( new RqFake( Arrays.asList( "GET /foo?present=343", "Host: w.example.com" ), "" ) ) ).single("absent", "def-5"), Matchers.startsWith("def-") ); } }