I copy and paste your 2 clases, and add to my project, then i add in
persistence.xml and finally i run the enhancement and works:

[openjpa:enhance]
108  kx_mailing  INFO   [main] openjpa.Tool - Enhancer running on type
"mytest.RiskFactor".
496  kx_mailing  INFO   [main] openjpa.Tool - Enhancer running on type
"mytest.MarketData".

Dont forget to add them in your persistence.xml

<class>mytest.RiskFactor</class>
<class>mytest.MarketData</class>


2012/11/19 Boblitz John <john.bobl...@bertschi.com>

> Actually, mine works just fine!
>
> I choose to annotate the attributes instead of the methodes, but here is
> an example:
>
> @Entity
> @Table(name = "UserGroup")
> public class UserGroup extends BaseEntity {
>
> [snip]
>
>         @ManyToMany(mappedBy = "userGroups")
>         private Set<Users> users;
>
> }
>
> @Entity
> @Table(name = "Users")
> public class Users extends BaseEntity {
>
> [snip]
>
>         @ManyToMany
>         @JoinTable(name = "UserGroupMember", joinColumns =
> @JoinColumn(name = "userid"), inverseJoinColumns = @JoinColumn(name =
> "groupid"))
>         private Set<UserGroup> userGroups;
>
> }
>
>
>
>
> > -----Ursprüngliche Nachricht-----
> > Von: Chris Wolf [mailto:cwolf.a...@gmail.com]
> > Gesendet: Montag, 19. November 2012 16:29
> > An: users@openjpa.apache.org
> > Betreff: Re: cannot persist m2m data, getting
> > "ArgumentException: Attempt to cast instance xxx
> > [java.util.HashSet]" to PersistenceCapable failed. Ensure
> > that it has been enhanced."
> >
> > José,
> >
> > The plugin doc says you can have a comma-delimited list of
> > classes, however, since enhancement on collection classes
> > doesn't seem to work anyway - per your suggestion, I removed
> > "java.util.ArrayList" and re-ran the "mvn openjpa:enhance" command.
> >
> > The result, as ever, is still:
> >
> > 771  openjpa  INFO   [main] openjpa.Enhance - Creating subclass and
> > redefining methods for
> > "[class java.util.ArrayList]". This means that your
> > application will be less efficient than it would if you ran
> > the OpenJPA enhancer.
> > Exception in thread "main" <openjpa-2.2.0-r422266:1244990
> > fatal user error>
> > org.apache.openjpa.persistence.ArgumentException: No
> > registered metadata for type  "class java.util.ArrayList".
> > This can happen if this class has not been annotated as a
> > persistent entity or specified in the persistence unit (ex:
> > in the orm.xml).
> >
> > I wonder if anyone knows of a working example of many-to-many
> > ORM using OpenJPA?
> >
> > Thanks,
> >
> >    -Chris
> >
> >
> > On Mon, Nov 19, 2012 at 10:19 AM, José Luis Cetina
> > <maxtorz...@gmail.com> wrote:
> > > And I think you don't have to set arraylist class or any
> > java "native"
> > > class as enhance class. Only your entities have to be enhancement.
> > > El 19/11/2012 09:12, "José Luis Cetina"
> > <maxtorz...@gmail.com> escribió:
> > >
> > >> I'm not sure if the include tag accept more than 1 class.
> > >>
> > >> You have:
> > >> <includes>**/entities/*.class,java.util.ArrayList.class</includes>
> > >>
> > >> Try to remove java.util.ArrayList.
> > >> El 19/11/2012 09:05, "Chris Wolf" <cwolf.a...@gmail.com> escribió:
> > >>
> > >>> José,
> > >>>
> > >>> Thanks - I sent the two entities to John (this list).
> > The pom.xml
> > >>> is attached...
> > >>>
> > >>>     -Chris
> > >>>
> > >>>
> > >>>
> > >>> On Mon, Nov 19, 2012 at 9:54 AM, José Luis Cetina
> > >>> <maxtorz...@gmail.com>
> > >>> wrote:
> > >>> > Please send your 2 entities and your pom configuration whit the
> > >>> > enhance plugin.
> > >>> > El 19/11/2012 08:46, "Chris Wolf"
> > <cwolf.a...@gmail.com> escribió:
> > >>> >
> > >>> >> José,
> > >>> >>
> > >>> >> I tried List/ArrayList - same error.  Thanks....
> > >>> >>
> > >>> >>    -Chris
> > >>> >>
> > >>> >> On Sun, Nov 18, 2012 at 9:47 PM, José Luis Cetina <
> > >>> maxtorz...@gmail.com>
> > >>> >> wrote:
> > >>> >> > Of course I'm using 1-M relationships but I use them
> > with List
> > >>> >> > not
> > >>> >> hashset,
> > >>> >> > why you dont give a try to list only for look if the
> > problem is
> > >>> >> > with hashset.
> > >>> >> > El 18/11/2012 19:59, "Chris Wolf"
> > <cwolf.a...@gmail.com> escribió:
> > >>> >> >
> > >>> >> >> José,
> > >>> >> >>
> > >>> >> >> Thanks for your reply.  My pom.xml setup is very similar to
> > >>> >> >> yours
> > >>> and
> > >>> >> >> the "enhance" goal  runs without error, but, as I mentioned,
> > >>> >> >> I still get the error on "casting
> > java.util.HashSet".   Are you able
> > >>> >> >> to persist entities with 1-M or M-M relationships?
> > >>> >> >>
> > >>> >> >> BTW, I changed my code to temporarily change JPA
> > provider from
> > >>> OpenJPA
> > >>> >> >> to the Hibernate JPA provider
> > >>> >> >> and, once again, Hibernate's JPA reports:
> > >>> >> >>
> > >>> >> >> Exception in thread "main"
> > java.lang.IllegalArgumentException:
> > >>> Unknown
> > >>> >> >> entity: java.util.HashSet
> > >>> >> >>         at
> > >>> >> >>
> > >>> >>
> > >>>
> > org.hibernate.ejb.AbstractEntityManagerImpl.persist(AbstractEntityMa
> > >>> nagerImpl.java:671)
> > >>> >> >>
> > >>> >> >> Well, at least both JPA implementations are
> > complaining about
> > >>> >> >> the
> > >>> same
> > >>> >> >> issue - I just wish I knew
> > >>> >> >> what I was doing!   I know I can get this to work
> > in an instant by
> > >>> >> >> reverting to Hibernate-only
> > >>> >> >> solution, but I was hoping the byte-code weaving of
> > JPA would
> > >>> >> >> be a performance advantage over Hibernate's
> > reflection/proxy
> > >>> >> >> pattern.
> > >>> >> >>
> > >>> >> >> Thanks again,
> > >>> >> >>
> > >>> >> >>     -Chris
> > >>> >> >>
> > >>> >> >> On Sun, Nov 18, 2012 at 1:26 PM, José Luis Cetina <
> > >>> maxtorz...@gmail.com
> > >>> >> >
> > >>> >> >> wrote:
> > >>> >> >> > I have this in my pom.xml for ENHANCMENT and works:
> > >>> >> >> >
> > >>> >> >> > <!--OPENJPA ENHANCMENT-->
> > >>> >> >> >             <plugin>
> > >>> >> >> >                 <groupId>org.apache.openjpa</groupId>
> > >>> >> >> >
> > <artifactId>openjpa-maven-plugin</artifactId>
> > >>> >> >> >                 <version>2.2.0</version>
> > >>> >> >> >                 <configuration>
> > >>> >> >> >
> > >>> >> >> > <includes>mypackage/model/*.class</includes>
> > >>> >> >> >
> > >>> >> <addDefaultConstructor>true</addDefaultConstructor>
> > >>> >> >> >
> > >>> >> >> >
> > <enforcePropertyRestrictions>true</enforcePropertyRestrictio
> > >>> >> >> > ns>
> > >>> >> >> >
> > >>> >> >> >
> > <connectionDriverName>com.mysql.jdbc.Driver</connectionDriverName>
> > >>> >> >> >                     <connectionProperties>
> > >>> >> >> >
> > driverClass=${database.driver.name},
> > >>> >> >> >
> > jdbcUrl=${database.connection.url},
> > >>> >> >> >                         user=${database.user},
> > >>> >> >> >                         password=${database.password},
> > >>> >> >> >                         minPoolSize=5,
> > >>> >> >> >                         acquireRetryAttempts=3,
> > >>> >> >> >                         maxPoolSize=20
> > >>> >> >> >                     </connectionProperties>
> > >>> >> >> >                 </configuration>
> > >>> >> >> >                 <executions>
> > >>> >> >> >                     <execution>
> > >>> >> >> >                         <id>enhancer</id>
> > >>> >> >> >                         <phase>process-classes</phase>
> > >>> >> >> >                         <goals>
> > >>> >> >> >                             <goal>enhance</goal>
> > >>> >> >> >                         </goals>
> > >>> >> >> >                     </execution>
> > >>> >> >> >                 </executions>
> > >>> >> >> >                 <dependencies>
> > >>> >> >> >                     <dependency>
> > >>> >> >> >
> > <groupId>org.apache.openjpa</groupId>
> > >>> >> >> >                         <artifactId>openjpa</artifactId>
> > >>> >> >> >                         <version>2.2.0</version>
> > >>> >> >> >                     </dependency>
> > >>> >> >> >                 </dependencies>
> > >>> >> >> >             </plugin>
> > >>> >> >> >
> > >>> >> >> > In my persistence.xml i have:
> > >>> >> >> >
> > >>> >> >> >      <property name="openjpa.ConnectionUserName"
> > >>> >> value="${db.username}"/>
> > >>> >> >> >       <property name="openjpa.ConnectionPassword"
> > >>> >> >> value="${db.password}"/>
> > >>> >> >> >       <property name="openjpa.ConnectionURL"
> > value="${db.url}"/>
> > >>> >> >> >       <property name="openjpa.ConnectionDriverName"
> > >>> >> >> > value="${db.driver.class}"/>
> > >>> >> >> >
> > >>> >> >> > You can replace the database properties in
> > persistence.xml
> > >>> >> >> > with
> > >>> your
> > >>> >> own
> > >>> >> >> > values
> > >>> (${db.username},${db.password},${db.url},${db.driver.class}).
> > >>> >> >> >
> > >>> >> >> >
> > >>> >> >> > I use this configuration for my JEE Projects.
> > >>> >> >> >
> > >>> >> >> > Maybe this can help you.
> > >>> >> >> >
> > >>> >> >> > Regards.
> > >>> >> >> >
> > >>> >> >> > SCJA. JL Cetina
> > >>> >> >> >
> > >>> >> >> >
> > >>> >> >> > 2012/11/18 Chris Wolf <cwolf.a...@gmail.com>
> > >>> >> >> >
> > >>> >> >> >> I wrote a shell script to directly invoke PCEnhancer on
> > >>> >> >> >> class java.util.HashSet, and even that didn't work:
> > >>> >> >> >>
> > >>> >> >> >> $ ./enhance.sh
> > >>> >> >> >> 52  openjpa  INFO   [main] openjpa.Tool -
> > Enhancer running on
> > >>> type
> > >>> >> >> >> "java.util.HashSet".
> > >>> >> >> >> Exception in thread "main" java.lang.RuntimeException:
> > >>> >> >> >> java.io.FileNotFoundExcep
> > >>> >> >> >> tion:
> > >>> >> >> >> file:\C:\opt\jdk\jre\lib\rt.jar!\java\util\HashSet.class
> > >>> (The
> > >>> >> >> >> filename, directory name, or volume label syntax
> > is incorrect)
> > >>> >> >> >>         at
> > >>> >> >> >>
> > >>> >> >>
> > >>> >>
> > >>>
> > org.apache.openjpa.lib.conf.Configurations.launchRunnable(Configurat
> > >>> ions.java:744)
> > >>> >> >> >>
> > >>> >> >> >> On Sun, Nov 18, 2012 at 10:37 AM, Chris Wolf <
> > >>> cwolf.a...@gmail.com>
> > >>> >> >> wrote:
> > >>> >> >> >> > Hello,
> > >>> >> >> >> >
> > >>> >> >> >> > This is my first posting and first attempt to use
> > >>> >> >> >> > OpenJPA.  I
> > >>> put
> > >>> >> >> >> > together a quick demo and can persist individual,
> > >>> >> >> >> > unrelated entities.  However, when I try to persist
> > >>> >> >> >> > related entities to two tables via a link table, i.e.
> > >>> many-2-many,
> > >>> >> >> >> > it keeps complaining about "casting to
> > >>> >> >> >> > PersistenceCapable", in particular the class
> > "java.util.HashSet".
> > >>> >> >> >> >
> > >>> >> >> >> > First, I am using the Eclipse JPA plugin
> > (called "Dali"
> > >>> >> >> >> > or "EclipseLink").  Of course, I have OpenJPA
> > configured
> > >>> >> >> >> > as my JPA provider, I am in a plain Java SE
> > environment
> > >>> >> >> >> > with LOCAL_RESOURCE via JDBC connection
> > properties in the
> > >>> >> >> >> > persistence.xml.  I am using Sun/Oracle 64bit
> > >>> >> >> >> > JDK-1.6 and OpenJPA-2.2.0.
> > >>> >> >> >> >
> > >>> >> >> >> > I am using the Eclipse JPA plugin to generate
> > the entity
> > >>> classes
> > >>> >> from
> > >>> >> >> >> > already-exiting database schema objects, and that code
> > >>> >> >> >> > looks like (just pasting the relationship code),
> > >>> this
> > >>> >> >> >> > action also adds these classes to persistence.xml via
> > >>> >> >> >> > persistence-unit/class elements.
> > >>> >> >> >> >
> > >>> >> >> >> > First M2M entity, "MarketData":
> > >>> >> >> >> >
> > >>> >> >> >> >         //bi-directional many-to-many
> > association to RiskFactor
> > >>> >> >> >> >         @ManyToMany(mappedBy="marketData")
> > >>> >> >> >> >         public Set<RiskFactor> getRiskFactors() {
> > >>> >> >> >> >                 return this.riskFactors;
> > >>> >> >> >> >         }
> > >>> >> >> >> >
> > >>> >> >> >> > Second M2M entity "RiskFactor":
> > >>> >> >> >> >
> > >>> >> >> >> >         //bi-directional many-to-many
> > association to MarketData
> > >>> >> >> >> >     @ManyToMany
> > >>> >> >> >> >         @JoinTable(
> > >>> >> >> >> >                 name="MARKET_DATA__RISK_FACTOR"
> > >>> >> >> >> >                 , joinColumns={
> > >>> >> >> >> >
> > >>> >> >> >> > @JoinColumn(name="RISK_FACTOR_ID",
> > >>> >> >> >> nullable=false)
> > >>> >> >> >> >                         }
> > >>> >> >> >> >                 , inverseJoinColumns={
> > >>> >> >> >> >
> > >>> >> >> >> > @JoinColumn(name="MARKET_DATA_ID",
> > >>> >> >> >> nullable=false)
> > >>> >> >> >> >                         }
> > >>> >> >> >> >                 )
> > >>> >> >> >> >         public Set<MarketData> getMarketData() {
> > >>> >> >> >> >                 return this.marketData;
> > >>> >> >> >> >         }
> > >>> >> >> >> >
> > >>> >> >> >> > When I run the code, the log indicates implicit runtime
> > >>> enhacement,
> > >>> >> >> >> > yet it is complaining:
> > >>> >> >> >> >
> > >>> >> >> >> > "[persistdemo.ojpa.entities.RiskFactor@61578aab]
> > >>> >> [java.util.HashSet]"
> > >>> >> >> >> > to PersistenceCapable failed.  Ensure that it has been
> > >>> enhanced."
> > >>> >> >> >> >
> > >>> >> >> >> > ...when it says, "Ensure that it has been enhanced." -
> > >>> >> >> >> > which is
> > >>> >> "it"
> > >>> >> >> >> > referring to?  The entity "RiskFactor" or the field
> > >>> relationship
> > >>> >> >> >> > field's class, "java.util.HashSet"?
> > >>> >> >> >> >
> > >>> >> >> >> >
> > >>> >> >> >> > 186  openjpa  INFO   [main] openjpa.Runtime - OpenJPA
> > >>> dynamically
> > >>> >> >> >> > loaded the class enhancer. Any classes that were not
> > >>> >> >> >> > enhanced
> > >>> at
> > >>> >> build
> > >>> >> >> >> > time will be enhanced when they are loaded by the JVM.
> > >>> >> >> >> > SLF4J: Failed to load class
> > >>> "org.slf4j.impl.StaticLoggerBinder".
> > >>> >> >> >> > SLF4J: Defaulting to no-operation (NOP) logger
> > >>> >> >> >> > implementation
> > >>> >> >> >> > SLF4J: See
> > >>> >> >> >> > http://www.slf4j.org/codes.html#StaticLoggerBinderfor
> > >>> >> >> >> > further details.
> > >>> >> >> >> > 243  openjpa  INFO   [main] openjpa.Runtime - OpenJPA
> > >>> dynamically
> > >>> >> >> >> > loaded a validation provider.
> > >>> >> >> >> > 596  openjpa  INFO   [main] openjpa.Runtime -
> > Starting OpenJPA
> > >>> >> 2.2.0
> > >>> >> >> >> > 630  openjpa  INFO   [main] openjpa.jdbc.JDBC - Using
> > >>> dictionary
> > >>> >> class
> > >>> >> >> >> > "org.apache.openjpa.jdbc.sql.OracleDictionary".
> > >>> >> >> >> > Exception in thread "main"
> > <openjpa-2.2.0-r422266:1244990
> > >>> nonfatal
> > >>> >> >> >> > user error>
> > org.apache.openjpa.persistence.ArgumentException:
> > >>> >> Attempt
> > >>> >> >> >> > to cast instance
> > >>> "[persistdemo.ojpa.entities.RiskFactor@61578aab]
> > >>> >> >> >> > [java.util.HashSet]" to PersistenceCapable failed.
> > >>> >> >> >> > Ensure
> > >>> that it
> > >>> >> has
> > >>> >> >> >> > been enhanced.
> > >>> >> >> >> >
> > >>> >> >> >> > Maybe because "java.util.HashSet" was loaded
> > before the
> > >>> >> >> >> > dynamic enhancer could get to it?
> > >>> >> >> >> >
> > >>> >> >> >> > Next, I tried performing build-time enhancement via
> > >>> >> >> >> > Maven, per
> > >>> this
> > >>> >> >> doc:
> > >>> >> >> >> > http://openjpa.apache.org/enhancement-with-maven.html
> > >>> >> >> >> >
> > >>> >> >> >> > When I ran "mvn openjpa:enhance", it finished with
> > >>> >> >> >> > success, but
> > >>> >> none
> > >>> >> >> >> > of the classes in target/classes seemed to have be
> > >>> >> >> >> > changed (last-modified date same as
> > compile-time).  and
> > >>> >> >> >> > re-running
> > >>> results
> > >>> >> in
> > >>> >> >> >> > the same error and stack-trace.
> > >>> >> >> >> >
> > >>> >> >> >> > My openjpa:enhance configuration was:
> > >>> >> >> >> > <configuration>
> > >>> >> >> >> >
> > <includes>**/entities/*.class,java.util.HashSet</includes>
> > >>> >> >> >> >
> > <addDefaultConstructor>true</addDefaultConstructor>
> > >>> >> >> >> >
> > >>> >>
> > <enforcePropertyRestrictions>true</enforcePropertyRestrictions>
> > >>> >> >> >> > </configuration>
> > >>> >> >> >> >
> > >>> >> >> >> >
> > >>> >> >> >> > Next, I tried invoking with:
> > >>> >> >> >> >
> > >>> >> >> >> >
> > -javaagent:/opt/apache-openjpa-2.2.0/openjpa-all-2.2.0.ja
> > >>> >> >> >> > r
> > >>> >> >> >> >
> > >>> >> >> >> > Same error - same stack trace.
> > >>> >> >> >> >
> > >>> >> >> >> > Then, I tried setting this property:
> > >>> >> >> >> > openjpa.RuntimeUnenhancedClasses=supported
> > >>> >> >> >> >
> > >>> >> >> >> > Same error - same stack trace.
> > >>> >> >> >> >
> > >>> >> >> >> >
> > >>> >> >> >> > Then, following a suggestion I found here:
> > >>> >> >> >> >
> > >>> >> >> >>
> > >>> >> >>
> > >>> >>
> > >>>
> > http://openjpa.208410.n2.nabble.com/JPA-adding-entities-to-EntityMan
> > >>> agerFactory-programmatically-td210697.html
> > >>> >> >> >> >
> > >>> >> >> >> > I tried setting both:
> > >>> >> >> >> > openjpa.RuntimeUnenhancedClasses=supported
> > >>> >> >> >> > openjpa.MetaDataFactory=jpa(Types=java.util.HashSet)
> > >>> >> >> >> >
> > >>> >> >> >> > BTW, this is a dead link
> > >>> >> >> >> > "User's Guide on Enhancement" /
> > >>> >> >> >> >
> > >>> >> >> >>
> > >>> >> >>
> > >>> >>
> > >>>
> > http://openjpa.apache.org/builds/latest/docs/manual/manual.html#ref_
> > >>> guide_pc_enhance
> > >>> >> >> >> > (from page:
> > >>> >> >> >> > http://openjpa.apache.org/entity-enhancement.html)
> > >>> >> >> >> >
> > >>> >> >> >> > So is there any way to use OpenJPA to persist objects
> > >>> >> >> >> > related
> > >>> via a
> > >>> >> >> >> > link table?  (there obviously must be, but
> > it's a total
> > >>> >> >> >> > mystery to me)  I can't believe it's this
> > >>> >> difficult,
> > >>> >> >> >> > I must be doing something really dumb.
> > >>> >> >> >> >
> > >>> >> >> >> > Regards,
> > >>> >> >> >> >
> > >>> >> >> >> > CW
> > >>> >> >> >>
> > >>> >> >> >
> > >>> >> >> >
> > >>> >> >> >
> > >>> >> >> > --
> > >>> >> >> >
> > >>>
> > -------------------------------------------------------------------
> > >>> >> >> > *SCJA. José Luis Cetina*
> > >>> >> >> >
> > >>>
> > -------------------------------------------------------------------
> > >>> >> >>
> > >>> >>
> > >>>
> > >>
> >
>



-- 
-------------------------------------------------------------------
*SCJA. José Luis Cetina*
-------------------------------------------------------------------

Reply via email to