/*******************************************************************************
* Copyright (c) 1998, 2015 Oracle and/or its affiliates. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* Contributors:
* Oracle - initial API and implementation from Oracle TopLink
******************************************************************************/
package org.eclipse.persistence.testing.models.jpa.xml.merge.advanced;
import java.sql.Date;
import java.io.*;
import javax.persistence.*;
/**
* This class is used to test XML and annotation merging. This class is mapped
* in: eclipselink-xml-merge-model/orm-annotation-merge-advanced-entity-mappings.xml
*
* This class is currently marked as metadata-complete=true meaning all the
* annotations defined here should be ignored (somewhat defeating the purpose
* of XML and Annotation merging testing)
*
* Also there are no automated tests that go along with these models, see the
* test suite: EntityMappingsMergeAdvancedJUnitTestCase. It tests through
* inspecting descriptor settings only and by no means does extensive
* validation of all the metadata and defaults.
*/
@Embeddable
@Table(name="CMP3_ANN_MERGE_EMPLOYEE")
public class EmploymentPeriod implements Serializable {
private Date startDate;
private Date endDate;
public EmploymentPeriod() {}
/**
* Return a new employment period instance.
* The constructor's purpose is to allow only valid instances of a class to
* be created. Valid means that the get/set and clone/toString methods
* should work on the instance. Arguments to constructors should be avoided
* unless those arguments are required to put the instance into a valid
* state, or represent the entire instance definition.
*/
public EmploymentPeriod(Date theStartDate, Date theEndDate) {
startDate = theStartDate;
endDate = theEndDate;
}
@Column(name="ANN_MERGE_S_DATE")
public Date getStartDate() {
return startDate;
}
public void setStartDate(Date date) {
this.startDate = date;
}
@Column(name="ANN_MERGE_E_DATE")
public Date getEndDate() {
return endDate;
}
public void setEndDate(Date date) {
this.endDate = date;
}
/**
* Print the start & end date
*/
public String toString() {
java.io.StringWriter writer = new java.io.StringWriter();
writer.write("EmploymentPeriod: ");
if (this.getStartDate() != null) {
writer.write(this.getStartDate().toString());
}
writer.write("-");
if (this.getEndDate() != null) {
writer.write(this.getEndDate().toString());
}
return writer.toString();
}
}