Project

General

Profile

Download (36.7 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.Distribution;
49
import eu.etaxonomy.cdm.model.description.Feature;
50
import eu.etaxonomy.cdm.model.description.FeatureNode;
51
import eu.etaxonomy.cdm.model.description.FeatureTree;
52
import eu.etaxonomy.cdm.model.description.IIdentificationKey;
53
import eu.etaxonomy.cdm.model.description.IndividualsAssociation;
54
import eu.etaxonomy.cdm.model.description.MeasurementUnit;
55
import eu.etaxonomy.cdm.model.description.MediaKey;
56
import eu.etaxonomy.cdm.model.description.MultiAccessKey;
57
import eu.etaxonomy.cdm.model.description.PolytomousKey;
58
import eu.etaxonomy.cdm.model.description.PolytomousKeyNode;
59
import eu.etaxonomy.cdm.model.description.PresenceAbsenceTerm;
60
import eu.etaxonomy.cdm.model.description.QuantitativeData;
61
import eu.etaxonomy.cdm.model.description.SpecimenDescription;
62
import eu.etaxonomy.cdm.model.description.State;
63
import eu.etaxonomy.cdm.model.description.StateData;
64
import eu.etaxonomy.cdm.model.description.StatisticalMeasure;
65
import eu.etaxonomy.cdm.model.description.StatisticalMeasurementValue;
66
import eu.etaxonomy.cdm.model.description.TaxonDescription;
67
import eu.etaxonomy.cdm.model.description.TaxonInteraction;
68
import eu.etaxonomy.cdm.model.description.TaxonNameDescription;
69
import eu.etaxonomy.cdm.model.description.TextData;
70
import eu.etaxonomy.cdm.model.description.TextFormat;
71
import eu.etaxonomy.cdm.model.description.WorkingSet;
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.BacterialName;
98
import eu.etaxonomy.cdm.model.name.CultivarPlantName;
99
import eu.etaxonomy.cdm.model.name.HybridRelationship;
100
import eu.etaxonomy.cdm.model.name.HybridRelationshipType;
101
import eu.etaxonomy.cdm.model.name.NameRelationship;
102
import eu.etaxonomy.cdm.model.name.NameRelationshipType;
103
import eu.etaxonomy.cdm.model.name.NameTypeDesignation;
104
import eu.etaxonomy.cdm.model.name.NameTypeDesignationStatus;
105
import eu.etaxonomy.cdm.model.name.NomenclaturalStatus;
106
import eu.etaxonomy.cdm.model.name.NomenclaturalStatusType;
107
import eu.etaxonomy.cdm.model.name.Rank;
108
import eu.etaxonomy.cdm.model.name.SpecimenTypeDesignation;
109
import eu.etaxonomy.cdm.model.name.SpecimenTypeDesignationStatus;
110
import eu.etaxonomy.cdm.model.name.TaxonNameBase;
111
import eu.etaxonomy.cdm.model.name.TaxonNameFactory;
112
import eu.etaxonomy.cdm.model.name.ViralName;
113
import eu.etaxonomy.cdm.model.occurrence.Collection;
114
import eu.etaxonomy.cdm.model.occurrence.DerivationEvent;
115
import eu.etaxonomy.cdm.model.occurrence.DerivationEventType;
116
import eu.etaxonomy.cdm.model.occurrence.DerivedUnit;
117
import eu.etaxonomy.cdm.model.occurrence.DeterminationEvent;
118
import eu.etaxonomy.cdm.model.occurrence.FieldUnit;
119
import eu.etaxonomy.cdm.model.occurrence.GatheringEvent;
120
import eu.etaxonomy.cdm.model.occurrence.MaterialOrMethodEvent;
121
import eu.etaxonomy.cdm.model.occurrence.MediaSpecimen;
122
import eu.etaxonomy.cdm.model.occurrence.PreservationMethod;
123
import eu.etaxonomy.cdm.model.occurrence.SpecimenOrObservationBase;
124
import eu.etaxonomy.cdm.model.occurrence.SpecimenOrObservationType;
125
import eu.etaxonomy.cdm.model.reference.Reference;
126
import eu.etaxonomy.cdm.model.reference.ReferenceFactory;
127
import eu.etaxonomy.cdm.model.taxon.Classification;
128
import eu.etaxonomy.cdm.model.taxon.Synonym;
129
import eu.etaxonomy.cdm.model.taxon.SynonymType;
130
import eu.etaxonomy.cdm.model.taxon.Taxon;
131
import eu.etaxonomy.cdm.model.taxon.TaxonNode;
132
import eu.etaxonomy.cdm.model.taxon.TaxonRelationship;
133
import eu.etaxonomy.cdm.model.taxon.TaxonRelationshipType;
134
import eu.etaxonomy.cdm.strategy.parser.TimePeriodParser;
135

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

    
154

    
155
	public void fillWithData(Session session){
156
		List<CdmBase> cdmBases = new ArrayList<CdmBase>();
157

    
158
		createAgents(cdmBases);
159

    
160
		createDescriptions(cdmBases);
161

    
162
		createMedia(cdmBases);
163

    
164
		createMolecular(cdmBases);
165

    
166
		createTaxonName(cdmBases);
167

    
168
		createOccurrence(cdmBases);
169

    
170
		createReference(cdmBases);
171

    
172
		createTaxon(cdmBases);
173

    
174
		createSupplemental(cdmBases);
175

    
176
		for (CdmBase cdmBase: cdmBases){
177
			session.save(cdmBase);
178
		}
179
	}
180

    
181

    
182
	private void createSupplemental(List<CdmBase> cdmBases)  {
183

    
184
		Reference ref = ReferenceFactory.newBook();
185

    
186
		Annotation annotation = Annotation.NewDefaultLanguageInstance("annotation");
187
		ref.addAnnotation(annotation);
188
		handleAnnotatableEntity(annotation);
189

    
190
		Credit credit = Credit.NewInstance(Person.NewInstance(), "refCredit", "rc", Language.DEFAULT());
191
		ref.addCredit(credit);
192
		handleAnnotatableEntity(credit);
193

    
194
		Rights rights = Rights.NewInstance("My rights", Language.GERMAN());
195
		ref.addRights(rights);
196
		handleAnnotatableEntity(rights);
197

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

    
207
		User user = User.NewInstance("myUser", "12345");
208
		Group group = Group.NewInstance("MyGroup");
209
		group.addMember(user);
210

    
211
		cdmBases.add(user);
212
		cdmBases.add(group);
213

    
214

    
215
		cdmBases.add(ref);
216

    
217
	}
218

    
219

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

    
232
		handleIdentifiableEntity(person);
233

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

    
243
		//Address
244
		Address address = Address.NewInstance(Country.GERMANY(), "locality", "pobox", "12345", "region", "street", locality);
245
		contact.addAddress(address);
246

    
247
		//Team
248
		Team team = Team.NewTitledInstance("Team title", "Team abbrev title");
249
		team.addTeamMember(person);
250
		handleIdentifiableEntity(team);
251

    
252

    
253
		//Institution
254
		Institution institution = Institution.NewInstance();
255
		institution.setCode("institution code");
256
		institution.setName("institution name");
257
		handleIdentifiableEntity(institution);
258

    
259

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

    
267
		Institution subInstitution = Institution.NewInstance();
268
		subInstitution.setCode("sub institution code");
269
		subInstitution.setName("sub institution name");
270
		subInstitution.setIsPartOf(institution);
271

    
272
		cdmBases.add(person);
273
		cdmBases.add(team);
274
		cdmBases.add(institution);
275
	}
