<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0" /> <base href="https://hibernate.atlassian.net" />
<title>Message Title</title>
</head>
<body class="jira" style="color: #333; font-family: Arial, sans-serif; font-size: 14px; line-height: 1.429">
<table id="background-table" cellpadding="0" cellspacing="0" width="100%" style="border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt; background-color: #f5f5f5; border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt">
<!-- header here -->
<tr>
<td id="header-pattern-container" style="padding: 0px; border-collapse: collapse; padding: 10px 20px">
<table id="header-pattern" cellspacing="0" cellpadding="0" border="0" style="border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt">
<tr>
<td id="header-avatar-image-container" valign="top" style="padding: 0px; border-collapse: collapse; vertical-align: top; width: 32px; padding-right: 8px"> <img id="header-avatar-image" class="image_fix" src="https://secure.gravatar.com/avatar/5f43b809e03b71b1e9df26dbd9bae949?d=mm&s=48" height="32" width="32" border="0" style="border-radius: 3px; vertical-align: top" />
</td>
<td id="header-text-container" valign="middle" style="padding: 0px; border-collapse: collapse; vertical-align: middle; font-family: Arial, sans-serif; font-size: 14px; line-height: 20px; mso-line-height-rule: exactly; mso-text-raise: 1px"> <a class="user-hover" rel="Frank Ellison" id="email_Frank Ellison" href="https://hibernate.atlassian.net/secure/ViewProfile.jspa?name=Frank+Ellison" style="color:#6c797f;; color: #3b73af; text-decoration: none">Frank Ellison</a> <strong>created</strong> an issue
</td>
</tr>
</table>
</td>
</tr>
<tr>
<td id="email-content-container" style="padding: 0px; border-collapse: collapse; padding: 0 20px">
<table id="email-content-table" cellspacing="0" cellpadding="0" border="0" width="100%" style="border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt; border-spacing: 0; border-collapse: separate">
<tr>
<!-- there needs to be content in the cell for it to render in some clients -->
<td class="email-content-rounded-top mobile-expand" style="padding: 0px; border-collapse: collapse; color: #fff; padding: 0 15px 0 16px; height: 15px; background-color: #fff; border-left: 1px solid #ccc; border-top: 1px solid #ccc; border-right: 1px solid #ccc; border-bottom: 0; border-top-right-radius: 5px; border-top-left-radius: 5px; height: 10px; line-height: 10px; padding: 0 15px 0 16px; mso-line-height-rule: exactly">
</td>
</tr>
<tr>
<td class="email-content-main mobile-expand " style="padding: 0px; border-collapse: collapse; border-left: 1px solid #ccc; border-right: 1px solid #ccc; border-top: 0; border-bottom: 0; padding: 0 15px 0 16px; background-color: #fff">
<table class="page-title-pattern" cellspacing="0" cellpadding="0" border="0" width="100%" style="border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt">
<tr>
<td class="page-title-pattern-first-line " style="padding: 0px; border-collapse: collapse; font-family: Arial, sans-serif; font-size: 14px; padding-top: 10px"> <a href="https://hibernate.atlassian.net/browse/HHH" style="color: #3b73af; text-decoration: none">Hibernate ORM</a> / <a href="https://hibernate.atlassian.net/browse/HHH-9108" style="color: #3b73af; text-decoration: none"><img src="cid:jira-generated-image-static-bug-ed03942c-0e5d-466d-aec2-b014e366b2c0" height="16" width="16" border="0" align="absmiddle" alt="Bug" style="vertical-align: text-bottom" /></a> <a href="https://hibernate.atlassian.net/browse/HHH-9108" style="color: #3b73af; text-decoration: none">HHH-9108</a>
</td>
</tr>
<tr>
<td style="vertical-align: top;; padding: 0px; border-collapse: collapse; padding-right: 5px; font-size: 20px; line-height: 30px; mso-line-height-rule: exactly" class="page-title-pattern-header-container"> <span class="page-title-pattern-header" style="font-family: Arial, sans-serif; padding: 0; font-size: 20px; line-height: 30px; mso-text-raise: 2px; mso-line-height-rule: exactly; vertical-align: middle"> <a href="https://hibernate.atlassian.net/browse/HHH-9108" style="color: #3b73af; text-decoration: none">Envers with Embeddable having a collection of other entities results in PropertyAccessException: IllegalArgumentException</a> </span>
</td>
</tr>
</table>
</td>
</tr>
<tr>
<td class="email-content-main mobile-expand wrapper-special-margin" style="padding: 0px; border-collapse: collapse; border-left: 1px solid #ccc; border-right: 1px solid #ccc; border-top: 0; border-bottom: 0; padding: 0 15px 0 16px; background-color: #fff; padding-top: 10px; padding-bottom: 5px">
<table class="keyvalue-table" style="border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt">
<tr>
<th style="color: #707070; font: normal 14px/20px Arial, sans-serif; text-align: left; vertical-align: top; padding: 2px 0">
Issue Type:
</th>
<td class="has-icon" style="padding: 0px; border-collapse: collapse; font: normal 14px/20px Arial, sans-serif; padding: 2px 0 2px 5px; vertical-align: top"> <img src="cid:jira-generated-image-static-bug-ed03942c-0e5d-466d-aec2-b014e366b2c0" height="16" width="16" border="0" align="absmiddle" alt="Bug" style="vertical-align: text-bottom" /> Bug
</td>
</tr>
<tr>
<th style="color: #707070; font: normal 14px/20px Arial, sans-serif; text-align: left; vertical-align: top; padding: 2px 0">
Affects Versions:
</th>
<td style="padding: 0px; border-collapse: collapse; font: normal 14px/20px Arial, sans-serif; padding: 2px 0 2px 5px; vertical-align: top">
4.3.5
</td>
</tr>
<tr>
<th style="color: #707070; font: normal 14px/20px Arial, sans-serif; text-align: left; vertical-align: top; padding: 2px 0">
Assignee:
</th>
<td style="padding: 0px; border-collapse: collapse; font: normal 14px/20px Arial, sans-serif; padding: 2px 0 2px 5px; vertical-align: top">
Unassigned
</td>
</tr>
<tr>
<th style="color: #707070; font: normal 14px/20px Arial, sans-serif; text-align: left; vertical-align: top; padding: 2px 0">
Attachments:
</th>
<td style="padding: 0px; border-collapse: collapse; font: normal 14px/20px Arial, sans-serif; padding: 2px 0 2px 5px; vertical-align: top">
hhh-9105.zip
</td>
</tr>
<tr>
<th style="color: #707070; font: normal 14px/20px Arial, sans-serif; text-align: left; vertical-align: top; padding: 2px 0">
Components:
</th>
<td style="padding: 0px; border-collapse: collapse; font: normal 14px/20px Arial, sans-serif; padding: 2px 0 2px 5px; vertical-align: top">
envers
</td>
</tr>
<tr>
<th style="color: #707070; font: normal 14px/20px Arial, sans-serif; text-align: left; vertical-align: top; padding: 2px 0">
Created:
</th>
<td style="padding: 0px; border-collapse: collapse; font: normal 14px/20px Arial, sans-serif; padding: 2px 0 2px 5px; vertical-align: top">
08/Apr/14 7:53 AM
</td>
</tr>
<tr>
<th style="color: #707070; font: normal 14px/20px Arial, sans-serif; text-align: left; vertical-align: top; padding: 2px 0">
Environment:
</th>
<td style="padding: 0px; border-collapse: collapse; font: normal 14px/20px Arial, sans-serif; padding: 2px 0 2px 5px; vertical-align: top">
Hibernate 4.3.5.Final <br /> Databases: HSQLDB or Microsoft SQL Server 2008 R2
</td>
</tr>
<tr>
<th style="color: #707070; font: normal 14px/20px Arial, sans-serif; text-align: left; vertical-align: top; padding: 2px 0">
Labels:
</th>
<td style="padding: 0px; border-collapse: collapse; font: normal 14px/20px Arial, sans-serif; padding: 2px 0 2px 5px; vertical-align: top">
envers
</td>
</tr>
<tr>
<th style="color: #707070; font: normal 14px/20px Arial, sans-serif; text-align: left; vertical-align: top; padding: 2px 0">
Priority:
</th>
<td class="has-icon" style="padding: 0px; border-collapse: collapse; font: normal 14px/20px Arial, sans-serif; padding: 2px 0 2px 5px; vertical-align: top"> <img src="cid:jira-generated-image-static-major-994a7265-ad4a-4c81-9752-34f03ad404d5" height="16" width="16" border="0" align="absmiddle" alt="Major" style="vertical-align: text-bottom" /> Major
</td>
</tr>
<tr>
<th style="color: #707070; font: normal 14px/20px Arial, sans-serif; text-align: left; vertical-align: top; padding: 2px 0">
Reporter:
</th>
<td style="padding: 0px; border-collapse: collapse; font: normal 14px/20px Arial, sans-serif; padding: 2px 0 2px 5px; vertical-align: top"> <a class="user-hover" rel="Frank Ellison" id="email_Frank Ellison" href="https://hibernate.atlassian.net/secure/ViewProfile.jspa?name=Frank+Ellison" style="color:#6c797f;; color: #3b73af; text-decoration: none">Frank Ellison</a>
</td>
</tr>
</table>
</td>
</tr>
<tr>
<td class="email-content-main mobile-expand issue-description-container" style="padding: 0px; border-collapse: collapse; border-left: 1px solid #ccc; border-right: 1px solid #ccc; border-top: 0; border-bottom: 0; padding: 0 15px 0 16px; background-color: #fff; padding-top: 5px; padding-bottom: 10px">
<table class="text-paragraph-pattern" cellspacing="0" cellpadding="0" border="0" width="100%" style="border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt; font-family: Arial, sans-serif; font-size: 14px; line-height: 20px; mso-line-height-rule: exactly; mso-text-raise: 2px">
<tr>
<td class="text-paragraph-pattern-container mobile-resize-text " style="padding: 0px; border-collapse: collapse; padding: 0 0 10px 0">
<p style="margin-top:0;margin-bottom:10px;; margin: 10px 0 0 0">It is impossible to save with Envers Auditing enabled when the model has an embeddable that has a collection of other entities.</p>
<div class="preformatted panel" style="border-width: 1px;; border: 1px solid #ccc; background: #f5f5f5; font-size: 12px; line-height: 1.333; font-family: monospace; border: 1px solid #ccc; -moz-border-radius: 3px 3px 3px 3px; border-radius: 3px 3px 3px 3px; margin: 9px 0">
<div class="preformattedContent panelContent" style="padding: 9px 12px">
<pre style="margin: 10px 0 0 0; max-height: 30em; overflow: auto; white-space: pre-wrap; word-wrap: normal; white-space: pre; word-break: normal; word-wrap: break-word; word-break: break-word; white-space: pre-wrap">org.hibernate.PropertyAccessException: IllegalArgumentException occurred calling getter of org.hibernate.bugs.Item.header
        at org.hibernate.property.BasicPropertyAccessor$BasicGetter.get(BasicPropertyAccessor.java:192)
        at org.hibernate.property.BasicPropertyAccessor$BasicGetter.getForInsert(BasicPropertyAccessor.java:204)
        at org.hibernate.tuple.entity.AbstractEntityTuplizer.getPropertyValuesToInsert(AbstractEntityTuplizer.java:624)
        at org.hibernate.tuple.entity.PojoEntityTuplizer.getPropertyValuesToInsert(PojoEntityTuplizer.java:382)
        at org.hibernate.persister.entity.AbstractEntityPersister.getPropertyValuesToInsert(AbstractEntityPersister.java:4817)
        at org.hibernate.event.internal.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:267)
        at org.hibernate.event.internal.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:194)
        at org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:125)
        at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:209)
        at org.hibernate.event.internal.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:55)
        at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:194)
        at org.hibernate.event.internal.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:49)
        at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:90)
        at org.hibernate.internal.SessionImpl.fireSave(SessionImpl.java:715)
        at org.hibernate.internal.SessionImpl.save(SessionImpl.java:707)
        at org.hibernate.envers.strategy.DefaultAuditStrategy.performCollectionChange(DefaultAuditStrategy.java:41)
        at org.hibernate.envers.internal.synchronization.work.PersistentCollectionChangeWorkUnit.perform(PersistentCollectionChangeWorkUnit.java:97)
        at org.hibernate.envers.internal.synchronization.AuditProcess.executeInSession(AuditProcess.java:119)
        at org.hibernate.envers.internal.synchronization.AuditProcess.doBeforeTransactionCompletion(AuditProcess.java:161)
        at org.hibernate.envers.internal.synchronization.AuditProcessManager$1.doBeforeTransactionCompletion(AuditProcessManager.java:63)
        at org.hibernate.engine.spi.ActionQueue$BeforeTransactionCompletionProcessQueue.beforeTransactionCompletion(ActionQueue.java:715)
        at org.hibernate.engine.spi.ActionQueue.beforeTransactionCompletion(ActionQueue.java:389)
        at org.hibernate.internal.SessionImpl.beforeTransactionCompletion(SessionImpl.java:516)
        at org.hibernate.engine.transaction.internal.jdbc.JdbcTransaction.beforeTransactionCommit(JdbcTransaction.java:105)
        at org.hibernate.engine.transaction.spi.AbstractTransactionImpl.commit(AbstractTransactionImpl.java:177)
        at org.hibernate.bugs.Hhh9105.testEmbeddableWithCollection(Hhh9105.java:74)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:601)
        at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
        at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
        at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
        at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
        at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
        at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271)
        at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70)
        at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
        at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
        at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
        at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
        at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
        at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
        at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
        at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
        at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
        at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
        at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
        at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
        at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: java.lang.IllegalArgumentException: object is not an instance of declaring class
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:601)
        at org.hibernate.property.BasicPropertyAccessor$BasicGetter.get(BasicPropertyAccessor.java:169)
        ... 49 more
