/** * TestCube is an enterprise Test management tool. * Copyright (C) 2011 JatakaSource Ltd. * * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * TestCube is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with TestCube. If not, see <http://www.gnu.org/licenses/>. */ package org.jatakasource.testcube.model.testplan; import java.util.Date; import java.util.List; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.JoinTable; import javax.persistence.Lob; import javax.persistence.ManyToMany; import javax.persistence.ManyToOne; import javax.persistence.SequenceGenerator; import javax.persistence.Table; import javax.persistence.Temporal; import javax.persistence.TemporalType; import javax.persistence.UniqueConstraint; import org.hibernate.annotations.Cache; import org.hibernate.annotations.CacheConcurrencyStrategy; import org.hibernate.annotations.Fetch; import org.hibernate.annotations.FetchMode; import org.hibernate.annotations.ForeignKey; import org.hibernate.annotations.Index; import org.hibernate.annotations.Type; import org.jatakasource.testcube.model.product.Product; import org.jatakasource.testcube.model.product.Version; import org.jatakasource.testcube.model.security.User; @Entity @Table(name = "CUB_TESTPLANS", uniqueConstraints = { @UniqueConstraint(name = "UC_NAME_PRODUCT", columnNames = { TestPlan.FIELD_NAME, TestPlan.COLUMN_PRODUCT }) }) @Cache(usage = CacheConcurrencyStrategy.READ_WRITE) public class TestPlan extends TestPlanPojo { private static final long serialVersionUID = 2210656336860097791L; private static final String[][] UNIQUE_CONSTRAINTS = new String[][] { new String[] { TestPlan.FIELD_NAME, TestPlan.FIELD_PRODUCT } }; public TestPlan() { } public TestPlan(Long id) { super.setId(id); } @Id @SequenceGenerator(name = "CUB_TESTPLANS_SEQ", sequenceName = "CUB_TESTPLANS_SEQ", initialValue = 0) @GeneratedValue(strategy = GenerationType.AUTO, generator = "CUB_TESTPLANS_SEQ") @Override public Long getId() { return super.getId(); } @Override public void setId(Long id) { super.setId(id); } @Override @Column(length = FIELD_NAME_LENGTH, nullable = false) @Index(name = "IDX_NAME") public String getName() { return super.getName(); } @Override public void setName(String name) { super.setName(name); } @Override @Column(length = FIELD_DESC_LENGTH, nullable = false) @Index(name = "IDX_DESCRIPTION") public String getDescription() { return super.getDescription(); } @Override public void setDescription(String description) { super.setDescription(description); } @Lob @Column @Type(type="org.hibernate.type.StringClobType") @Override public String getDocument() { return super.getDocument(); } @Override public void setDocument(String document) { super.setDocument(document); } @Override @ManyToOne(fetch = FetchType.EAGER, optional = false) @Fetch(FetchMode.SELECT) @ForeignKey(name = "FK_TESTPLANS_PRODUCTS") @Index(name = "IDX_TESTPLANS_PRODUCTS") public Product getProduct() { return (Product) super.getProduct(); } public void setProduct(Product product) { super.setProduct(product); } @Override @Column(updatable = false) @Temporal(TemporalType.TIMESTAMP) public Date getCreatedDate() { return super.getCreatedDate(); } @Override public void setCreatedDate(Date createdDate) { super.setCreatedDate(createdDate); } @Override @ManyToOne(fetch = FetchType.EAGER, optional = false) @JoinColumn(updatable = false) @Fetch(FetchMode.SELECT) @ForeignKey(name = "FK_TESTPLANS_USERS") @Index(name = "IDX_TESTPLANS_USERS") public User getCreatedBy() { return (User) super.getCreatedBy(); } public void setCreatedBy(User createdBy) { super.setCreatedBy(createdBy); } @Override @ManyToOne(fetch = FetchType.EAGER) @Fetch(FetchMode.SELECT) @ForeignKey(name = "FK_TESTPLANS_PLANTYPES") @Index(name = "FK_TESTPLANS_PLANTYPES") public PlanType getPlanType() { return (PlanType) super.getPlanType(); } public void setPlanType(PlanType planType) { super.setPlanType(planType); } @Override @ManyToOne(fetch = FetchType.EAGER) @Fetch(FetchMode.SELECT) @ForeignKey(name = "FK_TESTPLANS_VERSIONS") @Index(name = "FK_TESTPLANS_VERSIONS") public Version getProductVersion() { return (Version) super.getProductVersion(); } public void setProductVersion(Version productVersion) { super.setProductVersion(productVersion); } @Override @SuppressWarnings("unchecked") @ManyToMany(fetch = FetchType.EAGER) @JoinTable(name = "CUB_TESTPLANS_ATTACHMENTS") @Fetch(FetchMode.SELECT) public List<PlanAttachment> getAttachments() { return super.getAttachments(); } @Override public <T extends PlanAttachmentPojo> void setAttachments(List<T> attachments) { super.setAttachments(attachments); } @Override public String[][] uniqueConstraints() { return UNIQUE_CONSTRAINTS; } }