276

    
277

    
278
	private void createDescriptions(List<CdmBase> cdmBases) {
279

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

    
285
		Representation rep = voc.getRepresentations().iterator().next();
286
		handleAnnotatableEntity(rep);
287
//		Representation engRep = Language.ENGLISH().getRepresentations().iterator().next();
288
//		handleAnnotatableEntity(engRep);
289
//		cdmBases.add(engRep);  //needed?
290

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

    
300

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

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

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

    
333
		CommonTaxonName commonTaxonName = CommonTaxonName.NewInstance("common name", Language.ENGLISH(), Country.UNITEDSTATESOFAMERICA());
334
		handleAnnotatableEntity(commonTaxonName);
335

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

    
341
		Taxon referencedTaxon = getTaxon();
342
		cdmBases.add(referencedTaxon);
343
		languageString.addIntextReference(IntextReference.NewTaxonInstance(referencedTaxon, languageString, 2, 5));
344
		textData.putModifyingText(eng, "nice diagnosis");
345
		handleAnnotatableEntity(textData);
346
		handleAnnotatableEntity(languageString);
347

    
348
		TextFormat format = TextFormat.NewInstance("format", "format", null);
349
		textData.setFormat(format);
350
		cdmBases.add(format);
351
		handleAnnotatableEntity(format);
352

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

    
358

    
359
		TaxonInteraction taxonInteraction = TaxonInteraction.NewInstance(Feature.HOSTPLANT());
360
		taxonInteraction.putDescription(Language.ENGLISH(), "interaction description");
361
		handleAnnotatableEntity(taxonInteraction);
362

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

    
369
		Taxon taxon = getTaxon();
370
		TaxonDescription taxonDescription = TaxonDescription.NewInstance(taxon);
371
		taxonDescription.addElements(categoricalData, quantitativeData,
372
				textData, commonTaxonName, taxonInteraction, indAssoc, distribution);
373

    
374
		DerivedUnit describedSpecimenOrObservation = DerivedUnit.NewInstance(SpecimenOrObservationType.DerivedUnit);
375
		taxonDescription.setDescribedSpecimenOrObservation(describedSpecimenOrObservation);
376

    
377
		taxonDescription.addScope(DefinedTerm.SEX_FEMALE());
378
		taxonDescription.addGeoScope(Country.GERMANY());
379
		handleIdentifiableEntity(taxonDescription);
380

    
381
		cdmBases.add(taxon);
382

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

    
393
		taxonDescription.addDescriptionSource(ref);
394

    
395

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

    
402
		//Name description
403
		TaxonNameBase<?,?> name = TaxonNameFactory.NewBotanicalInstance(Rank.GENUS());
404
		TaxonNameDescription nameDesc = TaxonNameDescription.NewInstance(name);
405
		cdmBases.add(name);
406
		handleAnnotatableEntity(nameDesc);
407

    
408

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

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

    
427

    
428
		WorkingSet workingSet = WorkingSet.NewInstance();
429
		workingSet.addDescription(taxonDescription);
430
		workingSet.setLabel("My Workingset");
431
		workingSet.getDescriptiveSystem();
432
		handleAnnotatableEntity(workingSet);
433

    
434

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

    
441

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

    
447
		PolytomousKey subkey = PolytomousKey.NewTitledInstance("Sub-key");
448
		firstChildNode.setSubkey(subkey);
449

    
450
		PolytomousKeyNode subKeyNode = PolytomousKeyNode.NewInstance("sub key couplet");
451
		subkey.getRoot().addChild(subKeyNode);
452
		secondChildNode.setOtherNode(subKeyNode);
453

    
454
		secondChildNode.putModifyingText(Language.GERMAN(), "manchmal");
455

    
456
		cdmBases.add(key);
457
		cdmBases.add(subkey);
458

    
459
		MediaKey mediaKey = MediaKey.NewInstance();
460
		mediaKey.addKeyRepresentation(Representation.NewInstance("Media Key Representation", "media key", null, Language.ENGLISH()));
461
		handleIdentificationKey(mediaKey, taxon, coveredTaxon);
462

    
463
		MultiAccessKey multiAccessKey = MultiAccessKey.NewInstance();
464
		handleIdentificationKey(multiAccessKey, taxon, coveredTaxon);
465

    
466
		cdmBases.add(mediaKey);
467
		cdmBases.add(multiAccessKey);
468

    
469
	}
