Class AbstractUrlAssert<SELF extends AbstractUrlAssert<SELF>>

java.lang.Object
org.assertj.core.api.AbstractAssert<SELF,URL>
org.assertj.core.api.AbstractUrlAssert<SELF>
Type Parameters:
SELF - the "self" type of this assertion class.
All Implemented Interfaces:
Assert<SELF,URL>, Descriptable<SELF>, ExtensionPoints<SELF,URL>
Direct Known Subclasses:
UrlAssert

public abstract class AbstractUrlAssert<SELF extends AbstractUrlAssert<SELF>> extends AbstractAssert<SELF,URL>
Base class for all implementations of assertions for URLs.
See Also:
  • Field Details

    • urls

      protected org.assertj.core.internal.Urls urls
  • Constructor Details

    • AbstractUrlAssert

      protected AbstractUrlAssert(URL actual, Class<?> selfType)
  • Method Details

    • hasProtocol

      public SELF hasProtocol(String expected)
      Verifies that the actual URL has the expected protocol.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("ftp://helloworld.org")).hasProtocol("ftp");
      
       // This assertion fails:
       assertThat(new URL("http://helloworld.org")).hasProtocol("ftp");
      Parameters:
      expected - the expected protocol of the actual URL.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if the actual protocol is not equal to the expected protocol.
    • hasPath

      public SELF hasPath(String expected)
      Verifies that the actual URL has the expected path (which must not be null).

      Examples:

       // These assertions succeed:
       assertThat(new URL("http://helloworld.org/pages")).hasPath("/pages");
       assertThat(new URL("http://www.helloworld.org")).hasPath("");
       // or preferably:
       assertThat(new URL("http://www.helloworld.org")).hasNoPath();
      
       // this assertion fails:
       assertThat(new URL("http://helloworld.org/pickme")).hasPath("/pages/");
      
       // this assertion throws an IllegalArgumentException:
       assertThat(new URL("http://helloworld.org/pages")).hasPath(null);
      Parameters:
      expected - the expected path of the actual URL.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if the actual URL path is not equal to the expected path.
      IllegalArgumentException - if given path is null.
    • hasNoPath

      public SELF hasNoPath()
      Verifies that the actual URL has no path.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("http://www.helloworld.org")).hasNoPath();
      
       // this assertion fails:
       assertThat(new URL("http://helloworld.org/france")).hasNoPath();
      Returns:
      this assertion object.
      Throws:
      AssertionError - if actual has a path.
    • hasPort

      public SELF hasPort(int expected)
      Verifies that the actual URL has the expected port.

      Examples:

       // These assertions succeed:
       assertThat(new URL("http://helloworld.org:8080")).hasPort(8080);
      
       // These assertions fail:
       assertThat(new URL("http://helloworld.org:8080")).hasPort(9876);
       assertThat(new URL("http://helloworld.org")).hasPort(8080);
      Parameters:
      expected - the expected port of the actual URL.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if the actual port is not equal to the expected port.
    • hasNoPort

      public SELF hasNoPort()
      Verifies that the actual URL has no port.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("http://helloworld.org")).hasNoPort();
      
       // This assertion fails:
       assertThat(new URL("http://helloworld.org:8080")).hasNoPort();
      Returns:
      this assertion object.
      Throws:
      AssertionError - if actual has a port.
    • hasHost

      public SELF hasHost(String expected)
      Verifies that the actual URL has the expected host.

      Examples:

       // These assertions succeed:
       assertThat(new URL("http://helloworld.org/pages")).hasHost("helloworld.org");
       assertThat(new URL("http://helloworld.org:8080")).hasHost("helloworld.org");
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org")).hasHost("helloworld.org");
       assertThat(new URL("http://www.helloworld.org:8080")).hasHost("helloworld.org");
      Parameters:
      expected - the expected host of the actual URL.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if the actual host is not equal to the expected host.
    • hasNoHost

      public SELF hasNoHost()
      Verifies that the actual URL has no host.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("file:///home/user/Documents/hello-world.txt")).hasNoHost();
      
       // This assertion fails:
       assertThat(new URL("http://helloworld.org:8080/index.html")).hasNoHost();
      Returns:
      this assertion object.
      Throws:
      AssertionError - if actual has a host.
      Since:
      3.22.0
    • hasAuthority

      public SELF hasAuthority(String expected)
      Verifies that the actual URL has the expected authority.

      Examples:

       // These assertions succeed:
       assertThat(new URL("http://helloworld.org")).hasAuthority("helloworld.org");
       assertThat(new URL("http://helloworld.org:8080")).hasAuthority("helloworld.org:8080");
       assertThat(new URL("http://www.helloworld.org:8080/news")).hasAuthority("www.helloworld.org:8080");
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org:8080")).hasAuthority("www.helloworld.org");
       assertThat(new URL("http://www.helloworld.org")).hasAuthority("www.helloworld.org:8080");
      Parameters:
      expected - the expected authority of the actual URL.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if the actual authority is not equal to the expected authority.
    • hasQuery

      public SELF hasQuery(String expected)
      Verifies that the actual URL has the expected query.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("http://www.helloworld.org/index.html?type=test")).hasQuery("type=test");
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org/index.html?type=test")).hasQuery("type=hello");
       assertThat(new URL("http://www.helloworld.org/index.html")).hasQuery("type=hello");
      Parameters:
      expected - the expected query of the actual URL.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if the actual query is not equal to the expected query.
    • hasNoQuery

      public SELF hasNoQuery()
      Verifies that the actual URL has no query.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("http://www.helloworld.org/index.html")).hasNoQuery();
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org/index.html?type=test")).hasNoQuery();
      Returns:
      this assertion object.
      Throws:
      AssertionError - if actual has a query.
    • hasAnchor

      public SELF hasAnchor(String expected)
      Verifies that the actual URL has the expected anchor.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("http://www.helloworld.org/news.html#sport")).hasAnchor("sport");
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org/news.html#sport")).hasAnchor("war");
       assertThat(new URL("http://www.helloworld.org/news.html")).hasAnchor("sport");
      Parameters:
      expected - the expected anchor of the actual URL.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if the actual anchor is not equal to the expected anchor.
    • hasNoAnchor

      public SELF hasNoAnchor()
      Verifies that the actual URL has no anchor.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("http://www.helloworld.org/news.html")).hasNoAnchor();
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org/news.html#sport")).hasNoAnchor();
      Returns:
      this assertion object.
      Throws:
      AssertionError - if actual has a anchor.
    • hasUserInfo

      public SELF hasUserInfo(String expected)
      Verifies that the actual URL has the expected userinfo.

      Examples:

       // These assertions succeed:
       assertThat(new URL("http://test:[email protected]/index.html")).hasUserInfo("test:pass");
       assertThat(new URL("http://[email protected]/index.html")).hasUserInfo("test");
       assertThat(new URL("http://:[email protected]/index.html")).hasUserInfo(":pass");
      
       // These assertions fail:
       assertThat(new URL("http://test:[email protected]/index.html")).hasUserInfo("test:fail");
       assertThat(new URL("http://www.helloworld.org/index.html")).hasUserInfo("test:pass");
      Parameters:
      expected - the expected userinfo of the actual URL.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if the actual userinfo is not equal to the expected userinfo.
    • hasNoUserInfo

      public SELF hasNoUserInfo()
      Verifies that the actual URL has no userinfo.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("http://www.helloworld.org/index.html")).hasNoUserInfo();
      
       // This assertion fails:
       assertThat(new URL("http://test:[email protected]/index.html")).hasNoUserInfo();
      Returns:
      this assertion object.
      Throws:
      AssertionError - if actual has some userinfo.
    • hasParameter

      public SELF hasParameter(String name)
      Verifies that the actual URL has a parameter with the expected name.

      The value of the parameter is not checked.

      Examples:

       // These assertions succeed:
       assertThat(new URL("http://www.helloworld.org/index.html?happy")).hasParameter("happy");
       assertThat(new URL("http://www.helloworld.org/index.html?happy=very")).hasParameter("happy");
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org/index.html")).hasParameter("happy");
       assertThat(new URL("http://www.helloworld.org/index.html?sad=much")).hasParameter("happy");
      Parameters:
      name - the name of the parameter expected to be present.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if the actual does not have the expected parameter.
      IllegalArgumentException - if the query string contains an invalid escape sequence.
    • hasParameter

      public SELF hasParameter(String name, String value)
      Verifies that the actual URL has a parameter with the expected name and value.

      Use null to indicate an absent value (e.g. foo&bar) as opposed to an empty value (e.g. foo=&bar=).

      Examples:

       // These assertions succeed:
       assertThat(new URL("http://www.helloworld.org/index.html?happy")).hasParameter("happy", null);
       assertThat(new URL("http://www.helloworld.org/index.html?happy=very")).hasParameter("happy", "very");
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org/index.html?sad")).hasParameter("sad", "much");
       assertThat(new URL("http://www.helloworld.org/index.html?sad=much")).hasParameter("sad", null);
      Parameters:
      name - the name of the parameter expected to be present.
      value - the value of the parameter expected to be present.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if the actual does not have the expected parameter.
      IllegalArgumentException - if the query string contains an invalid escape sequence.
    • hasNoParameters

      public SELF hasNoParameters()
      Verifies that the actual URL does not have any parameters.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("http://www.helloworld.org/index.html")).hasNoParameters();
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org/index.html?sad")).hasNoParameters();
       assertThat(new URL("http://www.helloworld.org/index.html?sad=much")).hasNoParameters();
      Returns:
      this assertion object.
      Throws:
      AssertionError - if actual has a parameter.
      IllegalArgumentException - if the query string contains an invalid escape sequence.
      Since:
      2.5.0 / 3.5.0
    • hasNoParameter

      public SELF hasNoParameter(String name)
      Verifies that the actual URL does not have a parameter with the specified name.

      The value of the parameter is not checked.

      Examples:

       // This assertion succeeds:
       assertThat(new URL("http://www.helloworld.org/index.html")).hasNoParameter("happy");
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org/index.html?sad")).hasNoParameter("sad");
       assertThat(new URL("http://www.helloworld.org/index.html?sad=much")).hasNoParameter("sad");
      Parameters:
      name - the name of the parameter expected to be absent.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if actual has the expected parameter.
      IllegalArgumentException - if the query string contains an invalid escape sequence.
      Since:
      2.5.0 / 3.5.0
    • hasNoParameter

      public SELF hasNoParameter(String name, String value)
      Verifies that the actual URL does not have a parameter with the expected name and value.

      Use null to indicate an absent value (e.g. foo&bar) as opposed to an empty value (e.g. foo=&bar=).

      Examples:

       // These assertions succeed:
       assertThat(new URL("http://www.helloworld.org/index.html")).hasNoParameter("happy", "very");
       assertThat(new URL("http://www.helloworld.org/index.html?happy")).hasNoParameter("happy", "very");
       assertThat(new URL("http://www.helloworld.org/index.html?happy=very")).hasNoParameter("happy", null);
      
       // These assertions fail:
       assertThat(new URL("http://www.helloworld.org/index.html?sad")).hasNoParameter("sad", null);
       assertThat(new URL("http://www.helloworld.org/index.html?sad=much")).hasNoParameter("sad", "much");
      Parameters:
      name - the name of the parameter expected to be absent.
      value - the value of the parameter expected to be absent.
      Returns:
      this assertion object.
      Throws:
      AssertionError - if actual has the expected parameter.
      IllegalArgumentException - if the query string contains an invalid escape sequence.
      Since:
      2.5.0 / 3.5.0
    • isEqualToWithSortedQueryParameters

      public SELF isEqualToWithSortedQueryParameters(URL expected)
      Verifies that the actual URL is equivalent to the given one after their parameters are sorted.

      Example:

       URL url = new URL("http://example.com?a=b&c=d");
      
       // this assertion succeeds ...
       assertThat(url).isEqualToWithSortedQueryParameters(new URL("http://example.com?c=d&a=b"))
                      .isEqualToWithSortedQueryParameters(new URL("http://example.com?a=b&c=d"));
      
       // ... but this one fails as parameters do not match.
       assertThat(url).isEqualToWithSortedQueryParameters(new URL("http://example.com?a=b&c=e"));
      
       //... and this one fails as domains are different.
       assertThat(url).isEqualToWithSortedQueryParameters(new URL("http://example2.com?amp;a=b&c=d")); 
      Parameters:
      expected - the expected URL to compare actual to.
      Returns:
      this assertion object.
      Throws:
      NullPointerException - if the given URL is null.
      AssertionError - if the actual URL is null.
      AssertionError - if the actual URL is not equivalent to the given one after their parameters are sorted.
      Since:
      3.16.0