Project

General

Profile

Download (36.5 KB) Statistics
| Branch: | Tag: | Revision:
1
/**
2
 *
3
 */
4
package eu.etaxonomy.cdm.database.data;
5

    
6
import java.net.URI;
7
import java.util.ArrayList;
8
import java.util.List;
9

    
10
import org.hibernate.Session;
11
import org.joda.time.DateTime;
12

    
13
import com.ibm.lsid.MalformedLSIDException;
14

    
15
import eu.etaxonomy.cdm.common.DOI;
16
import eu.etaxonomy.cdm.model.agent.Address;
17
import eu.etaxonomy.cdm.model.agent.Contact;
18
import eu.etaxonomy.cdm.model.agent.Institution;
19
import eu.etaxonomy.cdm.model.agent.Person;
20
import eu.etaxonomy.cdm.model.agent.Team;
21
import eu.etaxonomy.cdm.model.common.AnnotatableEntity;
22
import eu.etaxonomy.cdm.model.common.Annotation;
23
import eu.etaxonomy.cdm.model.common.CdmBase;
24
import eu.etaxonomy.cdm.model.common.Credit;
25
import eu.etaxonomy.cdm.model.common.DefinedTerm;
26
import eu.etaxonomy.cdm.model.common.EventBase;
27
import eu.etaxonomy.cdm.model.common.Extension;
28
import eu.etaxonomy.cdm.model.common.ExtensionType;
29
import eu.etaxonomy.cdm.model.common.Group;
30
import eu.etaxonomy.cdm.model.common.IdentifiableEntity;
31
import eu.etaxonomy.cdm.model.common.IdentifiableSource;
32
import eu.etaxonomy.cdm.model.common.Identifier;
33
import eu.etaxonomy.cdm.model.common.IntextReference;
34
import eu.etaxonomy.cdm.model.common.LSID;
35
import eu.etaxonomy.cdm.model.common.LSIDAuthority;
36
import eu.etaxonomy.cdm.model.common.Language;
37
import eu.etaxonomy.cdm.model.common.LanguageString;
38
import eu.etaxonomy.cdm.model.common.Marker;
39
import eu.etaxonomy.cdm.model.common.MarkerType;
40
import eu.etaxonomy.cdm.model.common.OriginalSourceType;
41
import eu.etaxonomy.cdm.model.common.Representation;
42
import eu.etaxonomy.cdm.model.common.TermType;
43
import eu.etaxonomy.cdm.model.common.TermVocabulary;
44
import eu.etaxonomy.cdm.model.common.User;
45
import eu.etaxonomy.cdm.model.description.CategoricalData;
46
import eu.etaxonomy.cdm.model.description.CommonTaxonName;
47
import eu.etaxonomy.cdm.model.description.DescriptionElementSource;
48
import eu.etaxonomy.cdm.model.description.DescriptiveDataSet;
49
import eu.etaxonomy.cdm.model.description.Distribution;
50
import eu.etaxonomy.cdm.model.description.Feature;
51
import eu.etaxonomy.cdm.model.description.FeatureNode;
52
import eu.etaxonomy.cdm.model.description.FeatureTree;
53
import eu.etaxonomy.cdm.model.description.IIdentificationKey;
54
import eu.etaxonomy.cdm.model.description.IndividualsAssociation;
55
import eu.etaxonomy.cdm.model.description.MeasurementUnit;
56
import eu.etaxonomy.cdm.model.description.MediaKey;
57
import eu.etaxonomy.cdm.model.description.MultiAccessKey;
58
import eu.etaxonomy.cdm.model.description.PolytomousKey;
59
import eu.etaxonomy.cdm.model.description.PolytomousKeyNode;
60
import eu.etaxonomy.cdm.model.description.PresenceAbsenceTerm;
61
import eu.etaxonomy.cdm.model.description.QuantitativeData;
62
import eu.etaxonomy.cdm.model.description.SpecimenDescription;
63
import eu.etaxonomy.cdm.model.description.State;
64
import eu.etaxonomy.cdm.model.description.StateData;
65
import eu.etaxonomy.cdm.model.description.StatisticalMeasure;
66
import eu.etaxonomy.cdm.model.description.StatisticalMeasurementValue;
67
import eu.etaxonomy.cdm.model.description.TaxonDescription;
68
import eu.etaxonomy.cdm.model.description.TaxonInteraction;
69
import eu.etaxonomy.cdm.model.description.TaxonNameDescription;
70
import eu.etaxonomy.cdm.model.description.TextData;
71
import eu.etaxonomy.cdm.model.description.TextFormat;
72
import eu.etaxonomy.cdm.model.location.Country;
73
import eu.etaxonomy.cdm.model.location.NamedArea;
74
import eu.etaxonomy.cdm.model.location.Point;
75
import eu.etaxonomy.cdm.model.location.ReferenceSystem;
76
import eu.etaxonomy.cdm.model.media.AudioFile;
77
import eu.etaxonomy.cdm.model.media.IdentifiableMediaEntity;
78
import eu.etaxonomy.cdm.model.media.ImageFile;
79
import eu.etaxonomy.cdm.model.media.Media;
80
import eu.etaxonomy.cdm.model.media.MediaRepresentation;
81
import eu.etaxonomy.cdm.model.media.MovieFile;
82
import eu.etaxonomy.cdm.model.media.Rights;
83
import eu.etaxonomy.cdm.model.media.RightsType;
84
import eu.etaxonomy.cdm.model.molecular.Amplification;
85
import eu.etaxonomy.cdm.model.molecular.AmplificationResult;
86
import eu.etaxonomy.cdm.model.molecular.Cloning;
87
import eu.etaxonomy.cdm.model.molecular.DnaQuality;
88
import eu.etaxonomy.cdm.model.molecular.DnaSample;
89
import eu.etaxonomy.cdm.model.molecular.PhylogeneticTree;
90
import eu.etaxonomy.cdm.model.molecular.Primer;
91
import eu.etaxonomy.cdm.model.molecular.Sequence;
92
import eu.etaxonomy.cdm.model.molecular.SequenceDirection;
93
import eu.etaxonomy.cdm.model.molecular.SequenceString;
94
import eu.etaxonomy.cdm.model.molecular.SingleRead;
95
import eu.etaxonomy.cdm.model.molecular.SingleReadAlignment;
96
import eu.etaxonomy.cdm.model.molecular.SingleReadAlignment.Shift;
97
import eu.etaxonomy.cdm.model.name.HybridRelationship;
98
import eu.etaxonomy.cdm.model.name.HybridRelationshipType;
99
import eu.etaxonomy.cdm.model.name.NameRelationship;
100
import eu.etaxonomy.cdm.model.name.NameRelationshipType;
101
import eu.etaxonomy.cdm.model.name.NameTypeDesignation;
102
import eu.etaxonomy.cdm.model.name.NameTypeDesignationStatus;
103
import eu.etaxonomy.cdm.model.name.NomenclaturalStatus;
104
import eu.etaxonomy.cdm.model.name.NomenclaturalStatusType;
105
import eu.etaxonomy.cdm.model.name.Rank;
106
import eu.etaxonomy.cdm.model.name.SpecimenTypeDesignation;
107
import eu.etaxonomy.cdm.model.name.SpecimenTypeDesignationStatus;
108
import eu.etaxonomy.cdm.model.name.TaxonName;
109
import eu.etaxonomy.cdm.model.name.TaxonNameFactory;
110
import eu.etaxonomy.cdm.model.occurrence.Collection;
111
import eu.etaxonomy.cdm.model.occurrence.DerivationEvent;
112
import eu.etaxonomy.cdm.model.occurrence.DerivationEventType;
113
import eu.etaxonomy.cdm.model.occurrence.DerivedUnit;
114
import eu.etaxonomy.cdm.model.occurrence.DeterminationEvent;
115
import eu.etaxonomy.cdm.model.occurrence.FieldUnit;
116
import eu.etaxonomy.cdm.model.occurrence.GatheringEvent;
117
import eu.etaxonomy.cdm.model.occurrence.MaterialOrMethodEvent;
118
import eu.etaxonomy.cdm.model.occurrence.MediaSpecimen;
119
import eu.etaxonomy.cdm.model.occurrence.PreservationMethod;
120
import eu.etaxonomy.cdm.model.occurrence.SpecimenOrObservationBase;
121
import eu.etaxonomy.cdm.model.occurrence.SpecimenOrObservationType;
122
import eu.etaxonomy.cdm.model.reference.Reference;
123
import eu.etaxonomy.cdm.model.reference.ReferenceFactory;
124
import eu.etaxonomy.cdm.model.taxon.Classification;
125
import eu.etaxonomy.cdm.model.taxon.Synonym;
126
import eu.etaxonomy.cdm.model.taxon.SynonymType;
127
import eu.etaxonomy.cdm.model.taxon.Taxon;
128
import eu.etaxonomy.cdm.model.taxon.TaxonNode;
129
import eu.etaxonomy.cdm.model.taxon.TaxonRelationship;
130
import eu.etaxonomy.cdm.model.taxon.TaxonRelationshipType;
131
import eu.etaxonomy.cdm.strategy.parser.TimePeriodParser;
132

    
133
/**
134
 * This class tries to create a database that has
135
 * at least one record in each table.
136
 * It is meant to test update scripts as well as imports
137
 * and exports.
138
 *
139
 * ATTENTION: As the content of the created database may change
140
 * over time due to model changes and other requirements test using
141
 * this class should be written in a way that they do rather
142
 * depend on general parameter than concrete data values.
143
 *
144
 * @author a.mueller
145
 * @since 3013-12-02
146
 *
147
 *
148
 */
