Class AbstractJsonContentAssert<SELF extends AbstractJsonContentAssert<SELF>>

java.lang.Object
org.assertj.core.api.AbstractAssert<SELF,ACTUAL>
org.assertj.core.api.AbstractCharSequenceAssert<SELF,String>
org.assertj.core.api.AbstractStringAssert<SELF>
org.springframework.test.json.AbstractJsonContentAssert<SELF>
Type Parameters:
SELF - the type of assertions
All Implemented Interfaces:
org.assertj.core.api.Assert<SELF,String>, org.assertj.core.api.Descriptable<SELF>, org.assertj.core.api.EnumerableAssert<SELF,Character>, org.assertj.core.api.ExtensionPoints<SELF,String>
Direct Known Subclasses:
JsonContentAssert

public abstract class AbstractJsonContentAssert<SELF extends AbstractJsonContentAssert<SELF>> extends org.assertj.core.api.AbstractStringAssert<SELF>
Base AssertJ assertions that can be applied to a JSON document.

Supports evaluating JSON path expressions and extracting a part of the document for further assertions on the value.

Also supports comparing the JSON document against a target, using JSON Assert. Resources that are loaded from the classpath can be relative if a class is provided. By default, UTF-8 is used to load resources, but this can be overridden using withCharset(Charset).

