[hibernate-commits] Hibernate SVN: r18731 - in core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities: complex and 1 other directory.

hibernate-commits at lists.jboss.org hibernate-commits at lists.jboss.org
Mon Feb 8 13:44:26 EST 2010


Author: stalep
Date: 2010-02-08 13:44:26 -0500 (Mon, 08 Feb 2010)
New Revision: 18731

Added:
   core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/
   core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/Customer.java
   core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/CustomerInventory.java
   core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/CustomerInventoryPK.java
   core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/IdClassGeneratedValueManyToOneTest.java
   core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/Item.java
Log:
[HHH-4848]
added an example that derive from entities not defined with component key


Added: core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/Customer.java
===================================================================
--- core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/Customer.java	                        (rev 0)
+++ core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/Customer.java	2010-02-08 18:44:26 UTC (rev 18731)
@@ -0,0 +1,217 @@
+package org.hibernate.test.annotations.derivedidentities.complex;
+
+import java.io.Serializable;
+import java.math.BigDecimal;
+import java.util.ArrayList;
+import java.util.Calendar;
+import java.util.List;
+
+import javax.persistence.AttributeOverride;
+import javax.persistence.AttributeOverrides;
+import javax.persistence.CascadeType;
+import javax.persistence.Column;
+import javax.persistence.Embedded;
+import javax.persistence.Entity;
+import javax.persistence.FetchType;
+import javax.persistence.Id;
+import javax.persistence.NamedQueries;
+import javax.persistence.NamedQuery;
+import javax.persistence.OneToMany;
+import javax.persistence.Table;
+import javax.persistence.Temporal;
+import javax.persistence.TemporalType;
+import javax.persistence.Version;
+
+ at SuppressWarnings("serial")
+ at NamedQueries({
+   @NamedQuery(name=Customer.QUERY_ALL,
+         query="select a from Customer a"),
+         @NamedQuery(name=Customer.QUERY_COUNT,
+               query="select COUNT(a) from Customer a"),
+               @NamedQuery(name=Customer.QUERY_BY_CREDIT,
+                     query="SELECT c.id FROM Customer c WHERE c.creditLimit > :limit")
+})
+ at Entity 
+ at Table(name="O_CUSTOMER") 
+public class Customer implements Serializable {
+   public static final String QUERY_ALL = "Customer.selectAll";
+   public static final String QUERY_COUNT = "Customer.count";
+   public static final String QUERY_BY_CREDIT = "Customer.selectByCreditLimit";
+
+   public static final String BAD_CREDIT = "BC";
+
+   @Id
+   @Column(name="C_ID")
+   private int id;
+
+   @Column(name="C_FIRST")
+   private String firstName;
+
+   @Column(name="C_LAST")
+   private String lastName;
+
+   @Column(name="C_CONTACT")
+   private String contact;
+
+   @Column(name="C_CREDIT")    
+   private String credit;
+
+   @Column(name="C_CREDIT_LIMIT")
+   private BigDecimal creditLimit;
+
+   @Column(name="C_SINCE")
+   @Temporal(TemporalType.DATE)
+   private Calendar since;
+
+   @Column(name="C_BALANCE")
+   private BigDecimal balance;
+
+   @Column(name="C_YTD_PAYMENT")
+   private BigDecimal ytdPayment;
+
+   @OneToMany(targetEntity=CustomerInventory.class, mappedBy="customer", cascade=CascadeType.ALL, fetch=FetchType.EAGER)
+   private List<CustomerInventory> customerInventories;
+
+
+   @Version 
+   @Column(name = "C_VERSION")
+   private int version;
+
+   protected Customer() {
+   }
+
+   public Customer(String first, String last, 
+         String contact, String credit, BigDecimal creditLimit,
+         BigDecimal balance, BigDecimal YtdPayment) {
+
+      this.firstName   = first;
+      this.lastName    = last;
+      this.contact     = contact;
+      this.since       = Calendar.getInstance();
+      this.credit      = credit;
+      this.creditLimit = creditLimit;
+      this.balance     = balance;
+      this.ytdPayment  = YtdPayment;
+   }
+
+   public Integer getId() {
+      return id;
+   }
+
+   public void setId(Integer customerId) {
+      this.id = customerId;
+   }
+
+   public String getFirstName() {
+      return firstName;
+   }
+
+   public void setFirstName(String firstName) {
+      this.firstName = firstName;
+   }
+
+   public String getLastName() {
+      return lastName;
+   }
+
+   public void setLastName(String lastName) {
+      this.lastName = lastName;
+   }
+
+   public String getContact() {
+      return contact;
+   }
+
+   public void setContact(String contact) {
+      this.contact = contact;
+   }
+
+   public String getCredit() {
+      return credit;
+   }
+
+   public void setCredit(String credit) {
+      this.credit = credit;
+   }
+
+   public BigDecimal getCreditLimit() {
+      return creditLimit;
+   }
+
+   public void setCreditLimit(BigDecimal creditLimit) {
+      this.creditLimit = creditLimit;
+   }
+
+   public Calendar getSince() {
+      return since;
+   }
+
+   public void setSince(Calendar since) {
+      this.since = since;
+   }
+
+   public BigDecimal getBalance() {
+      return balance;
+   }
+
+   public void setBalance(BigDecimal balance) {
+      this.balance = balance;
+   }
+
+   public void changeBalance(BigDecimal change) {
+      setBalance(balance.add(change).setScale(2, BigDecimal.ROUND_DOWN));
+   }
+
+   public BigDecimal getYtdPayment() {
+      return ytdPayment;
+   }
+
+   public void setYtdPayment(BigDecimal ytdPayment) {
+      this.ytdPayment = ytdPayment;
+   }
+
+   public List<CustomerInventory> getInventories() {
+      if (customerInventories == null){
+         customerInventories = new ArrayList<CustomerInventory>();
+      }
+      return customerInventories;
+   }
+
+   public CustomerInventory addInventory(Item item, int quantity, 
+         BigDecimal totalValue) {
+
+      CustomerInventory inventory = new CustomerInventory(this, item, 
+            quantity, totalValue);
+      getInventories().add(inventory);
+      return inventory;
+   }
+
+   public int getVersion() {
+      return version;
+   }
+
+   public boolean hasSufficientCredit(BigDecimal amount) {
+      return !BAD_CREDIT.equals(getCredit()) 
+      && creditLimit != null
+      && creditLimit.compareTo(amount) >= 0;
+   }
+
+   @Override
+   public boolean equals(Object o) {
+      if (this == o) 
+         return true;
+      if (o == null || getClass() != o.getClass()) 
+         return false;
+      return id == ((Customer) o).id;
+   }
+
+   @Override
+   public int hashCode() {
+      return new Integer(id).hashCode();
+   }
+
+   @Override
+   public String toString() {
+      return this.getFirstName() + " " + this.getLastName();
+   }
+}