149
public class FullCoverageDataGenerator {
150

    
151

    
152
	public void fillWithData(Session session){
153
		List<CdmBase> cdmBases = new ArrayList<CdmBase>();
154

    
155
		createAgents(cdmBases);
156

    
157
		createDescriptions(cdmBases);
158

    
159
		createMedia(cdmBases);
160

    
161
		createMolecular(cdmBases);
162

    
163
		createTaxonName(cdmBases);
164

    
165
		createOccurrence(cdmBases);
166

    
167
		createReference(cdmBases);
168

    
169
		createTaxon(cdmBases);
170

    
171
		createSupplemental(cdmBases);
172

    
173
		for (CdmBase cdmBase: cdmBases){
174
			session.save(cdmBase);
175
		}
176
	}
177

    
178

    
179
	private void createSupplemental(List<CdmBase> cdmBases)  {
180

    
181
		Reference ref = ReferenceFactory.newBook();
182

    
183
		Annotation annotation = Annotation.NewDefaultLanguageInstance("annotation");
184
		ref.addAnnotation(annotation);
185
		handleAnnotatableEntity(annotation);
186

    
187
		Credit credit = Credit.NewInstance(Person.NewInstance(), "refCredit", "rc", Language.DEFAULT());
188
		ref.addCredit(credit);
189
		handleAnnotatableEntity(credit);
190

    
191
		Rights rights = Rights.NewInstance("My rights", Language.GERMAN());
192
		ref.addRights(rights);
193
		handleAnnotatableEntity(rights);
194

    
195
		//Others
196
		try {
197
			LSIDAuthority lsidAuthority = new LSIDAuthority("My authority");
198
			lsidAuthority.addNamespace("lsidNamespace", TaxonName.class);
199
			cdmBases.add(lsidAuthority);
200
		} catch (MalformedLSIDException e) {
201
			e.printStackTrace();
202
		}
203

    
204
		User user = User.NewInstance("myUser", "12345");
205
		Group group = Group.NewInstance("MyGroup");
206
		group.addMember(user);
207

    
208
		cdmBases.add(user);
209
		cdmBases.add(group);
210

    
211

    
212
		cdmBases.add(ref);
213

    
214
	}
215

    
216

    
217
	/**
218
	 * @param cdmBases
219
	 */
220
	private void createAgents(List<CdmBase> cdmBases) {
221
		//Person
222
		Person person = Person.NewTitledInstance("Person Title");
223
		person.setGivenName("first name");
224
		person.setFamilyName("last name");
225
		person.setLifespan(TimePeriodParser.parseString("1905-1995"));
226
		person.setPrefix("prefix");
227
		person.setSuffix("suffix");
228

    
229
		handleIdentifiableEntity(person);
230

    
231
		//Contact
232
		Contact contact = Contact.NewInstance();
233
		person.setContact(contact);
234
		Point locality = Point.NewInstance(45.12, -38.69, ReferenceSystem.WGS84(), 22);
235
		contact.addEmailAddress("a@b.de");
236
		contact.addFaxNumber("f:010-123456");
237
		contact.addPhoneNumber("p:090-987654");
238
		contact.addUrl(URI.create("http://www.abc.de"));
239

    
240
		//Address
241
		Address address = Address.NewInstance(Country.GERMANY(), "locality", "pobox", "12345", "region", "street", locality);
242
		contact.addAddress(address);
243

    
244
		//Team
245
		Team team = Team.NewTitledInstance("Team title", "Team abbrev title");
246
		team.addTeamMember(person);
247
		handleIdentifiableEntity(team);
248

    
249

    
250
		//Institution
251
		Institution institution = Institution.NewInstance();
252
		institution.setCode("institution code");
253
		institution.setName("institution name");
254
		handleIdentifiableEntity(institution);
255

    
256

    
257
		//TODO vocabulary
258
//		voc = "29ad808b-3126-4274-be81-4561e7afc76f"
259
		DefinedTerm instType = DefinedTerm.NewInstitutionTypeInstance("Description forthis instition type", "institution type", "inst. t.");
260
		cdmBases.add(instType);
261
		institution.addType(instType);
262
		person.addInstitutionalMembership(institution, TimePeriodParser.parseString("1955-1956"), "department", "role");
263

    
264
		Institution subInstitution = Institution.NewInstance();
265
		subInstitution.setCode("sub institution code");
266
		subInstitution.setName("sub institution name");
267
		subInstitution.setIsPartOf(institution);
268

    
269
		cdmBases.add(person);
270
		cdmBases.add(team);
271
		cdmBases.add(institution);
272
	}
273

    
274

    
275
	private void createDescriptions(List<CdmBase> cdmBases) {
276

    
277
		TermVocabulary<?> voc = TermVocabulary.NewInstance(TermType.AnnotationType, "my termVoc desc",
278
				"myTerm voc", "mtv", URI.create("http://www.abc.de"));
279
		handleIdentifiableEntity(voc);
280
		cdmBases.add(voc);
281

    
282
		Representation rep = voc.getRepresentations().iterator().next();
283
		handleAnnotatableEntity(rep);
284
//		Representation engRep = Language.ENGLISH().getRepresentations().iterator().next();
285
//		handleAnnotatableEntity(engRep);
286
//		cdmBases.add(engRep);  //needed?
287

    
288
		//Categorical data
289
		State state = State.NewInstance("Test state", "state", "st.");
290
		state.addMedia(Media.NewInstance());
291
		cdmBases.add(state);
292
		CategoricalData categoricalData = CategoricalData.NewInstance(state, Feature.CONSERVATION());
293
		StateData stateData = categoricalData.getStateData().get(0);
294
		stateData.addModifier(DefinedTerm.SEX_FEMALE());
295
		handleAnnotatableEntity(categoricalData);
296

    
297

    
298
		State nextState = State.NewInstance();
299
		cdmBases.add(nextState);
300
		StateData stateData2 = StateData.NewInstance(nextState);
301
		stateData2.putModifyingText(Language.ENGLISH(), "State2 modifying text");
302
		categoricalData.addStateData(stateData2);
303
		categoricalData.setOrderRelevant(true);
304

    
305
		//Quantitative data
306
		Feature leaveLength = Feature.NewInstance("Leave length description", "leave length", "l.l.");
307
		cdmBases.add(leaveLength);
308
		leaveLength.setSupportsQuantitativeData(true);
309
		QuantitativeData quantitativeData = QuantitativeData.NewInstance(leaveLength);
310
		MeasurementUnit measurementUnit = MeasurementUnit.NewInstance("Measurement Unit", "munit", null);
311
		cdmBases.add(measurementUnit);
312
		quantitativeData.setUnit(measurementUnit);
313
		StatisticalMeasurementValue statisticalMeasurementValue = quantitativeData.setAverage((float)22.9 , null);
314
		handleAnnotatableEntity(quantitativeData);
315
		handleIdentifiableEntity(measurementUnit);
316
		DefinedTerm valueModifier = DefinedTerm.NewModifierInstance("about", "about", null);
317
		statisticalMeasurementValue.addModifier(valueModifier);
318
		cdmBases.add(valueModifier);
319

    
320
		//Feature
321
		TermVocabulary<DefinedTerm> recommendedModifierEnumeration = TermVocabulary.NewInstance(TermType.Modifier, DefinedTerm.class);
322
		leaveLength.addRecommendedModifierEnumeration(recommendedModifierEnumeration);
323
		cdmBases.add(recommendedModifierEnumeration);
324
		TermVocabulary<State> supportedCategoricalEnumeration = TermVocabulary.NewInstance(TermType.State, State.class);
325
		leaveLength.addSupportedCategoricalEnumeration(supportedCategoricalEnumeration);
326
		cdmBases.add(supportedCategoricalEnumeration);
327
		leaveLength.addRecommendedMeasurementUnit(measurementUnit);
328
		leaveLength.addRecommendedStatisticalMeasure(StatisticalMeasure.AVERAGE());
329

    
330
		CommonTaxonName commonTaxonName = CommonTaxonName.NewInstance("common name", Language.ENGLISH(), Country.UNITEDSTATESOFAMERICA());
331
		handleAnnotatableEntity(commonTaxonName);
332

    
333
		TextData textData = TextData.NewInstance(Feature.DIAGNOSIS());
334
		Language eng = Language.ENGLISH();
335
		textData.putText(eng, "My text data");
336
		LanguageString languageString = textData.getLanguageText(eng);
337

    
338
		Taxon referencedTaxon = getTaxon();
339
		cdmBases.add(referencedTaxon);
340
		languageString.addIntextReference(IntextReference.NewInstance(referencedTaxon, languageString, 2, 5));
341
		textData.putModifyingText(eng, "nice diagnosis");
342
		handleAnnotatableEntity(textData);
343
		handleAnnotatableEntity(languageString);
344

    
345
		TextFormat format = TextFormat.NewInstance("format", "format", null);
346
		textData.setFormat(format);
347
		cdmBases.add(format);
348
		handleAnnotatableEntity(format);
349

    
350
		DerivedUnit specimen = DerivedUnit.NewInstance(SpecimenOrObservationType.PreservedSpecimen);
351
		IndividualsAssociation indAssoc = IndividualsAssociation.NewInstance(specimen);
352
		indAssoc.putDescription(Language.ENGLISH(), "description for individuals association");
353
		handleAnnotatableEntity(indAssoc);
354

    
355

    
356
		TaxonInteraction taxonInteraction = TaxonInteraction.NewInstance(Feature.HOSTPLANT());
357
		taxonInteraction.putDescription(Language.ENGLISH(), "interaction description");
358
		handleAnnotatableEntity(taxonInteraction);
359

    
360
		NamedArea inCountryArea = NamedArea.NewInstance("My area in a country", "my area", "ma");
361
		inCountryArea.addCountry(Country.TURKEYREPUBLICOF());
362
		cdmBases.add(inCountryArea);
363
		Distribution distribution = Distribution.NewInstance(inCountryArea, PresenceAbsenceTerm.CULTIVATED());
364
		handleAnnotatableEntity(distribution);
365

    
366
		Taxon taxon = getTaxon();
367
		TaxonDescription taxonDescription = TaxonDescription.NewInstance(taxon);
368
		taxonDescription.addElements(categoricalData, quantitativeData,
369
				textData, commonTaxonName, taxonInteraction, indAssoc, distribution);
370

    
371
		DerivedUnit describedSpecimenOrObservation = DerivedUnit.NewInstance(SpecimenOrObservationType.DerivedUnit);
372
		taxonDescription.setDescribedSpecimenOrObservation(describedSpecimenOrObservation);
373

    
374
		taxonDescription.addScope(DefinedTerm.SEX_FEMALE());
375
		taxonDescription.addGeoScope(Country.GERMANY());
376
		handleIdentifiableEntity(taxonDescription);
377

    
378
		cdmBases.add(taxon);
379

    
380
		//DescriptionElmenetBase  + source
381
		textData.addMedia(Media.NewInstance());
382
		textData.addModifier(DefinedTerm.SEX_HERMAPHRODITE());
383
		textData.putModifyingText(Language.ENGLISH(), "no modification");
384
		textData.setTimeperiod(TimePeriodParser.parseString("1970-1980"));
385
		Reference ref = ReferenceFactory.newArticle();
386
		DescriptionElementSource source = textData.addSource(OriginalSourceType.Import, "22", "taxon description table", ref, "detail");
387
		source.setNameUsedInSource(TaxonNameFactory.NewBotanicalInstance(Rank.GENUS()));
388
		handleAnnotatableEntity(source);
389

    
390
		taxonDescription.addDescriptionSource(ref);
391

    
392

    
393
		//Specimen description
394
		SpecimenOrObservationBase<?> describedSpecimen = getSpecimen();
395
		SpecimenDescription specDesc = SpecimenDescription.NewInstance(specimen);
396
		cdmBases.add(describedSpecimen);
397
		handleAnnotatableEntity(specDesc);
398

    
399
		//Name description
400
		TaxonName name = TaxonNameFactory.NewBotanicalInstance(Rank.GENUS());
401
		TaxonNameDescription nameDesc = TaxonNameDescription.NewInstance(name);
402
		cdmBases.add(name);
403
		handleAnnotatableEntity(nameDesc);
404

    
405

    
406
		//Feature Tree
407
		FeatureTree featureTree = FeatureTree.NewInstance();
408
//		featureTree
409
		FeatureNode descriptionFeatureNode = FeatureNode.NewInstance(Feature.DESCRIPTION());
410
		FeatureNode leaveLengthNode = FeatureNode.NewInstance(leaveLength);
411
		featureTree.getRootChildren().add(descriptionFeatureNode);
412
		descriptionFeatureNode.addChild(leaveLengthNode);
413
		handleIdentifiableEntity(featureTree);
414

    
415
		State inapplicableState = State.NewInstance("inapplicableState", "inapplicableState", null);
416
		State applicableState = State.NewInstance("only applicable state", "only applicable state", null);
417
		cdmBases.add(applicableState);
418
		cdmBases.add(inapplicableState);
419
		leaveLengthNode.addInapplicableState(inapplicableState);
420
		leaveLengthNode.addApplicableState(applicableState);
421
		cdmBases.add(featureTree);
422
		cdmBases.add(leaveLengthNode);
423

    
424

    
425
		DescriptiveDataSet descriptiveDataSet = DescriptiveDataSet.NewInstance();
426
		descriptiveDataSet.addDescription(taxonDescription);
427
		descriptiveDataSet.setLabel("My Descriptive Dataset");
428
		descriptiveDataSet.getDescriptiveSystem();
429
		handleAnnotatableEntity(descriptiveDataSet);
430

    
431

    
432
		//polytomous keys
433
		Taxon coveredTaxon = Taxon.NewInstance(name, null);
434
		PolytomousKey key = PolytomousKey.NewTitledInstance("My Polykey");
435
		handleIdentificationKey(key, taxon, coveredTaxon);
436
		key.setStartNumber(10);
437

    
438

    
439
		PolytomousKeyNode firstChildNode = PolytomousKeyNode.NewInstance("Green", "What is the leave length?", coveredTaxon, leaveLength);
440
		key.getRoot().addChild(firstChildNode);
441
		PolytomousKeyNode secondChildNode = PolytomousKeyNode.NewInstance("234");
442
		firstChildNode.addChild(secondChildNode);
443

    
444
		PolytomousKey subkey = PolytomousKey.NewTitledInstance("Sub-key");
445
		firstChildNode.setSubkey(subkey);
446

    
447
		PolytomousKeyNode subKeyNode = PolytomousKeyNode.NewInstance("sub key couplet");
448
		subkey.getRoot().addChild(subKeyNode);
449
		secondChildNode.setOtherNode(subKeyNode);
450

    
451
		secondChildNode.putModifyingText(Language.GERMAN(), "manchmal");
452

    
453
		cdmBases.add(key);
454
		cdmBases.add(subkey);
455

    
456
		MediaKey mediaKey = MediaKey.NewInstance();
457
		mediaKey.addKeyRepresentation(Representation.NewInstance("Media Key Representation", "media key", null, Language.ENGLISH()));
458
		handleIdentificationKey(mediaKey, taxon, coveredTaxon);
459

    
460
		MultiAccessKey multiAccessKey = MultiAccessKey.NewInstance();
461
		handleIdentificationKey(multiAccessKey, taxon, coveredTaxon);
462

    
463
		cdmBases.add(mediaKey);
464
		cdmBases.add(multiAccessKey);
465

    
466
	}
467

    
468

    
469

    
470
	private void handleIdentificationKey(IIdentificationKey key, Taxon taxon, Taxon coveredTaxon){
471
		key.addCoveredTaxon(coveredTaxon);
472
		key.addGeographicalScope(Country.GERMANY());
473
		key.addScopeRestriction(DefinedTerm.SEX_FEMALE());
474
		key.addTaxonomicScope(taxon);
475
		if (key instanceof IdentifiableEntity<?>){
476
			handleIdentifiableEntity((IdentifiableEntity<?>)key);
477
		}else{
478
			handleAnnotatableEntity((AnnotatableEntity)key);
479
		}
480

    
481

    
482
	}
483

    
484

    
485
	private void createMedia(List<CdmBase> cdmBases){
486
		AudioFile audioFile = AudioFile.NewInstance(URI.create("http://a.b.de"), 22);
487
		ImageFile imageFile = ImageFile.NewInstance(URI.create("http://b.c.de"), 44, 467, 55);
488
		MovieFile movieFile = MovieFile.NewInstance(URI.create("http://b.c.de"), 67);
489
		MediaRepresentation mediaRepresentation = MediaRepresentation.NewInstance("mime", "media");
490

    
491
		mediaRepresentation.addRepresentationPart(movieFile);
492
		mediaRepresentation.addRepresentationPart(imageFile);
493
		mediaRepresentation.addRepresentationPart(audioFile);
494
		Media media = Media.NewInstance();
495
		media.addRepresentation(mediaRepresentation);
496

    
497
		media.putTitle(Language.ENGLISH(), "Media title");
498
		media.setMediaCreated(DateTime.now());
499
		media.putDescription(Language.ENGLISH(), "Media description");
500
		handleIdentifiableEntity(media);
501

    
502

    
503
		Person artist = Person.NewTitledInstance("artist");
504
		media.setArtist(artist);
505
		cdmBases.add(media);
506
		cdmBases.add(artist);
507
	}
508

    
509

    
510
	private void createMolecular(List<CdmBase> cdmBases) {
511
		DnaSample dnaSample = DnaSample.NewInstance();
512

    
513
		//Amplification
514
		Amplification amplification = Amplification.NewInstance();
515

    
516
		DefinedTerm dnaMarker = DefinedTerm.NewDnaMarkerInstance("My dna marker", "dna marker", null);
517
		cdmBases.add(dnaMarker);
518
		amplification.setDnaMarker(dnaMarker);
519
		Institution inst = Institution.NewInstance();
520
		amplification.setInstitution(inst);
521
		handleEventBase(amplification);
522
		handleAnnotatableEntity(amplification);
523

    
524
		Primer forwardPrimer = Primer.NewInstance("forward primer");
525
		forwardPrimer.setPublishedIn(getReference());
526
		forwardPrimer.setSequence(SequenceString.NewInstance("my sequence"));
527
		handleAnnotatableEntity(forwardPrimer);
528

    
529
		Primer reversePrimer = Primer.NewInstance("reverse primer");
530
		handleAnnotatableEntity(reversePrimer);
531

    
532
		amplification.setForwardPrimer(forwardPrimer);
533
		amplification.setReversePrimer(reversePrimer);
534

    
535
		DefinedTerm purificationMethod = DefinedTerm.NewInstance(TermType.MaterialOrMethod, "purification method", "purification method", null);
536
		cdmBases.add(purificationMethod);
537
		MaterialOrMethodEvent purification = MaterialOrMethodEvent.NewInstance(purificationMethod, "purification method");
538
		amplification.setPurification(purification);
539
		handleAnnotatableEntity(purification);
540
		handleAnnotatableEntity(purificationMethod);
541

    
542
		amplification.setLadderUsed("ladder");
543
		amplification.setElectrophoresisVoltage(5.5);
544
		amplification.setGelConcentration(2.4);
545
		amplification.setGelRunningTime(3.6);
546

    
547
		//Amplification result
548
		AmplificationResult amplificationResult = AmplificationResult.NewInstance(dnaSample, amplification);
549
		amplificationResult.setSuccessful(true);
550
		amplificationResult.setSuccessText("Very successful");
551
		handleAnnotatableEntity(amplificationResult);
552

    
553
		DefinedTerm cloningMethod = DefinedTerm.NewInstance(TermType.MaterialOrMethod, "cloning method", "cloning method", null);
554
		cdmBases.add(cloningMethod);
555
		Cloning cloning = Cloning.NewInstance(cloningMethod, "My cloning method", "my strain", forwardPrimer, reversePrimer);
556
		amplificationResult.setCloning(cloning);
557
		handleAnnotatableEntity(cloningMethod);
558
		handleAnnotatableEntity(cloning);
559

    
560
		Media gelPhoto = Media.NewInstance();
561
		amplificationResult.setGelPhoto(gelPhoto);
562

    
563
		//SingleRead
564
		SingleRead singleRead = SingleRead.NewInstance();
565
		handleAnnotatableEntity(singleRead);
566
		amplificationResult.addSingleRead(singleRead);
567
		MaterialOrMethodEvent readMethod = MaterialOrMethodEvent.NewInstance(null, "read method");
568
		singleRead.setMaterialOrMethod(readMethod);
569
		handleAnnotatableEntity(readMethod);
570

    
571
		Media pherogram = Media.NewInstance();
572
		singleRead.setPherogram(pherogram);
573

    
574
		singleRead.setPrimer(forwardPrimer);
575
		singleRead.setSequence(SequenceString.NewInstance("ABTC"));
576
		singleRead.setDirection(SequenceDirection.Forward);
577

    
578
		//Sequence
579
		Sequence sequence = Sequence.NewInstance("ADDT");
580
		dnaSample.addSequence(sequence);
581

    
582
//		SequenceString alignedSequence = SequenceString.NewInstance("AGTC");
583
		Shift[] shifts = new Shift[]{new Shift(66,1),new Shift(103,-2)};
584
		SingleReadAlignment.NewInstance(sequence, singleRead, shifts, "AGTC");
585

    
586
		Media contigFile = Media.NewInstance();
587
		sequence.setContigFile(contigFile);
588
		sequence.setIsBarcode(true);
589
		sequence.setDnaMarker(dnaMarker);
590
		sequence.setBarcodeSequencePart(SequenceString.NewInstance("ADTA"));
591
		sequence.setGeneticAccessionNumber("GenNO12345");
592
		sequence.setBoldProcessId("boldId");
593
		sequence.setHaplotype("haplotype");
594
		Reference sequenceCitation = getReference();
595
		sequence.addCitation(sequenceCitation);
596
		handleAnnotatableEntity(sequence);
597

    
598
		//DnaQuality
599
		DnaQuality dnaQuality = DnaQuality.NewInstance();
600
		dnaQuality.setConcentration(2.0);
601
		MeasurementUnit mu = MeasurementUnit.NewInstance("mg/ml", "mg/ml","mg/ml");
602
		cdmBases.add(mu);
603
		dnaQuality.setConcentrationUnit(mu);
604
		dnaQuality.setPurificationMethod("purification method");
605
		dnaQuality.setQualityCheckDate(DateTime.now());
606
		dnaQuality.setQualityTerm(null); //TODO
607
		dnaQuality.setRatioOfAbsorbance260_230(22.0);
608
		dnaQuality.setRatioOfAbsorbance260_280(3.9);
609
		dnaSample.setDnaQuality(dnaQuality);
610

    
611

    
612
		//Phylogenetic Tree
613
		PhylogeneticTree phyloTree = PhylogeneticTree.NewInstance();
614
		phyloTree.addUsedSequences(sequence);
615
		handleIdentifiableEntity(phyloTree);
616

    
617

    
618
		cdmBases.add(dnaSample);
619
		cdmBases.add(phyloTree);
620
	}
621

    
622

    
623
	private void createTaxon(List<CdmBase> cdmBases) {
624
		Reference sec = getReference();
625
		TaxonName name = TaxonNameFactory.NewBotanicalInstance(Rank.GENUS());
626
		Taxon taxon = Taxon.NewInstance(name, sec);
627
		handleIdentifiableEntity(taxon);
628

    
629
		TaxonName synName = TaxonNameFactory.NewBotanicalInstance(Rank.GENUS());
630
		Synonym syn = Synonym.NewInstance(synName, sec, "123");
631
		taxon.addSynonym(syn, SynonymType.HETEROTYPIC_SYNONYM_OF());
632
		taxon.setDoubtful(true);
633
		handleIdentifiableEntity(syn);
634

    
635

    
636
		Taxon concept = Taxon.NewInstance(name, getReference());
637
		TaxonRelationship taxRel = taxon.addTaxonRelation(concept, TaxonRelationshipType.CONGRUENT_TO(),
638
				sec, "444");
639
		taxon.setTaxonStatusUnknown(true);
640
		handleAnnotatableEntity(taxRel);
641

    
642

    
643
		//Classification
644
		Classification classification = Classification.NewInstance("My classification", sec);
645
		classification.setMicroReference("p. 123");
646
		classification.setTimeperiod(TimePeriodParser.parseString("1.1.2012-4.8.2013"));
647
		classification.addGeoScope(Country.GERMANY());
648
		classification.putDescription(Language.ENGLISH(), "An interesting classification");
649

    
650

    
651
		TaxonNode node = classification.addChildTaxon(taxon, sec,"22");
652
		handleIdentifiableEntity(classification);
653
		handleAnnotatableEntity(node);
654

    
655
		Taxon childTaxon = Taxon.NewInstance(synName, sec);
656
		node.addChildTaxon(childTaxon, sec, "44");
657
	    node.setUnplaced(true);
658
	    node.setExcluded(true);
659

    
660
		cdmBases.add(taxon);
661
		cdmBases.add(concept);
662
		cdmBases.add(childTaxon);
663
		cdmBases.add(classification);
664

    
665

    
666
	}
667

    
668

    
669

    
670

    
671
	private void createReference(List<CdmBase> cdmBases) {
672
		Reference reference = ReferenceFactory.newArticle();
673
		Person author = Person.NewTitledInstance("Author team");
674
		reference.setAuthorship(author);
675
		reference.setTitle("ref title");
676
		reference.setAbbrevTitle("abbrev title");
677
		reference.setDatePublished(TimePeriodParser.parseString("1999"));
678
		reference.setEdition("edition");
679
		reference.setEditor("editor");
680
		Institution institution = Institution.NewInstance();
681
		reference.setInstitution(institution);
682
		reference.setIsbn("1234556");
683
		reference.setIssn("issn");
684
		reference.setDoi(DOI.fromRegistrantCodeAndSuffix("14356", "suffix"));
685
		reference.setReferenceAbstract("referenceAbstract");
686
		reference.setOrganization("organization");
687
		reference.setPages("123-134");
688
		reference.setPlacePublished("place Published");
689
		reference.setPublisher("publisher");
690
		Institution school = Institution.NewInstance();
691
		reference.setSchool(school);
692
//		reference.setSeriesPart("series");
693
		reference.setSeriesPart("seriesPart");
694
		reference.setVolume("vol. 3");
695
		reference.setUri(URI.create("http://rer.abc.de"));
696

    
697
		Reference journal = ReferenceFactory.newJournal();
698
		reference.setInJournal(journal);
699

    
700
		handleIdentifiableEntity(reference);
701

    
702
		cdmBases.add(reference);
703

    
704
	}
705

    
706

    
707

    
708

    
709
	private void createOccurrence(List<CdmBase> cdmBases) {
710
		//Collection
711
		Collection collection = Collection.NewInstance();
712
		Collection subCollection = Collection.NewInstance();
713
		subCollection.setSuperCollection(collection);
714
		handleIdentifiableEntity(collection);
715
		handleIdentifiableEntity(subCollection);
716
		cdmBases.add(subCollection);
717

    
718
		collection.setCode("coll code");
719
		collection.setCodeStandard("codeStandard");
720
		collection.setName("coll name");
721
		collection.setTownOrLocation("townOrLocation");
722
		Institution institution = Institution.NewInstance();
723
		collection.setInstitute(institution);
724

    
725
		//FieldUnit
726
		FieldUnit fieldUnit = FieldUnit.NewInstance();
727
		fieldUnit.setFieldNumber("fieldNumber");
728
		fieldUnit.setFieldNotes("fieldNotes");
729
		Person primaryCollector = Person.NewInstance();
730
		fieldUnit.setPrimaryCollector(primaryCollector);
731
		handleIdentifiableEntity(fieldUnit);
732

    
733
		GatheringEvent gatheringEvent = GatheringEvent.NewInstance();
734
		fieldUnit.setGatheringEvent(gatheringEvent);
735
		gatheringEvent.putLocality(Language.ENGLISH(), "locality");
736
		gatheringEvent.setExactLocation(Point.NewInstance(22.4, -34.2,
737
				ReferenceSystem.WGS84(), 33));
738
		gatheringEvent.setCountry(Country.GERMANY());
739
		gatheringEvent.addCollectingArea(NamedArea.EUROPE());
740
		gatheringEvent.setCollectingMethod("collectingMethod");
741
		gatheringEvent.setAbsoluteElevation(10);
742
		gatheringEvent.setAbsoluteElevationMax(100);
743
		gatheringEvent.setAbsoluteElevationText("elevation text");
744

    
745
		gatheringEvent.setDistanceToGround(10.4);
746
		gatheringEvent.setDistanceToGroundMax(100.3);
747
		gatheringEvent.setDistanceToGroundText("distance to ground text");
748

    
749
		gatheringEvent.setDistanceToWaterSurface(10.4);
750
		gatheringEvent.setDistanceToWaterSurfaceMax(100.3);
751
		gatheringEvent.setDistanceToWaterSurfaceText("distance to water text");
752
		handleAnnotatableEntity(gatheringEvent);
753
		handleEventBase(gatheringEvent);
754

    
755

    
756
		//Derived Unit
757
		MediaSpecimen mediaSpecimen = MediaSpecimen.NewInstance(SpecimenOrObservationType.StillImage);
758
		mediaSpecimen.setCollection(collection);
759
		mediaSpecimen.setCatalogNumber("catalogNumber");
760
		mediaSpecimen.setAccessionNumber("accessionNumber");
761
//		mediaSpecimen.setCollectorsNumber("collectorsNumber");
762
		mediaSpecimen.setBarcode("barcode");
763
		TaxonName storedUnder = TaxonNameFactory.NewBotanicalInstance(Rank.SPECIES());
764
		storedUnder.setTitleCache("Stored under", true);
765
		mediaSpecimen.setStoredUnder(storedUnder);
766
		mediaSpecimen.setExsiccatum("exsiccatum");
767
		PreservationMethod preservation = PreservationMethod.NewInstance(null, "My preservation");
768
		preservation.setTemperature(22.4);
769
		mediaSpecimen.setPreservation(preservation);
770
		mediaSpecimen.setOriginalLabelInfo("Original Label Info");
771
		handleIdentifiableEntity(mediaSpecimen);
772

    
773
		//DerivationEvent
774
		DerivationEvent event = DerivationEvent.NewInstance(DerivationEventType.ACCESSIONING());
775
		event.addOriginal(fieldUnit);
776
		event.addDerivative(mediaSpecimen);
777
		Institution inst = Institution.NewInstance();
778
		event.setInstitution(inst);
779
		handleAnnotatableEntity(event);
780
		handleEventBase(event);
781

    
782
		//SpecOrObservationBase
783
		fieldUnit.setSex(DefinedTerm.SEX_FEMALE());
784
		DefinedTerm lifeStage = DefinedTerm.NewStageInstance("Live stage", "stage", null);
785
		cdmBases.add(lifeStage);
786
		fieldUnit.setLifeStage(lifeStage);
787
		DefinedTerm kindOfUnit = DefinedTerm.NewKindOfUnitInstance("Kind of unit", "Kind of unit", null);
788
		cdmBases.add(kindOfUnit);
789
		fieldUnit.setKindOfUnit(kindOfUnit);
790
		fieldUnit.setIndividualCount("3");
791
		fieldUnit.putDefinition(Language.ENGLISH(), "definition");
792
		fieldUnit.setPublish(true);
793
		handleIdentifiableEntity(fieldUnit);
794

    
795
		//Determination
796
		DeterminationEvent determinationEvent = DeterminationEvent.NewInstance(getTaxon(), mediaSpecimen);
797
		determinationEvent.setModifier(DefinedTerm.DETERMINATION_MODIFIER_AFFINIS());
798
		determinationEvent.setPreferredFlag(true);
799
		determinationEvent.addReference(getReference());
800
		handleAnnotatableEntity(determinationEvent);
801
		handleEventBase(determinationEvent);
802

    
803
		cdmBases.add(fieldUnit);
804
		cdmBases.add(mediaSpecimen);
805
		cdmBases.add(collection);
806
	}
807

    
808

    
809
	private void createTaxonName(List<CdmBase> cdmBases) {
810
		TaxonName bacName = TaxonNameFactory.NewBacterialInstance(Rank.GENUS());
811
		bacName.setSubGenusAuthorship("sub Genus author");
812
		bacName.setNameApprobation("nameApprobation");
813
		handleIdentifiableEntity(bacName);
814

    
815
		TaxonName botName = TaxonNameFactory.NewCultivarInstance(Rank.SUBSPECIES());
816
		botName.setAnamorphic(true);
817
		botName.setCultivarName("cultivarName");
818
		botName.setGenusOrUninomial("Genus");
819
		botName.setInfraGenericEpithet("InfraGeneric");
820
		botName.setSpecificEpithet("specificEpithet");
821
		botName.setInfraSpecificEpithet("infraSpecificEpithet");
822
		Person combinationAuthorship = Person.NewInstance();
823
		botName.setCombinationAuthorship(combinationAuthorship);
824
		Person exCombinationAuthorship = Person.NewInstance();
825
		botName.setExCombinationAuthorship(exCombinationAuthorship);
826
		Person basionymAuthorship = Person.NewInstance();
827
		botName.setBasionymAuthorship(basionymAuthorship);
828
		Person exBasionymAuthorship = Person.NewInstance();
829
		botName.setExBasionymAuthorship(exBasionymAuthorship);
830
		handleIdentifiableEntity(botName);
831
		handleAnnotatableEntity(botName.getHomotypicalGroup());
832
		TaxonName botName2 = TaxonNameFactory.NewBotanicalInstance(Rank.SPECIES());
833
		HybridRelationship hybridRel = botName2.addHybridChild(botName, HybridRelationshipType.FIRST_PARENT(), "Rule 1.2.3");
834
		hybridRel.setCitation(ReferenceFactory.newBook());
835
		hybridRel.setCitationMicroReference("p. 123");
836
		handleAnnotatableEntity(hybridRel);
837

    
838
		TaxonName zooName = TaxonNameFactory.NewZoologicalInstance(Rank.GENUS());
839
		zooName.setBreed("breed");
840
		zooName.setPublicationYear(1922);
841
		zooName.setOriginalPublicationYear(1987);
842
		zooName.setAppendedPhrase("appended phrase");
843
		zooName.addDescription(TaxonNameDescription.NewInstance());
844
		zooName.setNomenclaturalMicroReference("p. 123");
845
		zooName.setNomenclaturalReference(getReference());
846
		NameRelationship rel = zooName.addRelationshipFromName(botName, NameRelationshipType.LATER_HOMONYM() , "ruleConsidered");
847
		NomenclaturalStatus status = NomenclaturalStatus.NewInstance(NomenclaturalStatusType.CONSERVED(), getReference(), "p. 222");
848
		zooName.addStatus(status);
849
		handleAnnotatableEntity(rel);
850
		handleAnnotatableEntity(status);
851
		handleIdentifiableEntity(zooName);
852

    
853
		//TypeDesignation
854
		TaxonName speciesZooName = TaxonNameFactory.NewZoologicalInstance(Rank.SPECIES());
855
		NameTypeDesignation nameDesig = zooName.addNameTypeDesignation(speciesZooName, getReference(), "111", "original name",
856
				NameTypeDesignationStatus.AUTOMATIC(), true, true, true, true);
857
		handleAnnotatableEntity(nameDesig);
858
		SpecimenTypeDesignation specimenDesig = speciesZooName.addSpecimenTypeDesignation(getSpecimen(), SpecimenTypeDesignationStatus.HOLOTYPE(),
859
				getReference(), "p,22", "original name", false, true);
860
		handleAnnotatableEntity(specimenDesig);
861

    
862
		TaxonName viralName = TaxonNameFactory.NewViralInstance(Rank.GENUS());
863
		viralName.setAcronym("acronym");
864
		handleIdentifiableEntity(viralName);
865

    
866

    
867
		cdmBases.add(bacName);
868
		cdmBases.add(botName);
869
		cdmBases.add(viralName);
870
		cdmBases.add(zooName);
871
	}
872

    
873
	private void handleEventBase(EventBase event){
874
		event.setTimeperiod(TimePeriodParser.parseString("1.4.1975-2.5.1980"));
875
		event.setActor(Person.NewTitledInstance("EventActor"));
876
		event.setDescription("Some interesing event");
877
	}
878

    
879
	private void handleAnnotatableEntity(AnnotatableEntity entity){
880
		Annotation annotation = Annotation.NewDefaultLanguageInstance("annotation");
881
		entity.addAnnotation(annotation);
882
		Marker marker = Marker.NewInstance(MarkerType.COMPLETE(), true);
883
		entity.addMarker(marker);
884
	}
885

    
886
	private void handleIdentifiableEntity(IdentifiableEntity<?> identifiableEntity){
887
		handleAnnotatableEntity(identifiableEntity);
888

    
889
		//Credits
890
		Person creditor = Person.NewTitledInstance("Creditor");
891
		Credit credit = Credit.NewInstance(creditor, "credit");
892
		identifiableEntity.addCredit(credit);
893

    
894
		//Extension
895
		Extension.NewInstance(identifiableEntity, "extension", ExtensionType.INFORMAL_CATEGORY());
896

    
897
		//Identifier
898
		Identifier<?> identifier = identifiableEntity.addIdentifier("ident23", DefinedTerm.SEX_FEMALE());
899
		handleAnnotatableEntity(identifier);
900

    
901

    
902
		//Rights
903
		Rights rights = Rights.NewInstance("right", Language.ENGLISH());
904
		rights.setUri(URI.create("http://rights.abc.de"));
905
		rights.setAbbreviatedText("abbrev");
906
		rights.setType(RightsType.COPYRIGHT());
907
		Person owner = Person.NewTitledInstance("Owner");
908
		rights.setAgent(owner);
909
		identifiableEntity.addRights(rights);
910

    
911
		if (identifiableEntity.isInstanceOf(IdentifiableMediaEntity.class)){
912
			Media media = Media.NewInstance(URI.create("http://www.identifiableMedia.de"), 22, "img/jpg", "jpg");
913
			((IdentifiableMediaEntity<?>)identifiableEntity).addMedia(media);
914
		}
915

    
916
		//source
917
		IdentifiableSource source = identifiableEntity.addSource(OriginalSourceType.Import, "id", "idNamespace",
918
				getReference(), "123");
919
		source.setOriginalNameString("original name");
920

    
921
		//LSID
922
		 try {
923
			LSID lsid = new LSID("urn:lsid:a.b.de:namespace:1234");
924
			identifiableEntity.setLsid(lsid);
925
		} catch (MalformedLSIDException e) {
926
			e.printStackTrace();
927
		}
928

    
929

    
930
	}
931

    
932

    
933
	private Reference getReference() {
934
		 Reference result = ReferenceFactory.newGeneric();
935
		 result.setTitle("some generic reference");
936
		 return result;
937
	}
938

    
939

    
940
	private DerivedUnit getSpecimen() {
941
		DerivedUnit derivedUnit = DerivedUnit.NewPreservedSpecimenInstance();
942
		return derivedUnit;
943
	}
944

    
945

    
946

    
947
	private Taxon getTaxon() {
948
		Reference sec = getReference();
949
		TaxonName name = TaxonNameFactory.NewBotanicalInstance(Rank.GENUS());
950
		Taxon taxon = Taxon.NewInstance(name, sec);
951
		return taxon;
952

    
953
	}
954
}
    (1-1/1)