public class MockRequestContext extends java.lang.Object implements RequestContext
RequestContext
interface to facilitate standalone flow artifact (e.g. action)
unit tests.RequestContext
,
Action
Constructor and Description |
---|
MockRequestContext()
Convenience constructor that creates a new mock request context with the following defaults:
A mock flow execution context with a active session of flow "mockFlow" in state "mockState".
|
MockRequestContext(Flow flow)
Convenience constructor that creates a new mock request context with the following defaults:
A mock flow execution context with an active session for the specified flow.
|
MockRequestContext(FlowExecutionContext flowExecutionContext)
Creates a new mock request context with the provided flow execution context.
|
MockRequestContext(ParameterMap requestParameterMap)
Convenience constructor that creates a new mock request context with the following defaults:
A mock flow execution context with a active session of flow "mockFlow" in state "mockState".
|
Modifier and Type | Method and Description |
---|---|
FlowDefinition |
getActiveFlow()
Returns the definition of the flow that is currently executing.
|
MutableAttributeMap |
getAttributeMap()
Returns the contained mutable context
attribute map allowing setting of mock context
attributes. |
MutableAttributeMap |
getAttributes()
Returns a context map for accessing attributes about the state of the current request.
|
MutableAttributeMap |
getConversationScope()
Returns a mutable accessor for accessing and/or setting attributes in conversation scope.
|
Event |
getCurrentEvent()
Returns the current event being processed by this flow.
|
StateDefinition |
getCurrentState()
Returns the current state of the executing flow.
|
TransitionDefinition |
getCurrentTransition()
Returns the current transition executing in this request.
|
View |
getCurrentView()
Returns the current view in use; if not null, the view returned is about to be rendered, is rendering, is
processing a user event, or has finished user event processing and the current ViewState is exiting due to a
state transition.
|
ExternalContext |
getExternalContext()
Returns the external client context that originated (or triggered) this request.
|
MutableAttributeMap |
getFlashScope()
Returns a mutable map for accessing and/or setting attributes in flash scope.
|
FlowExecutionContext |
getFlowExecutionContext()
Returns contextual information about the flow execution itself.
|
java.lang.String |
getFlowExecutionUrl()
Returns the URL of this flow execution.
|
MutableAttributeMap |
getFlowScope()
Returns a mutable map for accessing and/or setting attributes in flow scope.
|
TransitionDefinition |
getMatchingTransition(java.lang.String eventId)
Returns the transition that would execute on the occurrence of the given event.
|
MessageContext |
getMessageContext()
Returns the message context of this request.
|
MockExternalContext |
getMockExternalContext()
Returns the external context as a
MockExternalContext . |
MockFlowExecutionContext |
getMockFlowExecutionContext()
Returns the flow execution context as a
MockFlowExecutionContext . |
ParameterMap |
getRequestParameters()
Returns the immutable input parameters associated with this request into Spring Web Flow.
|
MutableAttributeMap |
getRequestScope()
Returns a mutable map for accessing and/or setting attributes in request scope.
|
Flow |
getRootFlow()
Returns the root flow definition for this request context.
|
MutableAttributeMap |
getViewScope()
Returns a mutable map for accessing and/or setting attributes in view scope.
|
boolean |
inViewState()
Returns true if the flow is currently active and in a view state.
|
void |
putRequestParameter(java.lang.String parameterName,
org.springframework.web.multipart.MultipartFile parameterValue)
Puts a MultipartFile request parameter into the mock parameter map.
|
void |
putRequestParameter(java.lang.String parameterName,
java.lang.String parameterValue)
Adds a request parameter to the configured external context.
|
void |
putRequestParameter(java.lang.String parameterName,
java.lang.String[] parameterValues)
Adds a multi-valued request parameter to the configured external context.
|
void |
removeAttribute(java.lang.String attributeName)
Remove a request context attribute.
|
void |
sendFlowExecutionRedirect() |
void |
setActiveSession(FlowSession flowSession)
Sets the active flow session of the executing flow associated with this request.
|
void |
setAttribute(java.lang.String attributeName,
java.lang.Object attributeValue)
Set a request context attribute.
|
void |
setCurrentEvent(Event event)
Set the current event being processed by this flow.
|
void |
setCurrentTransition(Transition transition)
Set the current transition executing in this request context.
|
void |
setCurrentView(View currentView)
Set the current view in this request context.
|
void |
setExternalContext(ExternalContext externalContext)
Sets the external context.
|
void |
setFlowExecutionContext(FlowExecutionContext flowExecutionContext)
Sets the flow execution context.
|
public MockRequestContext()
putRequestParameter(String, String)
method.public MockRequestContext(Flow flow)
putRequestParameter(String, String)
method.flow
- the flow definitionpublic MockRequestContext(ParameterMap requestParameterMap)
public MockRequestContext(FlowExecutionContext flowExecutionContext)
putRequestParameter(String, String)
method.flowExecutionContext
- the flow execution contextpublic FlowDefinition getActiveFlow()
RequestContext
getActiveFlow
in interface RequestContext
FlowExecutionContext.isActive()
public StateDefinition getCurrentState()
RequestContext
null
if the active flow's start state has
not yet been entered.getCurrentState
in interface RequestContext
null
if in the process of startingFlowExecutionContext.isActive()
public TransitionDefinition getMatchingTransition(java.lang.String eventId) throws java.lang.IllegalStateException
RequestContext
getMatchingTransition
in interface RequestContext
eventId
- the id of the user eventnull
if no transition matchesjava.lang.IllegalStateException
- if this flow execution is not activeFlowExecutionContext.isActive()
public boolean inViewState()
RequestContext
RequestContext.getViewScope()
,
can be safely called.inViewState
in interface RequestContext
RequestContext.getViewScope()
public MutableAttributeMap getRequestScope()
RequestContext
getRequestScope
in interface RequestContext
public MutableAttributeMap getFlashScope()
RequestContext
getFlashScope
in interface RequestContext
public MutableAttributeMap getViewScope() throws java.lang.IllegalStateException
RequestContext
getViewScope
in interface RequestContext
java.lang.IllegalStateException
- if this flow is not in a view-state or the flow execution is not activeRequestContext.inViewState()
,
FlowExecutionContext.isActive()
public MutableAttributeMap getFlowScope()
RequestContext
getFlowScope
in interface RequestContext
FlowSession
,
FlowExecutionContext.isActive()
public MutableAttributeMap getConversationScope()
RequestContext
getConversationScope
in interface RequestContext
FlowExecutionContext
public ParameterMap getRequestParameters()
RequestContext
This is typically a convenient shortcut for accessing the ExternalContext.getRequestParameterMap()
directly.
getRequestParameters
in interface RequestContext
RequestContext.getExternalContext()
public MessageContext getMessageContext()
RequestContext
getMessageContext
in interface RequestContext
public ExternalContext getExternalContext()
RequestContext
Acting as a facade, the returned context object provides a single point of access to the calling client's environment. It provides normalized access to attributes of the client environment without tying you to specific constructs within that environment.
In addition, this context may be downcastable to a specific context type for a specific client environment, such as Servlets or Portlets. Such downcasting will give you full access to a native HttpServletRequest, for example. With that said, for portability reasons you should avoid coupling your flow artifacts to a specific deployment environment when possible.
getExternalContext
in interface RequestContext
public FlowExecutionContext getFlowExecutionContext()
RequestContext
getFlowExecutionContext
in interface RequestContext
public Event getCurrentEvent()
RequestContext
getCurrentEvent
in interface RequestContext
public TransitionDefinition getCurrentTransition()
RequestContext
getCurrentTransition
in interface RequestContext
null
if no transition has occurred yetpublic View getCurrentView()
RequestContext
null
if the flow is not in a view state.getCurrentView
in interface RequestContext
null
if the flow is not in a view statepublic MutableAttributeMap getAttributes()
RequestContext
getAttributes
in interface RequestContext
public java.lang.String getFlowExecutionUrl()
RequestContext
getFlowExecutionUrl
in interface RequestContext
public void sendFlowExecutionRedirect()
public void setActiveSession(FlowSession flowSession)
getActiveFlow()
and getCurrentState()
, as well as getFlowScope()
and
getFlashScope()
.public void setExternalContext(ExternalContext externalContext)
public void setFlowExecutionContext(FlowExecutionContext flowExecutionContext)
public void setCurrentEvent(Event event)
event
- the current eventpublic void setCurrentTransition(Transition transition)
transition
- the current transition to setpublic void setCurrentView(View currentView)
currentView
- the current viewpublic void setAttribute(java.lang.String attributeName, java.lang.Object attributeValue)
attributeName
- the attribute nameattributeValue
- the attribute valuepublic void removeAttribute(java.lang.String attributeName)
attributeName
- the attribute namepublic void putRequestParameter(java.lang.String parameterName, java.lang.String parameterValue)
parameterName
- the parameter nameparameterValue
- the parameter valuepublic void putRequestParameter(java.lang.String parameterName, java.lang.String[] parameterValues)
parameterName
- the parameter nameparameterValues
- the parameter valuespublic void putRequestParameter(java.lang.String parameterName, org.springframework.web.multipart.MultipartFile parameterValue)
parameterName
- the parameter nameparameterValue
- the parameter valuepublic Flow getRootFlow()
Flow
implementation.public MutableAttributeMap getAttributeMap()
attribute map
allowing setting of mock context
attributes.public MockFlowExecutionContext getMockFlowExecutionContext()
MockFlowExecutionContext
.public MockExternalContext getMockExternalContext()
MockExternalContext
.