Property changes on: core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/Customer.java
___________________________________________________________________
Name: svn:executable
   + *

Added: core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/CustomerInventory.java
===================================================================
--- core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/CustomerInventory.java	                        (rev 0)
+++ core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/CustomerInventory.java	2010-02-08 18:44:26 UTC (rev 18731)
@@ -0,0 +1,118 @@
+package org.hibernate.test.annotations.derivedidentities.complex;
+
+import java.io.Serializable;
+import java.math.BigDecimal;
+import java.util.Comparator;
+
+import javax.persistence.CascadeType;
+import javax.persistence.Column;
+import javax.persistence.Entity;
+import javax.persistence.GeneratedValue;
+import javax.persistence.GenerationType;
+import javax.persistence.Id;
+import javax.persistence.IdClass;
+import javax.persistence.JoinColumn;
+import javax.persistence.ManyToOne;
+import javax.persistence.NamedQueries;
+import javax.persistence.NamedQuery;
+import javax.persistence.Table;
+import javax.persistence.TableGenerator;
+import javax.persistence.Version;
+
+ at NamedQueries({
+   @NamedQuery(name="CustomerInventory.selectAll",
+         query="select a from CustomerInventory a")
+})
+ at SuppressWarnings("serial")
+ at Entity 
+ at Table(name="O_CUSTINVENTORY")
+ at IdClass(CustomerInventoryPK.class)
+public class CustomerInventory implements Serializable, Comparator<CustomerInventory> {
+   
+   @Id
+   @TableGenerator(name="inventory",
+         table="U_SEQUENCES",
+         pkColumnName="S_ID",
+         valueColumnName="S_NEXTNUM",
+         pkColumnValue="inventory",
+         allocationSize=1000)
+         @GeneratedValue(strategy=GenerationType.TABLE,generator="inventory")
+         @Column(name="CI_ID")
+         private Integer         id;
+
+ 
+   @Id
+   @ManyToOne(cascade=CascadeType.MERGE)
+   @JoinColumn(name="CI_CUSTOMERID")
+   private Customer        customer;
+
+   @ManyToOne(cascade=CascadeType.MERGE)
+   @JoinColumn(name = "CI_ITEMID")
+   private Item            vehicle;
+
+   @Column(name="CI_VALUE")
+   private BigDecimal      totalCost;
+
+   @Column(name="CI_QUANTITY")
+   private int             quantity;
+
+   @Version 
+   @Column(name = "CI_VERSION")
+   private int             version;
+
+   protected CustomerInventory() {
+   }
+
+   CustomerInventory(Customer customer, Item vehicle, int quantity , BigDecimal totalValue) 
+   {
+      this.customer = customer;
+      this.vehicle = vehicle;
+      this.quantity = quantity;
+      this.totalCost = totalValue;
+   }
+
+   public Item getVehicle() {
+      return vehicle;
+   }
+
+   public BigDecimal getTotalCost() {
+      return totalCost;
+   }
+
+   public int getQuantity() {
+      return quantity;
+   }
+
+   public Integer getId() {
+      return id;
+   }
+
+   public Customer getCustomer() {
+      return customer;
+   }
+
+   public int getVersion() {
+      return version;
+   }
+
+   public int compare(CustomerInventory cdb1, CustomerInventory cdb2) {
+      return cdb1.id.compareTo(cdb2.id);
+   }
+
+   @Override
+   public boolean equals (Object obj) {
+      if (obj == this)
+         return true;
+      if (obj == null || !(obj instanceof CustomerInventory)) 
+         return false;
+      if (this.id == ((CustomerInventory)obj).id)
+         return true;
+      if (this.id != null && ((CustomerInventory)obj).id == null)
+         return false;
+      if (this.id == null && ((CustomerInventory)obj).id != null)
+         return false;
+
+      return this.id.equals(((CustomerInventory)obj).id);
+   }
+
+}