470

    
471

    
472

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

    
484

    
485
	}
486

    
487

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

    
494
		mediaRepresentation.addRepresentationPart(movieFile);
495
		mediaRepresentation.addRepresentationPart(imageFile);
496
		mediaRepresentation.addRepresentationPart(audioFile);
497
		Media media = Media.NewInstance();
498
		media.addRepresentation(mediaRepresentation);
499

    
500
		media.putTitle(Language.ENGLISH(), "Media title");
501
		media.setMediaCreated(DateTime.now());
502
		media.putDescription(Language.ENGLISH(), "Media description");
503
		handleIdentifiableEntity(media);
504

    
505

    
506
		Person artist = Person.NewTitledInstance("artist");
507
		media.setArtist(artist);
508
		cdmBases.add(media);
509
		cdmBases.add(artist);
510
	}
511

    
512

    
513
	private void createMolecular(List<CdmBase> cdmBases) {
514
		DnaSample dnaSample = DnaSample.NewInstance();
515

    
516
		//Amplification
517
		Amplification amplification = Amplification.NewInstance();
518

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

    
527
		Primer forwardPrimer = Primer.NewInstance("forward primer");
528
		forwardPrimer.setPublishedIn(getReference());
529
		forwardPrimer.setSequence(SequenceString.NewInstance("my sequence"));
530
		handleAnnotatableEntity(forwardPrimer);
531

    
532
		Primer reversePrimer = Primer.NewInstance("reverse primer");
533
		handleAnnotatableEntity(reversePrimer);
534

    
535
		amplification.setForwardPrimer(forwardPrimer);
536
		amplification.setReversePrimer(reversePrimer);
537

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

    
545
		amplification.setLadderUsed("ladder");
546
		amplification.setElectrophoresisVoltage(5.5);
547
		amplification.setGelConcentration(2.4);
548
		amplification.setGelRunningTime(3.6);
549

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

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

    
563
		Media gelPhoto = Media.NewInstance();
564
		amplificationResult.setGelPhoto(gelPhoto);
565

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

    
574
		Media pherogram = Media.NewInstance();
575
		singleRead.setPherogram(pherogram);
576

    
577
		singleRead.setPrimer(forwardPrimer);
578
		singleRead.setSequence(SequenceString.NewInstance("ABTC"));
579
		singleRead.setDirection(SequenceDirection.Forward);
580

    
581
		//Sequence
582
		Sequence sequence = Sequence.NewInstance("ADDT");
583
		dnaSample.addSequence(sequence);
584

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

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

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

    
614

    
615
		//Phylogenetic Tree
616
		PhylogeneticTree phyloTree = PhylogeneticTree.NewInstance();
617
		phyloTree.addUsedSequences(sequence);
618
		handleIdentifiableEntity(phyloTree);
619

    
620

    
621
		cdmBases.add(dnaSample);
622
		cdmBases.add(phyloTree);
623
	}