Since:
6.2
Author:
Stephane Nicoll, Phillip Webb, Andy Wilkinson, Diego Berrueta, Camille Vienot
  • Field Summary

    Fields inherited from class org.assertj.core.api.AbstractAssert

    actual, info, myself, objects, throwUnsupportedExceptionOnEquals
  • Constructor Summary

    Constructors
    Modifier
    Constructor
    Description
    protected
    AbstractJsonContentAssert(String json, GenericHttpMessageConverter<Object> jsonMessageConverter, Class<?> selfType)
    Create an assert for the given JSON document.
  • Method Summary

    Modifier and Type
    Method
    Description
    Verify that the given JSON path does not match.
    Verify that the given JSON path is present, and extract the JSON value for further assertions.
    Verify that the given JSON path matches.
    hasPathSatisfying(String path, Consumer<org.assertj.core.api.AssertProvider<JsonPathValueAssert>> valueRequirements)
    Verify that the given JSON path is present with a JSON value satisfying the given valueRequirements.
    isEqualTo(CharSequence expected, org.skyscreamer.jsonassert.comparator.JSONComparator comparator)
    Verify that the actual value is equal to the given JSON.
    isEqualTo(CharSequence expected, org.skyscreamer.jsonassert.JSONCompareMode compareMode)
    Verify that the actual value is equal to the given JSON.
    isEqualTo(Resource expected, org.skyscreamer.jsonassert.comparator.JSONComparator comparator)
    Verify that the actual value is equal to the given JSON Resource.
    isEqualTo(Resource expected, org.skyscreamer.jsonassert.JSONCompareMode compareMode)
    Verify that the actual value is equal to the given JSON Resource.
    Verify that the actual value is leniently equal to the given JSON.
    Verify that the actual value is leniently equal to the given JSON Resource.
    isNotEqualTo(CharSequence expected, org.skyscreamer.jsonassert.comparator.JSONComparator comparator)
    Verify that the actual value is not equal to the given JSON.
    isNotEqualTo(CharSequence expected, org.skyscreamer.jsonassert.JSONCompareMode compareMode)
    Verify that the actual value is not equal to the given JSON.
    isNotEqualTo(Resource expected, org.skyscreamer.jsonassert.comparator.JSONComparator comparator)
    Verify that the actual value is not equal to the given JSON Resource.
    isNotEqualTo(Resource expected, org.skyscreamer.jsonassert.JSONCompareMode compareMode)
    Verify that the actual value is not equal to the given JSON Resource.
    Verify that the actual value is not leniently equal to the given JSON.
    Verify that the actual value is not leniently equal to the given JSON Resource.
    Verify that the actual value is not strictly equal to the given JSON.
    Verify that the actual value is not strictly equal to the given JSON Resource.
    Verify that the actual value is strictly equal to the given JSON.
    Verify that the actual value is strictly equal to the given JSON Resource.
    Override the Charset to use to load resources.
    withResourceLoadClass(Class<?> resourceLoadClass)
    Override the class used to load resources.

    Methods inherited from class org.assertj.core.api.AbstractStringAssert

    asBase64Decoded, asBoolean, asByte, asDouble, asFloat, asInt, asLong, asShort, decodedAsBase64, isBase64, isBetween, isEqualTo, isEqualTo, isGreaterThan, isGreaterThanOrEqualTo, isLessThan, isLessThanOrEqualTo, isStrictlyBetween, usingComparator, usingComparator, usingDefaultComparator

    Methods inherited from class org.assertj.core.api.AbstractCharSequenceAssert

    contains, contains, containsAnyOf, containsIgnoringCase, containsIgnoringNewLines, containsIgnoringWhitespaces, containsOnlyDigits, containsOnlyOnce, containsOnlyWhitespaces, containsPattern, containsPattern, containsPatternSatisfying, containsPatternSatisfying, containsSequence, containsSequence, containsSubsequence, containsSubsequence, containsWhitespaces, doesNotContain, doesNotContain, doesNotContainAnyWhitespaces, doesNotContainIgnoringCase, doesNotContainOnlyWhitespaces, doesNotContainPattern, doesNotContainPattern, doesNotEndWith, doesNotEndWithIgnoringCase, doesNotMatch, doesNotMatch, doesNotStartWith, doesNotStartWithIgnoringCase, endsWith, endsWithIgnoringCase, hasLineCount, hasSameSizeAs, hasSameSizeAs, hasSameSizeAs, hasSize, hasSizeBetween, hasSizeGreaterThan, hasSizeGreaterThanOrEqualTo, hasSizeLessThan, hasSizeLessThanOrEqualTo, inHexadecimal, inUnicode, isAlphabetic, isAlphanumeric, isASCII, isBlank, isEmpty, isEqualToIgnoringCase, isEqualToIgnoringNewLines, isEqualToIgnoringWhitespace, isEqualToNormalizingNewlines, isEqualToNormalizingPunctuationAndWhitespace, isEqualToNormalizingUnicode, isEqualToNormalizingWhitespace, isHexadecimal, isJavaBlank, isLowerCase, isMixedCase, isNotBlank, isNotEmpty, isNotEqualToIgnoringCase, isNotEqualToIgnoringWhitespace, isNotEqualToNormalizingWhitespace, isNotJavaBlank, isNullOrEmpty, isPrintable, isSubstringOf, isUpperCase, isVisible, isXmlEqualTo, isXmlEqualToContentOf, matches, matches, matchesSatisfying, matchesSatisfying, startsWith, startsWithIgnoringCase, usingDefaultElementComparator, usingElementComparator

    Methods inherited from class org.assertj.core.api.AbstractAssert

    areEqual, asInstanceOf, asList, assertionError, asString, describedAs, descriptionText, doesNotHave, doesNotHaveSameClassAs, doesNotHaveSameHashCodeAs, doesNotHaveToString, doesNotHaveToString, equals, extracting, extracting, failure, failureWithActualExpected, failWithActualExpectedAndMessage, failWithMessage, getWritableAssertionInfo, has, hashCode, hasSameClassAs, hasSameHashCodeAs, hasToString, hasToString, inBinary, is, isElementOfCustomAssert, isEqualTo, isExactlyInstanceOf, isIn, isIn, isInstanceOf, isInstanceOfAny, isInstanceOfSatisfying, isNot, isNotEqualTo, isNotExactlyInstanceOf, isNotIn, isNotIn, isNotInstanceOf, isNotInstanceOfAny, isNotNull, isNotOfAnyClassIn, isNotSameAs, isNull, isOfAnyClassIn, isSameAs, matches, matches, newListAssertInstance, overridingErrorMessage, overridingErrorMessage, satisfies, satisfies, satisfies, satisfiesAnyOf, satisfiesAnyOf, satisfiesAnyOfForProxy, satisfiesForProxy, setCustomRepresentation, setDescriptionConsumer, setPrintAssertionsDescription, throwAssertionError, usingRecursiveAssertion, usingRecursiveAssertion, usingRecursiveComparison, usingRecursiveComparison, withFailMessage, withFailMessage, withRepresentation, withThreadDumpOnError

    Methods inherited from class java.lang.Object

    clone, finalize, getClass, notify, notifyAll, toString, wait, wait, wait

    Methods inherited from interface org.assertj.core.api.Descriptable

    as, as, as, describedAs, describedAs
  • Constructor Details

    • AbstractJsonContentAssert

      protected AbstractJsonContentAssert(@Nullable String json, @Nullable GenericHttpMessageConverter<Object> jsonMessageConverter, Class<?> selfType)
      Create an assert for the given JSON document.

      Path can be converted to a value object using the given JSON message converter.

      Parameters:
      json - the JSON document to assert
      jsonMessageConverter - the converter to use
      selfType - the implementation type of this assert
  • Method Details

    • extractingPath

      public JsonPathValueAssert extractingPath(String path)
      Verify that the given JSON path is present, and extract the JSON value for further assertions.
      Parameters:
      path - the JsonPath expression
      See Also:
    • hasPathSatisfying

      public SELF hasPathSatisfying(String path, Consumer<org.assertj.core.api.AssertProvider<JsonPathValueAssert>> valueRequirements)
      Verify that the given JSON path is present with a JSON value satisfying the given valueRequirements.
      Parameters:
      path - the JsonPath expression
      valueRequirements - a Consumer of the assertion object
    • hasPath

      public SELF hasPath(String path)
      Verify that the given JSON path matches. For paths with an operator, this validates that the path expression is valid, but does not validate that it yield any results.
      Parameters:
      path - the JsonPath expression
    • doesNotHavePath

      public SELF doesNotHavePath(String path)
      Verify that the given JSON path does not match.
      Parameters:
      path - the JsonPath expression
    • isEqualTo

      public SELF isEqualTo(@Nullable CharSequence expected, org.skyscreamer.jsonassert.JSONCompareMode compareMode)
      Verify that the actual value is equal to the given JSON. The expected value can contain the JSON itself or, if it ends with .json, the name of a resource to be loaded from the classpath.
      Parameters:
      expected - the expected JSON or the name of a resource containing the expected JSON
      compareMode - the compare mode used when checking
    • isEqualTo

      public SELF isEqualTo(Resource expected, org.skyscreamer.jsonassert.JSONCompareMode compareMode)
      Verify that the actual value is equal to the given JSON Resource.

      The resource abstraction allows to provide several input types:

      Parameters:
      expected - a resource containing the expected JSON
      compareMode - the compare mode used when checking
    • isEqualTo

      public SELF isEqualTo(@Nullable CharSequence expected, org.skyscreamer.jsonassert.comparator.JSONComparator comparator)
      Verify that the actual value is equal to the given JSON. The expected value can contain the JSON itself or, if it ends with .json, the name of a resource to be loaded from the classpath.
      Parameters:
      expected - the expected JSON or the name of a resource containing the expected JSON
      comparator - the comparator used when checking
    • isEqualTo

      public SELF isEqualTo(Resource expected, org.skyscreamer.jsonassert.comparator.JSONComparator comparator)
      Verify that the actual value is equal to the given JSON Resource.

      The resource abstraction allows to provide several input types:

      Parameters:
      expected - a resource containing the expected JSON
      comparator - the comparator used when checking
    • isLenientlyEqualTo

      public SELF isLenientlyEqualTo(@Nullable CharSequence expected)
      Verify that the actual value is leniently equal to the given JSON. The expected value can contain the JSON itself or, if it ends with .json, the name of a resource to be loaded from the classpath.
      Parameters:
      expected - the expected JSON or the name of a resource containing the expected JSON
    • isLenientlyEqualTo

      public SELF isLenientlyEqualTo(Resource expected)
      Verify that the actual value is leniently equal to the given JSON Resource.

      The resource abstraction allows to provide several input types:

      Parameters:
      expected - a resource containing the expected JSON
    • isStrictlyEqualTo

      public SELF isStrictlyEqualTo(@Nullable CharSequence expected)
      Verify that the actual value is strictly equal to the given JSON. The expected value can contain the JSON itself or, if it ends with .json, the name of a resource to be loaded from the classpath.
      Parameters:
      expected - the expected JSON or the name of a resource containing the expected JSON
    • isStrictlyEqualTo

      public SELF isStrictlyEqualTo(Resource expected)
      Verify that the actual value is strictly equal to the given JSON Resource.

      The resource abstraction allows to provide several input types:

      Parameters:
      expected - a resource containing the expected JSON
    • isNotEqualTo

      public SELF isNotEqualTo(@Nullable CharSequence expected, org.skyscreamer.jsonassert.JSONCompareMode compareMode)
      Verify that the actual value is not equal to the given JSON. The expected value can contain the JSON itself or, if it ends with .json, the name of a resource to be loaded from the classpath.
      Parameters:
      expected - the expected JSON or the name of a resource containing the expected JSON
      compareMode - the compare mode used when checking
    • isNotEqualTo

      public SELF isNotEqualTo(Resource expected, org.skyscreamer.jsonassert.JSONCompareMode compareMode)
      Verify that the actual value is not equal to the given JSON Resource.

      The resource abstraction allows to provide several input types:

      Parameters:
      expected - a resource containing the expected JSON
      compareMode - the compare mode used when checking
    • isNotEqualTo

      public SELF isNotEqualTo(@Nullable CharSequence expected, org.skyscreamer.jsonassert.comparator.JSONComparator comparator)
      Verify that the actual value is not equal to the given JSON. The expected value can contain the JSON itself or, if it ends with .json, the name of a resource to be loaded from the classpath.
      Parameters:
      expected - the expected JSON or the name of a resource containing the expected JSON
      comparator - the comparator used when checking
    • isNotEqualTo

      public SELF isNotEqualTo(Resource expected, org.skyscreamer.jsonassert.comparator.JSONComparator comparator)
      Verify that the actual value is not equal to the given JSON Resource.

      The resource abstraction allows to provide several input types:

      Parameters:
      expected - a resource containing the expected JSON
      comparator - the comparator used when checking
    • isNotLenientlyEqualTo

      public SELF isNotLenientlyEqualTo(@Nullable CharSequence expected)
      Verify that the actual value is not leniently equal to the given JSON. The expected value can contain the JSON itself or, if it ends with .json, the name of a resource to be loaded from the classpath.
      Parameters:
      expected - the expected JSON or the name of a resource containing the expected JSON
    • isNotLenientlyEqualTo

      public SELF isNotLenientlyEqualTo(Resource expected)
      Verify that the actual value is not leniently equal to the given JSON Resource.

      The resource abstraction allows to provide several input types:

      Parameters:
      expected - a resource containing the expected JSON
    • isNotStrictlyEqualTo

      public SELF isNotStrictlyEqualTo(@Nullable CharSequence expected)
      Verify that the actual value is not strictly equal to the given JSON. The expected value can contain the JSON itself or, if it ends with .json, the name of a resource to be loaded from the classpath.
      Parameters:
      expected - the expected JSON or the name of a resource containing the expected JSON
    • isNotStrictlyEqualTo

      public SELF isNotStrictlyEqualTo(Resource expected)
      Verify that the actual value is not strictly equal to the given JSON Resource.

      The resource abstraction allows to provide several input types:

      Parameters:
      expected - a resource containing the expected JSON
    • withResourceLoadClass

      public SELF withResourceLoadClass(@Nullable Class<?> resourceLoadClass)
      Override the class used to load resources.

      Resources can be loaded from an absolute location or relative to the specified class. For instance, specifying com.example.MyClass as the resource class allows you to use "my-file.json" to load /com/example/my-file.json.

      Parameters:
      resourceLoadClass - the class used to load resources, or null to only use absolute paths
    • withCharset

      public SELF withCharset(@Nullable Charset charset)
      Override the Charset to use to load resources.

      By default, resources are loaded using UTF-8.

      Parameters:
      charset - the charset to use, or null to use the default