Property changes on: core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/CustomerInventory.java
___________________________________________________________________
Name: svn:executable
   + *

Added: core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/CustomerInventoryPK.java
===================================================================
--- core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/CustomerInventoryPK.java	                        (rev 0)
+++ core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/CustomerInventoryPK.java	2010-02-08 18:44:26 UTC (rev 18731)
@@ -0,0 +1,45 @@
+package org.hibernate.test.annotations.derivedidentities.complex;
+
+import java.io.Serializable;
+
+
+public class CustomerInventoryPK implements Serializable {
+
+   private Integer id;
+
+   private Customer        customer;
+
+   public CustomerInventoryPK() {
+   }
+
+   public CustomerInventoryPK(Integer id, Customer customer) {
+      this.id = id;
+      this.customer = customer;  
+   }
+
+   public boolean equals(Object other) {
+      if (other == this) {
+         return true;
+      }
+      if (other == null || getClass() != other.getClass()) {
+         return false;
+      }
+      CustomerInventoryPK cip = (CustomerInventoryPK) other;
+      return (getCustomer().getId() == cip.getCustomer().getId() && (id == cip.id || 
+            ( id != null && id.equals(cip.id))));
+   }
+
+   public int hashCode() {
+      return (id == null ? 0 : id.hashCode()) ^ getCustomer().getId();
+   }
+
+   public Integer getId() {
+      return id;
+   }
+
+   public Customer getCustomer() {
+      return customer;
+   }
+
+
+}


Property changes on: core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/CustomerInventoryPK.java
___________________________________________________________________
Name: svn:executable
   + *

Added: core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/IdClassGeneratedValueManyToOneTest.java
===================================================================
--- core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/IdClassGeneratedValueManyToOneTest.java	                        (rev 0)
+++ core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/IdClassGeneratedValueManyToOneTest.java	2010-02-08 18:44:26 UTC (rev 18731)
@@ -0,0 +1,70 @@
+package org.hibernate.test.annotations.derivedidentities.complex;
+
+import java.math.BigDecimal;
+import java.util.List;
+
+import org.apache.log4j.Level;
+import org.apache.log4j.Logger;
+import org.hibernate.Session;
+import org.hibernate.Transaction;
+import org.hibernate.test.annotations.TestCase;
+
+import org.hibernate.junit.FailureExpected;
+/**
+ * A test.
+ * 
+ * @author <a href="mailto:stale.pedersen at jboss.org">Stale W. Pedersen</a>
+ * @version $Revision: 1.1 $
+ */
+public class IdClassGeneratedValueManyToOneTest extends TestCase
+{
+   @FailureExpected(jiraKey="HHH-4848")
+   public void testComplexIdClass()
+   {
+      Logger.getLogger("org.hibernate").setLevel(Level.TRACE);
+      Session s = openSession();
+      Transaction tx = s.beginTransaction();
+      
+      Customer c1 = new Customer("foo", "bar", "contact1", "100", new BigDecimal(1000),new BigDecimal(1000), new BigDecimal(1000));
+
+      s.persist(c1);
+      Item boat = new Item();
+      boat.setId("1");
+      boat.setName("cruiser");
+      boat.setPrice(new BigDecimal(500));
+      boat.setDescription("a boat");
+      boat.setCategory(42);
+      
+      s.persist(boat);
+      s.flush();
+      s.clear();
+      
+      c1.addInventory(boat, 10, new BigDecimal(5000));
+      s.merge(c1);
+      s.flush();
+      s.clear();
+
+      Customer c2 = (Customer) s.createQuery( "select c from Customer c" ).uniqueResult();
+
+      List<CustomerInventory> inventory = c2.getInventories();
+      
+      assertEquals(1, inventory.size());
+      assertEquals(10, inventory.get(0).getQuantity());
+      
+      tx.rollback();
+      s.close();
+      
+      assertTrue(true);
+   }
+   
+   protected Class[] getAnnotatedClasses() 
+   {
+      return new Class[] {
+            Customer.class, 
+            CustomerInventory.class,
+            CustomerInventoryPK.class,
+            Item.class
+            
+      };
+   }
+}