624

    
625

    
626
	private void createTaxon(List<CdmBase> cdmBases) {
627
		Reference sec = getReference();
628
		TaxonNameBase<?,?> name = TaxonNameFactory.NewBotanicalInstance(Rank.GENUS());
629
		Taxon taxon = Taxon.NewInstance(name, sec);
630
		handleIdentifiableEntity(taxon);
631

    
632
		TaxonNameBase<?,?> synName = TaxonNameFactory.NewBotanicalInstance(Rank.GENUS());
633
		Synonym syn = Synonym.NewInstance(synName, sec, "123");
634
		taxon.addSynonym(syn, SynonymType.HETEROTYPIC_SYNONYM_OF());
635
		taxon.setDoubtful(true);
636
		handleIdentifiableEntity(syn);
637

    
638

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

    
645

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

    
653

    
654
		TaxonNode node = classification.addChildTaxon(taxon, sec,"22");
655
		handleIdentifiableEntity(classification);
656
		handleAnnotatableEntity(node);
657

    
658
		Taxon childTaxon = Taxon.NewInstance(synName, sec);
659
		node.addChildTaxon(childTaxon, sec, "44");
660
	    node.setUnplaced(true);
661
	    node.setExcluded(true);
662

    
663
		cdmBases.add(taxon);
664
		cdmBases.add(concept);
665
		cdmBases.add(childTaxon);
666
		cdmBases.add(classification);
667

    
668

    
669
	}
670

    
671

    
672

    
673

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

    
700
		Reference journal = ReferenceFactory.newJournal();
701
		reference.setInJournal(journal);
702

    
703
		handleIdentifiableEntity(reference);
704

    
705
		cdmBases.add(reference);
706

    
707
	}
708

    
709

    
710

    
711

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

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

    
728
		//FieldUnit
729
		FieldUnit fieldUnit = FieldUnit.NewInstance();
730
		fieldUnit.setFieldNumber("fieldNumber");
731
		fieldUnit.setFieldNotes("fieldNotes");
732
		Person primaryCollector = Person.NewInstance();