</pre>
</div>
</div>
<div class="code panel" style="border-width: 1px;; border: 1px solid #ccc; background: #f5f5f5; font-size: 12px; line-height: 1.333; font-family: monospace; border: 1px solid #ccc; -moz-border-radius: 3px 3px 3px 3px; border-radius: 3px 3px 3px 3px; margin: 9px 0">
<div class="codeHeader panelHeader" style="border-bottom-width: 1px;; border-bottom: 1px solid #ccc; padding: 9px 12px">
<b>Header.java</b>
</div>
<div class="codeContent panelContent" style="padding: 9px 12px">
<pre class="code-java" style="margin: 10px 0 0 0; max-height: 30em; overflow: auto; white-space: pre-wrap; word-wrap: normal">
@Audited
@Entity
@Table(name = <span class="code-quote" style="color: #009100">"ENVERS_HEADER"</span>)
<span class="code-keyword" style="color: #000091">public</span> class Header {
        <span class="code-keyword" style="color: #000091">private</span> <span class="code-object" style="color: #910091">Long</span> id;
        
        <span class="code-keyword" style="color: #000091">private</span> <span class="code-object" style="color: #910091">String</span> name;
        
        <span class="code-keyword" style="color: #000091">private</span> EmbeddableWithCollection embeddableWithCollection;
        
        <span class="code-keyword" style="color: #000091">public</span> Header() {
                
        }
        @Id
        @GeneratedValue
        <span class="code-keyword" style="color: #000091">public</span> <span class="code-object" style="color: #910091">Long</span> getId() {
                <span class="code-keyword" style="color: #000091">return</span> id;
        }
        <span class="code-keyword" style="color: #000091">public</span> void setId(<span class="code-object" style="color: #910091">Long</span> id) {
                <span class="code-keyword" style="color: #000091">this</span>.id = id;
        }
        @Column
        <span class="code-keyword" style="color: #000091">public</span> <span class="code-object" style="color: #910091">String</span> getName() {
                <span class="code-keyword" style="color: #000091">return</span> name;
        }
        <span class="code-keyword" style="color: #000091">public</span> void setName(<span class="code-object" style="color: #910091">String</span> name) {
                <span class="code-keyword" style="color: #000091">this</span>.name = name;
        }
        @Embedded
        <span class="code-keyword" style="color: #000091">public</span> EmbeddableWithCollection getEmbeddableWithCollection() {
                <span class="code-keyword" style="color: #000091">return</span> embeddableWithCollection;
        }
        <span class="code-keyword" style="color: #000091">public</span> void setEmbeddableWithCollection(EmbeddableWithCollection embeddableWithCollection) {
                <span class="code-keyword" style="color: #000091">if</span> (embeddableWithCollection != <span class="code-keyword" style="color: #000091">null</span>) {
                        <span class="code-keyword" style="color: #000091">this</span>.embeddableWithCollection = embeddableWithCollection;
                } <span class="code-keyword" style="color: #000091">else</span> <span class="code-keyword" style="color: #000091">if</span> (<span class="code-keyword" style="color: #000091">this</span>.embeddableWithCollection != <span class="code-keyword" style="color: #000091">null</span>) {
                        <span class="code-keyword" style="color: #000091">this</span>.embeddableWithCollection.getItems().clear();
                }
        }
}
</pre>
</div>
</div>
<div class="code panel" style="border-width: 1px;; border: 1px solid #ccc; background: #f5f5f5; font-size: 12px; line-height: 1.333; font-family: monospace; border: 1px solid #ccc; -moz-border-radius: 3px 3px 3px 3px; border-radius: 3px 3px 3px 3px; margin: 9px 0">
<div class="codeHeader panelHeader" style="border-bottom-width: 1px;; border-bottom: 1px solid #ccc; padding: 9px 12px">
<b>Item.java</b>
</div>
<div class="codeContent panelContent" style="padding: 9px 12px">
<pre class="code-java" style="margin: 10px 0 0 0; max-height: 30em; overflow: auto; white-space: pre-wrap; word-wrap: normal">
@Entity
@Table(name = <span class="code-quote" style="color: #009100">"ENVERS_ITEM"</span>)
@Audited
<span class="code-keyword" style="color: #000091">public</span> class Item {
        
        <span class="code-keyword" style="color: #000091">private</span> <span class="code-object" style="color: #910091">Long</span> id;
        
        <span class="code-keyword" style="color: #000091">private</span> <span class="code-object" style="color: #910091">String</span> name;
        
        <span class="code-keyword" style="color: #000091">private</span> Header header;
        
        <span class="code-keyword" style="color: #000091">private</span> <span class="code-object" style="color: #910091">Integer</span> position;
        
        <span class="code-keyword" style="color: #000091">public</span> Item() {
                
        }
        @Id
        @GeneratedValue
        <span class="code-keyword" style="color: #000091">public</span> <span class="code-object" style="color: #910091">Long</span> getId() {
                <span class="code-keyword" style="color: #000091">return</span> id;
        }
        <span class="code-keyword" style="color: #000091">public</span> void setId(<span class="code-object" style="color: #910091">Long</span> id) {
                <span class="code-keyword" style="color: #000091">this</span>.id = id;
        }
        @Column
        <span class="code-keyword" style="color: #000091">public</span> <span class="code-object" style="color: #910091">String</span> getName() {
                <span class="code-keyword" style="color: #000091">return</span> name;
        }
        <span class="code-keyword" style="color: #000091">public</span> void setName(<span class="code-object" style="color: #910091">String</span> name) {
                <span class="code-keyword" style="color: #000091">this</span>.name = name;
        }
        @ManyToOne
        @JoinColumn(name = <span class="code-quote" style="color: #009100">"C_HDR"</span>, insertable = <span class="code-keyword" style="color: #000091">false</span>, updatable = <span class="code-keyword" style="color: #000091">false</span>, nullable = <span class="code-keyword" style="color: #000091">false</span>)
        <span class="code-keyword" style="color: #000091">public</span> Header getHeader() {
                <span class="code-keyword" style="color: #000091">return</span> header;
        }
        <span class="code-keyword" style="color: #000091">public</span> void setHeader(Header header) {
                <span class="code-keyword" style="color: #000091">this</span>.header = header;
        }
        @Column(name = <span class="code-quote" style="color: #009100">"C_POSITION"</span>, insertable = <span class="code-keyword" style="color: #000091">false</span>, updatable = <span class="code-keyword" style="color: #000091">false</span>)
        <span class="code-keyword" style="color: #000091">public</span> <span class="code-object" style="color: #910091">Integer</span> getPosition() {
                <span class="code-keyword" style="color: #000091">return</span> position;
        }
        <span class="code-keyword" style="color: #000091">public</span> void setPosition(<span class="code-object" style="color: #910091">Integer</span> position) {
                <span class="code-keyword" style="color: #000091">this</span>.position = position;
        }
}
</pre>
</div>
</div>
<div class="code panel" style="border-width: 1px;; border: 1px solid #ccc; background: #f5f5f5; font-size: 12px; line-height: 1.333; font-family: monospace; border: 1px solid #ccc; -moz-border-radius: 3px 3px 3px 3px; border-radius: 3px 3px 3px 3px; margin: 9px 0">
<div class="codeHeader panelHeader" style="border-bottom-width: 1px;; border-bottom: 1px solid #ccc; padding: 9px 12px">
<b>EmbeddableWithCollection.java</b>
</div>
<div class="codeContent panelContent" style="padding: 9px 12px">
<pre class="code-java" style="margin: 10px 0 0 0; max-height: 30em; overflow: auto; white-space: pre-wrap; word-wrap: normal">
@Embeddable
@Audited
<span class="code-keyword" style="color: #000091">public</span> class EmbeddableWithCollection {
        
        <span class="code-keyword" style="color: #000091">private</span> List<Item> items;
        
        <span class="code-keyword" style="color: #000091">public</span> EmbeddableWithCollection() {
                
        }
        @OneToMany(fetch = FetchType.EAGER, cascade = CascadeType.ALL, orphanRemoval = <span class="code-keyword" style="color: #000091">true</span>)
        @JoinColumn(name = <span class="code-quote" style="color: #009100">"C_HDR"</span>, foreignKey = @ForeignKey(name = <span class="code-quote" style="color: #009100">"ENVERS_ITEM_FK_ENVERS_HEADER"</span>), nullable = <span class="code-keyword" style="color: #000091">false</span>)
        @OrderColumn(name = <span class="code-quote" style="color: #009100">"C_POSITION"</span>, nullable = <span class="code-keyword" style="color: #000091">false</span>)
        @AuditMappedBy(mappedBy = <span class="code-quote" style="color: #009100">"header"</span>, positionMappedBy = <span class="code-quote" style="color: #009100">"position"</span>)
        <span class="code-keyword" style="color: #000091">public</span> List<Item> getItems() {
                <span class="code-keyword" style="color: #000091">return</span> items;
        }
        <span class="code-keyword" style="color: #000091">public</span> void setItems(List<Item> items) {
                <span class="code-keyword" style="color: #000091">this</span>.items = items;
        }
}
</pre>
</div>
</div>
<p style="margin-top:0;margin-bottom:10px;; margin: 10px 0 0 0">Test Code project structure taken from <a href="https://hibernate.atlassian.net/browse/HHH-9105" title="Generic test case for bug reports" class="issue-link" data-issue-key="HHH-9105" style="color: #3b73af; text-decoration: none">HHH-9105</a> attachment.</p>
<div class="code panel" style="border-width: 1px;; border: 1px solid #ccc; background: #f5f5f5; font-size: 12px; line-height: 1.333; font-family: monospace; border: 1px solid #ccc; -moz-border-radius: 3px 3px 3px 3px; border-radius: 3px 3px 3px 3px; margin: 9px 0">
<div class="codeHeader panelHeader" style="border-bottom-width: 1px;; border-bottom: 1px solid #ccc; padding: 9px 12px">
<b>Test.java</b>
</div>
<div class="codeContent panelContent" style="padding: 9px 12px">
<pre class="code-java" style="margin: 10px 0 0 0; max-height: 30em; overflow: auto; white-space: pre-wrap; word-wrap: normal">
<span class="code-keyword" style="color: #000091">public</span> class Hhh9105 {
        <span class="code-keyword" style="color: #000091">private</span> Configuration config;
        <span class="code-keyword" style="color: #000091">private</span> SessionFactory sessionFactory;
        @SuppressWarnings(<span class="code-quote" style="color: #009100">"deprecation"</span>)
        @Before
        <span class="code-keyword" style="color: #000091">public</span> void setup() {
                config = <span class="code-keyword" style="color: #000091">new</span> Configuration();
                <span class="code-comment" style="color: #808080">// add your entities here e.g.:
</span>                <span class="code-comment" style="color: #808080">// config.addAnnotatedClass(Customer.class);
</span>                config.addAnnotatedClass(Header.class);
                config.addAnnotatedClass(Item.class);
                config.setProperty(<span class="code-quote" style="color: #009100">"hibernate.connection.driver_class"</span>, <span class="code-quote" style="color: #009100">"org.hsqldb.jdbcDriver"</span>);
                config.setProperty(<span class="code-quote" style="color: #009100">"hibernate.connection.url"</span>, <span class="code-quote" style="color: #009100">"jdbc:hsqldb:mem:myunittests"</span>);
                config.setProperty(<span class="code-quote" style="color: #009100">"hibernate.connection.username"</span>, <span class="code-quote" style="color: #009100">"sa"</span>);
                config.setProperty(<span class="code-quote" style="color: #009100">"hibernate.connection.password"</span>, "");
                config.setProperty(<span class="code-quote" style="color: #009100">"hibernate.connection.pool_size"</span>, <span class="code-quote" style="color: #009100">"1"</span>);
                config.setProperty(<span class="code-quote" style="color: #009100">"hibernate.current_session_context_class"</span>, <span class="code-quote" style="color: #009100">"thread"</span>);
                config.setProperty(<span class="code-quote" style="color: #009100">"hibernate.hbm2ddl.auto"</span>, <span class="code-quote" style="color: #009100">"update"</span>);
                config.setProperty(<span class="code-quote" style="color: #009100">"hibernate.dialect"</span>, <span class="code-quote" style="color: #009100">"org.hibernate.dialect.HSQLDialect"</span>);
                config.setProperty(<span class="code-quote" style="color: #009100">"hibernate.show_sql"</span>, <span class="code-quote" style="color: #009100">"<span class="code-keyword" style="color: #000091; color: #009100">true</span>"</span>);
                sessionFactory = config.buildSessionFactory();
        }
        <span class="code-comment" style="color: #808080">// perform your tests using standard junit test cases
</span>        @Test
        <span class="code-keyword" style="color: #000091">public</span> void testEmbeddableWithCollection() {
                Header h1 = <span class="code-keyword" style="color: #000091">new</span> Header();
                h1.setName(<span class="code-quote" style="color: #009100">"h1"</span>);
                
                EmbeddableWithCollection ewc = <span class="code-keyword" style="color: #000091">new</span> EmbeddableWithCollection();
                List<Item> items = <span class="code-keyword" style="color: #000091">new</span> ArrayList<Item>();
                Item i1 = <span class="code-keyword" style="color: #000091">new</span> Item();
                i1.setHeader(h1);
                i1.setName(<span class="code-quote" style="color: #009100">"h1-item1"</span>);
                i1.setPosition(0);
                Item i2 = <span class="code-keyword" style="color: #000091">new</span> Item();
                i2.setHeader(h1);
                i2.setName(<span class="code-quote" style="color: #009100">"h1-item2"</span>);
                i2.setPosition(1);
                items.add(i1);
                items.add(i2);
                ewc.setItems(items);
                
                h1.setEmbeddableWithCollection(ewc);
                sessionFactory.getCurrentSession().beginTransaction();
                <span class="code-object" style="color: #910091">Long</span> headerId = (<span class="code-object" style="color: #910091">Long</span>) sessionFactory.getCurrentSession().save(h1);
                                
                sessionFactory.getCurrentSession().getTransaction().commit();
                Header persistedHeader = (Header) sessionFactory.getCurrentSession()
                                .createCriteria(Header.class)
                                .add(Restrictions.idEq(headerId))
                                .uniqueResult();
                Assert.assertEquals(2, persistedHeader.getEmbeddableWithCollection().getItems().size());
                
                sessionFactory.getCurrentSession().beginTransaction();
                AuditReader reader = AuditReaderFactory.get(sessionFactory.getCurrentSession());
                Header auditedHeader = reader.find(Header.class, headerId, <span class="code-object" style="color: #910091">Integer</span>.MAX_VALUE);
                List<Item> auditedHeader1Items = auditedHeader.getEmbeddableWithCollection().getItems();
                Assert.assertEquals(2, auditedHeader1Items.size());
                Assert.assertEquals(<span class="code-quote" style="color: #009100">"h1-item1"</span>, auditedHeader1Items.get(0).getName());
                Assert.assertEquals(<span class="code-object" style="color: #910091">Long</span>.valueOf(0), auditedHeader1Items.get(0).getPosition());
                Assert.assertEquals(headerId, auditedHeader1Items.get(0).getHeader().getId());
                Assert.assertEquals(<span class="code-quote" style="color: #009100">"h1-item2"</span>, auditedHeader1Items.get(1).getName());
                Assert.assertEquals(<span class="code-object" style="color: #910091">Long</span>.valueOf(1), auditedHeader1Items.get(1).getPosition());
                Assert.assertEquals(headerId, auditedHeader1Items.get(1).getHeader().getId());
                sessionFactory.getCurrentSession().getTransaction().commit();
                sessionFactory.getCurrentSession().close();
        }
}
</pre>
</div>
</div>
<div class="code panel" style="border-width: 1px;; border: 1px solid #ccc; background: #f5f5f5; font-size: 12px; line-height: 1.333; font-family: monospace; border: 1px solid #ccc; -moz-border-radius: 3px 3px 3px 3px; border-radius: 3px 3px 3px 3px; margin: 9px 0">
<div class="codeHeader panelHeader" style="border-bottom-width: 1px;; border-bottom: 1px solid #ccc; padding: 9px 12px">
<b>pom.xml</b>
</div>
<div class="codeContent panelContent" style="padding: 9px 12px">
<pre class="code-java" style="margin: 10px 0 0 0; max-height: 30em; overflow: auto; white-space: pre-wrap; word-wrap: normal">
<project xmlns=<span class="code-quote" style="color: #009100">"http:<span class="code-comment" style="color: #808080">//maven.apache.org/POM/4.0.0"</span> xmlns:xsi=<span class="code-quote" style="color: #009100">"http://www.w3.org/2001/XMLSchema-instance"</span>
</span>        xsi:schemaLocation=<span class="code-quote" style="color: #009100">"http:<span class="code-comment" style="color: #808080">//maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"</span>>
</span>        <modelVersion>4.0.0</modelVersion>
        <prerequisites>
                <maven>3.0.4</maven>
        </prerequisites>
        <groupId>org.hibernate.bugs</groupId>
        <artifactId>hhh-9105</artifactId>
        <version>1.0-SNAPSHOT</version>
        <name>Hibernate Bug Report Test Case Example</name>
        <properties>
                <slf4j.version>1.7.2</slf4j.version>
        </properties>
        <dependencies>
                <dependency>
                        <groupId>org.slf4j</groupId>
                        <artifactId>slf4j-log4j12</artifactId>
                        <version>${slf4j.version}</version>
                </dependency>
                <dependency>
                        <groupId>org.hibernate</groupId>
                        <artifactId>hibernate-core</artifactId>
                        <version>4.3.5.Final</version>
                </dependency>
                <dependency>
                        <groupId>org.hibernate</groupId>
                        <artifactId>hibernate-testing</artifactId>
                        <version>4.3.5.Final</version>
                </dependency>
                <dependency>
                        <groupId>org.hibernate</groupId>
                        <artifactId>hibernate-envers</artifactId>
                        <version>4.3.5.Final</version>
                </dependency>                
                <dependency>
                        <groupId>org.hsqldb</groupId>
                        <artifactId>hsqldb</artifactId>
                        <version>2.3.2</version>
                        <scope>test</scope>
                </dependency>
                <dependency>
                        <groupId>junit</groupId>
                        <artifactId>junit</artifactId>
                        <version>4.11</version>
                        <scope>test</scope>
                </dependency>
        </dependencies>
        <build>
                <plugins>
                        <plugin>
                                <groupId>org.apache.maven.plugins</groupId>
                                <artifactId>maven-compiler-plugin</artifactId>
                                <version>3.1</version>
                                <configuration>
                                        <source>1.7</source>
                                        <target>1.7</target>
                                </configuration>
                        </plugin>
                </plugins>
        </build>
</project>
</pre>
</div>
</div>
<div class="code panel" style="border-width: 1px;; border: 1px solid #ccc; background: #f5f5f5; font-size: 12px; line-height: 1.333; font-family: monospace; border: 1px solid #ccc; -moz-border-radius: 3px 3px 3px 3px; border-radius: 3px 3px 3px 3px; margin: 9px 0">
<div class="codeHeader panelHeader" style="border-bottom-width: 1px;; border-bottom: 1px solid #ccc; padding: 9px 12px">
<b>log4j.properties</b>
</div>
<div class="codeContent panelContent" style="padding: 9px 12px">
<pre class="code-java" style="margin: 10px 0 0 0; max-height: 30em; overflow: auto; white-space: pre-wrap; word-wrap: normal">
# Root logger option
log4j.rootLogger=INFO, stdout
# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=<span class="code-object" style="color: #910091">System</span>.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
</pre>
</div>
</div>
</td>
</tr>
</table>
</td>
</tr>
<tr>
<td class="email-content-main mobile-expand " style="padding: 0px; border-collapse: collapse; border-left: 1px solid #ccc; border-right: 1px solid #ccc; border-top: 0; border-bottom: 0; padding: 0 15px 0 16px; background-color: #fff">
<table id="actions-pattern" cellspacing="0" cellpadding="0" border="0" width="100%" style="border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt; font-family: Arial, sans-serif; font-size: 14px; line-height: 20px; mso-line-height-rule: exactly; mso-text-raise: 1px">
<tr>
<td id="actions-pattern-container" valign="middle" style="padding: 0px; border-collapse: collapse; padding: 10px 0 10px 24px; vertical-align: middle; padding-left: 0">
<table align="left" style="border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt">
<tr>
<td class="actions-pattern-action-icon-container" style="padding: 0px; border-collapse: collapse; font-family: Arial, sans-serif; font-size: 14px; line-height: 20px; mso-line-height-rule: exactly; mso-text-raise: 0px; vertical-align: middle"> <a href="https://hibernate.atlassian.net/browse/HHH-9108#add-comment" target="_blank" title="Add Comment" style="color: #3b73af; text-decoration: none"> <img class="actions-pattern-action-icon-image" src="cid:jira-generated-image-static-comment-icon-37398a1d-59ee-47f3-a9b4-2fa9041a3fca" alt="Add Comment" title="Add Comment" height="16" width="16" border="0" style="vertical-align: middle" /> </a>
</td>
<td class="actions-pattern-action-text-container" style="padding: 0px; border-collapse: collapse; font-family: Arial, sans-serif; font-size: 14px; line-height: 20px; mso-line-height-rule: exactly; mso-text-raise: 4px; padding-left: 5px"> <a href="https://hibernate.atlassian.net/browse/HHH-9108#add-comment" target="_blank" title="Add Comment" style="color: #3b73af; text-decoration: none">Add Comment</a>
</td>
</tr>
</table>
</td>
</tr>
</table>
</td>
</tr>
<!-- there needs to be content in the cell for it to render in some clients -->
<tr>
<td class="email-content-rounded-bottom mobile-expand" style="padding: 0px; border-collapse: collapse; color: #fff; padding: 0 15px 0 16px; height: 5px; line-height: 5px; background-color: #fff; border-top: 0; border-left: 1px solid #ccc; border-bottom: 1px solid #ccc; border-right: 1px solid #ccc; border-bottom-right-radius: 5px; border-bottom-left-radius: 5px; mso-line-height-rule: exactly">
</td>
</tr>
</table>
</td>
</tr>
<tr>
<td id="footer-pattern" style="padding: 0px; border-collapse: collapse; padding: 12px 20px">
<table id="footer-pattern-container" cellspacing="0" cellpadding="0" border="0" style="border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt">
<tr>
<td id="footer-pattern-text" class="mobile-resize-text" width="100%" style="padding: 0px; border-collapse: collapse; color: #999; font-size: 12px; line-height: 18px; font-family: Arial, sans-serif; mso-line-height-rule: exactly; mso-text-raise: 2px">
This message was sent by Atlassian JIRA <span id="footer-build-information">(v6.3-OD-02-026#6318-<span title="955a9ee8603120962156c99532466d8e78960b49" data-commit-id="955a9ee8603120962156c99532466d8e78960b49}">sha1:955a9ee</span>)</span>
</td>
<td id="footer-pattern-logo-desktop-container" valign="top" style="padding: 0px; border-collapse: collapse; padding-left: 20px; vertical-align: top">
<table style="border-collapse: collapse; mso-table-lspace: 0pt; mso-table-rspace: 0pt">
<tr>
<td id="footer-pattern-logo-desktop-padding" style="padding: 0px; border-collapse: collapse; padding-top: 3px"> <img id="footer-pattern-logo-desktop" src="cid:jira-generated-image-static-footer-desktop-logo-a7da6e58-cf15-44b3-8869-6be179fd181e" alt="Atlassian logo" title="Atlassian logo" width="169" height="36" class="image_fix" />
</td>
</tr>
</table>
</td>
</tr>
</table>
</td>
</tr>
</table>
</body>
</html>