Property changes on: core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/IdClassGeneratedValueManyToOneTest.java
___________________________________________________________________
Name: svn:executable
   + *

Added: core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/Item.java
===================================================================
--- core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/Item.java	                        (rev 0)
+++ core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/Item.java	2010-02-08 18:44:26 UTC (rev 18731)
@@ -0,0 +1,120 @@
+package org.hibernate.test.annotations.derivedidentities.complex;
+
+import java.io.Serializable;
+import java.math.BigDecimal;
+
+import javax.persistence.Column;
+import javax.persistence.Entity;
+import javax.persistence.Id;
+import javax.persistence.NamedQueries;
+import javax.persistence.NamedQuery;
+import javax.persistence.Table;
+import javax.persistence.Version;
+
+
+
+   @NamedQueries( {
+      @NamedQuery(name = "Item.findByCategory", 
+          query = "SELECT i FROM Item i WHERE i.category=:category ORDER BY i.id")})
+  @SuppressWarnings("serial")
+  @Entity
+  @Table(name = "O_ITEM")
+  public class Item implements Serializable 
+  {
+
+    public static final String QUERY_BY_CATEGORY = "Item.findByCategory";
+
+    @Id
+    @Column(name = "I_ID")
+    private String id;
+
+    @Column(name = "I_NAME")
+    private String name;
+
+    @Column(name = "I_PRICE")
+    private BigDecimal price;
+
+    @Column(name = "I_DESC")
+    private String description;
+
+    @Column(name = "I_DISCOUNT")
+    private BigDecimal discount;
+
+    @Column(name = "I_CATEGORY")
+    private int category;
+
+    @Version
+    @Column(name = "I_VERSION")
+    int version;
+    
+    public String getId() {
+       return id;
+     }
+
+     public void setId(String i) {
+       id = i;
+     }
+    
+    public int getCategory() {
+       return category;
+     }
+
+     public void setCategory(int category) {
+       this.category = category;
+     }
+
+     public String getDescription() {
+       return description;
+     }
+
+     public void setDescription(String description) {
+       this.description = description;
+     }
+
+     public BigDecimal getDiscount() {
+       return discount;
+     }
+
+     public void setDiscount(BigDecimal discount) {
+       if (discount.doubleValue() < 0 || discount.doubleValue() > 100.0)
+         throw new IllegalArgumentException(this + " discount " + discount
+             + " is invalid. Must be between 0.0 and 100.0");
+       this.discount = discount;
+     }
+
+     public String getName() {
+       return name;
+     }
+
+     public void setName(String name) {
+       this.name = name;
+     }
+
+     public BigDecimal getPrice() {
+       return price;
+     }
+
+     public void setPrice(BigDecimal price) {
+       this.price = price;
+     }
+
+     public int getVersion() {
+       return version;
+     }
+     
+     @Override
+     public boolean equals(Object other) {
+       if (other == null || other.getClass() != this.getClass()) {
+         return false;
+       }
+       if (other == this) {
+         return true;
+       }
+       return id.equals(((Item) other).id);
+     }
+
+     @Override
+     public int hashCode() {
+       return id.hashCode();
+     }
+}


Property changes on: core/trunk/annotations/src/test/java/org/hibernate/test/annotations/derivedidentities/complex/Item.java
___________________________________________________________________
Name: svn:executable
   + *



More information about the hibernate-commits mailing list