org.springframework.test.web
Class ModelAndViewAssert

java.lang.Object
  extended by org.springframework.test.web.ModelAndViewAssert

public abstract class ModelAndViewAssert
extends java.lang.Object

A collection of assertions intended to simplify testing scenarios dealing with Spring Web MVC ModelAndView objects.

Intended for use with JUnit 4 and TestNG. All assert*() methods throw AssertionErrors.

Since:
2.5
Author:
Sam Brannen, Alef Arendsen, Bram Smeets
See Also:
ModelAndView

Constructor Summary
ModelAndViewAssert()
           
 
Method Summary
private static void appendNonMatchingSetsErrorMessage(java.util.Set<java.lang.String> assertionSet, java.util.Set<java.lang.String> incorrectSet, java.lang.StringBuilder sb)
           
static
<T> T
assertAndReturnModelAttributeOfType(ModelAndView mav, java.lang.String modelName, java.lang.Class<T> expectedType)
          Checks whether the model value under the given modelName exists and checks it type, based on the expectedType.
static void assertCompareListModelAttribute(ModelAndView mav, java.lang.String modelName, java.util.List expectedList)
          Compare each individual entry in a list, without first sorting the lists.
private static void assertCondition(boolean condition, java.lang.String message)
          Assert the provided boolean condition, throwing AssertionError with the supplied message if the test result is false.
static void assertModelAttributeAvailable(ModelAndView mav, java.lang.String modelName)
          Assert whether or not a model attribute is available.
static void assertModelAttributeValue(ModelAndView mav, java.lang.String modelName, java.lang.Object expectedValue)
          Compare a given expectedValue to the value from the model bound under the given modelName.
static void assertModelAttributeValues(ModelAndView mav, java.util.Map<java.lang.String,java.lang.Object> expectedModel)
          Inspect the expectedModel to see if all elements in the model appear and are equal.
static void assertSortAndCompareListModelAttribute(ModelAndView mav, java.lang.String modelName, java.util.List expectedList, java.util.Comparator comparator)
          Compare each individual entry in a list after having sorted both lists (optionally using a comparator).
static void assertViewName(ModelAndView mav, java.lang.String expectedName)
          Check to see if the view name in the ModelAndView matches the given expectedName.
private static void fail(java.lang.String message)
          Fails by throwing an AssertionError with the supplied message.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

ModelAndViewAssert

public ModelAndViewAssert()
Method Detail

assertAndReturnModelAttributeOfType

public static <T> T assertAndReturnModelAttributeOfType(ModelAndView mav,
                                                        java.lang.String modelName,
                                                        java.lang.Class<T> expectedType)
Checks whether the model value under the given modelName exists and checks it type, based on the expectedType. If the model entry exists and the type matches, the model value is returned.

Parameters:
mav - ModelAndView to test against (never null)
modelName - name of the object to add to the model (never null)
expectedType - expected type of the model value
Returns:
the model value

assertCompareListModelAttribute

public static void assertCompareListModelAttribute(ModelAndView mav,
                                                   java.lang.String modelName,
                                                   java.util.List expectedList)
Compare each individual entry in a list, without first sorting the lists.

Parameters:
mav - ModelAndView to test against (never null)
modelName - name of the object to add to the model (never null)
expectedList - the expected list

assertModelAttributeAvailable

public static void assertModelAttributeAvailable(ModelAndView mav,
                                                 java.lang.String modelName)
Assert whether or not a model attribute is available.

Parameters:
mav - ModelAndView to test against (never null)
modelName - name of the object to add to the model (never null)

assertModelAttributeValue

public static void assertModelAttributeValue(ModelAndView mav,
                                             java.lang.String modelName,
                                             java.lang.Object expectedValue)
Compare a given expectedValue to the value from the model bound under the given modelName.

Parameters:
mav - ModelAndView to test against (never null)
modelName - name of the object to add to the model (never null)
expectedValue - the model value

assertModelAttributeValues

public static void assertModelAttributeValues(ModelAndView mav,
                                              java.util.Map<java.lang.String,java.lang.Object> expectedModel)
Inspect the expectedModel to see if all elements in the model appear and are equal.

Parameters:
mav - ModelAndView to test against (never null)
expectedModel - the expected model

assertSortAndCompareListModelAttribute

public static void assertSortAndCompareListModelAttribute(ModelAndView mav,
                                                          java.lang.String modelName,
                                                          java.util.List expectedList,
                                                          java.util.Comparator comparator)
Compare each individual entry in a list after having sorted both lists (optionally using a comparator).

Parameters:
mav - ModelAndView to test against (never null)
modelName - name of the object to add to the model (never null)
expectedList - the expected list
comparator - the comparator to use (may be null). If not specifying the comparator, both lists will be sorted not using any comparator.

assertViewName

public static void assertViewName(ModelAndView mav,
                                  java.lang.String expectedName)
Check to see if the view name in the ModelAndView matches the given expectedName.

Parameters:
mav - ModelAndView to test against (never null)
expectedName - the name of the model value

fail

private static void fail(java.lang.String message)
Fails by throwing an AssertionError with the supplied message.

Parameters:
message - the exception message to use
See Also:
assertCondition(boolean,String)

assertCondition

private static void assertCondition(boolean condition,
                                    java.lang.String message)
Assert the provided boolean condition, throwing AssertionError with the supplied message if the test result is false.

Parameters:
condition - a boolean expression
message - the exception message to use if the assertion fails
See Also:
fail(String)

appendNonMatchingSetsErrorMessage

private static void appendNonMatchingSetsErrorMessage(java.util.Set<java.lang.String> assertionSet,
                                                      java.util.Set<java.lang.String> incorrectSet,
                                                      java.lang.StringBuilder sb)