[ 
https://issues.apache.org/jira/browse/ISIS-1599?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Andi Huber reopened ISIS-1599:
------------------------------
      Assignee: Andi Huber  (was: Dan Haywood)

Reopening, because by now it's only partly solved. We need to think about what 
we actually want here, either:

1) Simple behavior (as currently implemented): 
 Any collection passed to an Action or 'Supporting Method' (as parameter) is an 
ArrayList, no matter the actual Collection type returned by the 'Supporting 
Methods'. This is counter-intuitive but once users are aware of, not much of an 
issue.

2) Advanced behavior:
 For Action's and 'Supporting Method's' parameters (and possibly return types 
of these), we could support these concrete Interfaces:
 * Collection
 * List
 * Set
 * SortedSet

But no other. Metadata validation would throw an error, if any other Collection 
type is used or when there is a 'Supporting Method' return type to receiver 
parameter type mismatch. This is slightly more intuitive than option 1) and 
allows for a slightly more flexible domain model.

> "Set" interface does not work as an action parameter's collection  type
> -----------------------------------------------------------------------
>
>                 Key: ISIS-1599
>                 URL: https://issues.apache.org/jira/browse/ISIS-1599
>             Project: Isis
>          Issue Type: Bug
>          Components: Core
>    Affects Versions: 1.14.0
>            Reporter: Tadas Giniotis
>            Assignee: Andi Huber
>            Priority: Minor
>             Fix For: 2.0.0-M1
>
>
> When using a Set<MyClass> as a parameter for an action -> it throws an 
> exception when using that action. The same works correctly when using 
> List<MyClass>.
> {quote}
> ...
>  java.lang.IllegalArgumentException
> argument type mismatch
> sun.reflect.NativeMethodAccessorImpl#invoke0(null:-2)
> sun.reflect.NativeMethodAccessorImpl#invoke(null:-1)
> sun.reflect.DelegatingMethodAccessorImpl#invoke(null:-1)
> java.lang.reflect.Method#invoke(null:-1)
> org.apache.isis.core.metamodel.facets.actions.action.invocation.ActionInvocationFacetForDomainEventAbstract#invokeMethodElseFromCache(ActionInvocationFacetForDomainEventAbstract.java:408)
> org.apache.isis.core.metamodel.facets.actions.action.invocation.ActionInvocationFacetForDomainEventAbstract$2#execute(ActionInvocationFacetForDomainEventAbstract.java:262)
> org.apache.isis.core.metamodel.facets.actions.action.invocation.ActionInvocationFacetForDomainEventAbstract$2#execute(ActionInvocationFacetForDomainEventAbstract.java:223)
> org.apache.isis.applib.services.iactn.Interaction#executeInternal(Interaction.java:173)
> org.apache.isis.applib.services.iactn.Interaction#execute(Interaction.java:143)
>  
> ...
> {quote}



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to