733
		fieldUnit.setPrimaryCollector(primaryCollector);
734
		handleIdentifiableEntity(fieldUnit);
735

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

    
748
		gatheringEvent.setDistanceToGround(10.4);
749
		gatheringEvent.setDistanceToGroundMax(100.3);
750
		gatheringEvent.setDistanceToGroundText("distance to ground text");
751

    
752
		gatheringEvent.setDistanceToWaterSurface(10.4);
753
		gatheringEvent.setDistanceToWaterSurfaceMax(100.3);
754
		gatheringEvent.setDistanceToWaterSurfaceText("distance to water text");
755
		handleAnnotatableEntity(gatheringEvent);
756
		handleEventBase(gatheringEvent);
757

    
758

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

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

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

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

    
806
		cdmBases.add(fieldUnit);
807
		cdmBases.add(mediaSpecimen);
808
		cdmBases.add(collection);
809
	}
810

    
811

    
812
	private void createTaxonName(List<CdmBase> cdmBases) {
813
		BacterialName bacName = TaxonNameFactory.NewBacterialInstance(Rank.GENUS());
814
		bacName.setSubGenusAuthorship("sub Genus author");
815
		bacName.setNameApprobation("nameApprobation");
816
		handleIdentifiableEntity(bacName);
817

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

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

    
856
		//TypeDesignation
857
		TaxonNameBase<?,?> speciesZooName = TaxonNameFactory.NewZoologicalInstance(Rank.SPECIES());
858
		NameTypeDesignation nameDesig = zooName.addNameTypeDesignation(speciesZooName, getReference(), "111", "original name",
859
				NameTypeDesignationStatus.AUTOMATIC(), true, true, true, true);
860
		handleAnnotatableEntity(nameDesig);
861
		SpecimenTypeDesignation specimenDesig = speciesZooName.addSpecimenTypeDesignation(getSpecimen(), SpecimenTypeDesignationStatus.HOLOTYPE(),
862
				getReference(), "p,22", "original name", false, true);
863
		handleAnnotatableEntity(specimenDesig);
864

    
865
		ViralName viralName = TaxonNameFactory.NewViralInstance(Rank.GENUS());
866
		viralName.setAcronym("acronym");
867
		handleIdentifiableEntity(viralName);
868

    
869

    
870
		cdmBases.add(bacName);
871
		cdmBases.add(botName);
872
		cdmBases.add(viralName);
873
		cdmBases.add(zooName);
874
	}
875

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

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

    
889
	private void handleIdentifiableEntity(IdentifiableEntity<?> identifiableEntity){
890
		handleAnnotatableEntity(identifiableEntity);
891

    
892
		//Credits
893
		Person creditor = Person.NewTitledInstance("Creditor");
894
		Credit credit = Credit.NewInstance(creditor, "credit");
895
		identifiableEntity.addCredit(credit);
896

    
897
		//Extension
898
		Extension.NewInstance(identifiableEntity, "extension", ExtensionType.INFORMAL_CATEGORY());
899

    
900
		//Identifier
901
		Identifier<?> identifier = identifiableEntity.addIdentifier("ident23", DefinedTerm.SEX_FEMALE());
902
		handleAnnotatableEntity(identifier);
903

    
904

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

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

    
919
		//source
920
		IdentifiableSource source = identifiableEntity.addSource(OriginalSourceType.Import, "id", "idNamespace",
921
				getReference(), "123");
922
		source.setOriginalNameString("original name");
923

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

    
932

    
933
	}
934

    
935

    
936
	private Reference getReference() {
937
		 Reference result = ReferenceFactory.newGeneric();
938
		 result.setTitle("some generic reference");
939
		 return result;
940
	}
941

    
942

    
943
	private DerivedUnit getSpecimen() {
944
		DerivedUnit derivedUnit = DerivedUnit.NewPreservedSpecimenInstance();
945
		return derivedUnit;
946
	}
947

    
948

    
949

    
950
	private Taxon getTaxon() {
951
		Reference sec = getReference();
952
		TaxonNameBase<?,?> name = TaxonNameFactory.NewBotanicalInstance(Rank.GENUS());
953
		Taxon taxon = Taxon.NewInstance(name, sec);
954
		return taxon;
955

    
956
	}
957
}
    (1-1/1)