Robert Matthews created ISIS-236:
------------------------------------

             Summary: Classes that are not referenced in the DOM aren't found 
by the specification loader
                 Key: ISIS-236
                 URL: https://issues.apache.org/jira/browse/ISIS-236
             Project: Isis
          Issue Type: Bug
          Components: Core: MetaModel
    Affects Versions: 0.3.0-incubating
            Reporter: Robert Matthews


For example: if you have a field that uses an interface (eg Address) and it 
returns a concrete type (eg EmailAddress) but that type is not explicitly 
referred to elsewhere (as a return type or parameter) then the 
SpecificationLoader will never see it. Hence, if that class gets used (eg an 
EmailAddress is retrieved from persistent memory)  then an exception will occur.

The best long term solution is to load all classes from the Jar(s) that contain 
the DOM code.  This could be indicated by placing a marker, such as a file, in 
the metadata.of the Jar.

In the meantime a simple workaround is to add a method, typically to a service, 
that uses the concrete class and mark it as hidden. Give the method a name that 
makes it clear what the method is there for so nobody tries to use it.

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: 
https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira

        

Reply via email to