2 * Copyright (C) 2009 EDIT
3 * European Distributed Institute of Taxonomy
4 * http://www.e-taxonomy.eu
6 * The contents of this file are subject to the Mozilla Public License Version 1.1
7 * See LICENSE.TXT at the top of this package for the full license terms.
10 package eu
.etaxonomy
.cdm
.persistence
.dao
.hibernate
.taxon
;
12 import static org
.junit
.Assert
.assertEquals
;
13 import static org
.junit
.Assert
.assertFalse
;
14 import static org
.junit
.Assert
.assertNotNull
;
15 import static org
.junit
.Assert
.assertNull
;
16 import static org
.junit
.Assert
.assertTrue
;
17 import static org
.junit
.Assert
.fail
;
19 import java
.io
.FileNotFoundException
;
20 import java
.util
.ArrayList
;
21 import java
.util
.HashSet
;
22 import java
.util
.List
;
24 import java
.util
.UUID
;
26 import org
.apache
.log4j
.Level
;
27 import org
.hibernate
.Hibernate
;
28 import org
.hibernate
.envers
.query
.AuditEntity
;
29 import org
.hibernate
.envers
.query
.criteria
.AuditCriterion
;
30 import org
.hibernate
.proxy
.HibernateProxy
;
31 import org
.junit
.After
;
32 import org
.junit
.Assert
;
33 import org
.junit
.Before
;
34 import org
.junit
.Test
;
35 import org
.unitils
.dbunit
.annotation
.DataSet
;
36 import org
.unitils
.dbunit
.annotation
.ExpectedDataSet
;
37 import org
.unitils
.spring
.annotation
.SpringBeanByType
;
39 import eu
.etaxonomy
.cdm
.hibernate
.HibernateProxyHelper
;
40 import eu
.etaxonomy
.cdm
.model
.common
.IdentifiableEntity
;
41 import eu
.etaxonomy
.cdm
.model
.common
.Marker
;
42 import eu
.etaxonomy
.cdm
.model
.common
.MarkerType
;
43 import eu
.etaxonomy
.cdm
.model
.location
.NamedArea
;
44 import eu
.etaxonomy
.cdm
.model
.name
.NonViralName
;
45 import eu
.etaxonomy
.cdm
.model
.name
.TaxonNameBase
;
46 import eu
.etaxonomy
.cdm
.model
.reference
.Reference
;
47 import eu
.etaxonomy
.cdm
.model
.taxon
.Classification
;
48 import eu
.etaxonomy
.cdm
.model
.taxon
.Synonym
;
49 import eu
.etaxonomy
.cdm
.model
.taxon
.SynonymType
;
50 import eu
.etaxonomy
.cdm
.model
.taxon
.Taxon
;
51 import eu
.etaxonomy
.cdm
.model
.taxon
.TaxonBase
;
52 import eu
.etaxonomy
.cdm
.model
.taxon
.TaxonNode
;
53 import eu
.etaxonomy
.cdm
.model
.taxon
.TaxonRelationship
;
54 import eu
.etaxonomy
.cdm
.model
.taxon
.TaxonRelationshipType
;
55 import eu
.etaxonomy
.cdm
.model
.view
.AuditEvent
;
56 import eu
.etaxonomy
.cdm
.model
.view
.AuditEventRecord
;
57 import eu
.etaxonomy
.cdm
.model
.view
.context
.AuditEventContextHolder
;
58 import eu
.etaxonomy
.cdm
.persistence
.dao
.common
.AuditEventSort
;
59 import eu
.etaxonomy
.cdm
.persistence
.dao
.common
.IDefinedTermDao
;
60 import eu
.etaxonomy
.cdm
.persistence
.dao
.reference
.IReferenceDao
;
61 import eu
.etaxonomy
.cdm
.persistence
.dao
.taxon
.IClassificationDao
;
62 import eu
.etaxonomy
.cdm
.persistence
.dao
.taxon
.ITaxonDao
;
63 import eu
.etaxonomy
.cdm
.persistence
.dto
.UuidAndTitleCache
;
64 import eu
.etaxonomy
.cdm
.persistence
.query
.GroupByCount
;
65 import eu
.etaxonomy
.cdm
.persistence
.query
.GroupByDate
;
66 import eu
.etaxonomy
.cdm
.persistence
.query
.Grouping
;
67 import eu
.etaxonomy
.cdm
.persistence
.query
.MatchMode
;
68 import eu
.etaxonomy
.cdm
.persistence
.query
.NativeSqlOrderHint
;
69 import eu
.etaxonomy
.cdm
.persistence
.query
.OrderHint
;
70 import eu
.etaxonomy
.cdm
.persistence
.query
.OrderHint
.SortOrder
;
71 import eu
.etaxonomy
.cdm
.test
.integration
.CdmTransactionalIntegrationTest
;
72 import eu
.etaxonomy
.cdm
.test
.unitils
.CleanSweepInsertLoadStrategy
;
78 public class TaxonDaoHibernateImplTest
extends CdmTransactionalIntegrationTest
{
81 private ITaxonDao taxonDao
;
84 private IClassificationDao classificationDao
;
87 private IReferenceDao referenceDao
;
90 IDefinedTermDao definedTermDao
;
93 private UUID sphingidae
;
94 private UUID acherontia
;
96 private UUID retheraSecCdmtest
;
97 private UUID atroposAgassiz
; // a Synonym
98 private UUID atroposLeach
; // a Synonym
99 private UUID acherontiaLachesis
;
101 private AuditEvent previousAuditEvent
;
102 private AuditEvent mostRecentAuditEvent
;
104 private UUID northernAmericaUuid
;
105 private UUID southernAmericaUuid
;
106 private UUID antarcticaUuid
;
108 private UUID classificationUuid
;
110 private static final String
[] TABLE_NAMES
= new String
[] {
111 "HOMOTYPICALGROUP", "HOMOTYPICALGROUP_AUD", "REFERENCE", "REFERENCE_AUD", "TAXONBASE", "TAXONBASE_AUD"
112 , "TAXONNAMEBASE", "TAXONNAMEBASE_AUD", "TAXONRELATIONSHIP", "TAXONRELATIONSHIP_AUD" };
116 public void setUp() {
118 uuid
= UUID
.fromString("496b1325-be50-4b0a-9aa2-3ecd610215f2");
119 sphingidae
= UUID
.fromString("54e767ee-894e-4540-a758-f906ecb4e2d9");
120 acherontia
= UUID
.fromString("c5cc8674-4242-49a4-aada-72d63194f5fa");
121 acherontiaLachesis
= UUID
.fromString("b04cc9cb-2b4a-4cc4-a94a-3c93a2158b06");
122 atroposAgassiz
= UUID
.fromString("d75b2e3d-7394-4ada-b6a5-93175b8751c1");
123 atroposLeach
= UUID
.fromString("3da4ab34-6c50-4586-801e-732615899b07");
124 rethera
= UUID
.fromString("a9f42927-e507-4fda-9629-62073a908aae");
125 retheraSecCdmtest
= UUID
.fromString("a9f42927-e507-4fda-9629-62073a908aae");
127 previousAuditEvent
= new AuditEvent();
128 previousAuditEvent
.setRevisionNumber(1025);
129 previousAuditEvent
.setUuid(UUID
.fromString("a680fab4-365e-4765-b49e-768f2ee30cda"));
130 mostRecentAuditEvent
= new AuditEvent();
131 mostRecentAuditEvent
.setRevisionNumber(1026);
132 mostRecentAuditEvent
.setUuid(UUID
.fromString("afe8e761-8545-497b-9134-6a6791fc0b0d"));
133 AuditEventContextHolder
.clearContext(); // By default we're in the current view (i.e. view == null)
135 northernAmericaUuid
= UUID
.fromString("2757e726-d897-4546-93bd-7951d203bf6f");
136 southernAmericaUuid
= UUID
.fromString("6310b3ba-96f4-4855-bb5b-326e7af188ea");
137 antarcticaUuid
= UUID
.fromString("791b3aa0-54dd-4bed-9b68-56b4680aad0c");
139 classificationUuid
= UUID
.fromString("aeee7448-5298-4991-b724-8d5b75a0a7a9");
143 public void tearDown() {
144 AuditEventContextHolder
.clearContext();
148 * Test method for {@link eu.etaxonomy.cdm.persistence.dao.hibernate.taxon.TaxonDaoHibernateImpl#TaxonDaoHibernateImpl()}.
152 public void testInit() {
153 logger
.warn("testInit()");
154 assertNotNull("Instance of ITaxonDao expected",taxonDao
);
155 assertNotNull("Instance of IReferenceDao expected",referenceDao
);
159 * Test method for {@link eu.etaxonomy.cdm.persistence.dao.hibernate.taxon.TaxonDaoHibernateImpl#getTaxaByName(java.lang.String, eu.etaxonomy.cdm.model.reference.Reference)}.
163 public void testGetTaxaByName() {
164 Reference sec
= referenceDao
.findById(1);
165 assert sec
!= null : "sec must exist";
167 List
<TaxonBase
> results
= taxonDao
.getTaxaByName("Aus", sec
);
168 assertNotNull("getTaxaByName should return a List", results
);
169 //assertFalse("The list should not be empty", results.isEmpty());
170 assertEquals(1, results
.size());
172 results
= taxonDao
.getTaxaByName("A*", MatchMode
.BEGINNING
, true, null, null);
173 assertNotNull("getTaxaByName should return a List", results
);
175 int numberOfTaxaByName_A
= 5;
177 logger
.setLevel(Level
.DEBUG
); //FIXME #######################
178 if (logger
.isDebugEnabled()) {
179 for (int i
= 0; i
< results
.size(); i
++) {
180 String nameCache
= "";
181 TaxonNameBase
<?
,?
> taxonNameBase
= results
.get(i
).getName();
182 nameCache
= HibernateProxyHelper
.deproxy(taxonNameBase
, NonViralName
.class).getNameCache();
183 logger
.debug(results
.get(i
).getClass() + "(" + i
+")" +
184 ": Name Cache = " + nameCache
+ ", Title Cache = " + results
.get(i
).getTitleCache());
188 assertEquals(numberOfTaxaByName_A
, results
.size());
191 //System.err.println("Species group: " + Rank.SPECIESGROUP().getId() + "Species: " + Rank.SPECIES().getId() + "Section Botany: "+ Rank.SECTION_BOTANY());
193 // assertEquals(results.get(0).getTitleCache(), "Abies sec. ???");
194 // assertEquals(results.get(1).getTitleCache(), "Abies Mill.");
195 // assertEquals(results.get(2).getTitleCache(), "Abies mill. sec. ???");
196 // assertEquals(results.get(3).getTitleCache(), "Abies alba sec. ???");
197 // assertEquals(results.get(4).getTitleCache(), "Abies alba Michx. sec. ???");
198 // assertEquals(results.get(5).getTitleCache(), "Abies alba Mill. sec. ???");
200 results
= taxonDao
.getTaxaByName("A*", MatchMode
.BEGINNING
, true, null, null);
201 assertNotNull("getTaxaByName should return a List", results
);
202 assertEquals(numberOfTaxaByName_A
, results
.size());
204 results
= taxonDao
.getTaxaByName("Aus", MatchMode
.EXACT
, true, null, null);
205 assertNotNull("getTaxaByName should return a List", results
);
206 assertEquals("Results list should contain one entity",1,results
.size());
211 @DataSet (loadStrategy
=CleanSweepInsertLoadStrategy
.class, value
="TaxonDaoHibernateImplTest.testGetTaxaByNameAndArea.xml")
212 public void testGetTaxaByNameWithMisappliedNames(){
214 Classification classification
= classificationDao
.load(classificationUuid
);
217 * The testdata contains 3 misapplied names (1. nameCache = Aus, 2. nameCache = Rethera, 3. nameCache = Daphnis), two contained in the classification used in this test,
218 * the other one is not contained in any classification. This latter case is the more general situation.
219 * Misapplied names should be found regardless of whether they are contained in a classification or not.
221 //two accepted taxa starting with R in classification "TestBaum"
222 List
<TaxonBase
> results
= taxonDao
.getTaxaByName(true, false, false, false, false, "R*", classification
, MatchMode
.BEGINNING
, null, null, null, null, null);
223 Assert
.assertEquals("There should be 2 Taxa", 2, results
.size());
225 //three taxa, 2 accepted and 1 misapplied name starting with R
226 results
= taxonDao
.getTaxaByName(true, false, true, false, false, "R*", null, MatchMode
.BEGINNING
, null, null, null, null, null);
227 Assert
.assertEquals("There should be 3 Taxa", 3, results
.size());
229 //one synonym has no accepted taxon
230 results
= taxonDao
.getTaxaByName(true, true, true, false, false, "A*", null, MatchMode
.BEGINNING
, null, null, null, null, null);
231 Assert
.assertEquals("There should be 11 Taxa",11, results
.size());
233 //two accepted taxa in classification and 1 misapplied name with accepted name in classification
234 results
= taxonDao
.getTaxaByName(true, true, true, false, false, "R*", classification
, MatchMode
.BEGINNING
, null, null, null, null, null);
235 Assert
.assertEquals("There should be 3 Taxa", 3, results
.size());
237 //same as above because all taxa, synonyms and misapplied names starting with R are in the classification
238 results
= taxonDao
.getTaxaByName(true, true, true, false, false, "R*", null, MatchMode
.BEGINNING
, null, null, null, null, null);
239 Assert
.assertEquals("There should be 3 Taxa", 3, results
.size());
241 //find misapplied names with accepted taxon in the classification, the accepted taxa of two misapplied names are in the classification
242 results
= taxonDao
.getTaxaByName(false, false, true, false, false, "*", classification
, MatchMode
.BEGINNING
, null, null, null, null, null);
243 Assert
.assertEquals("There should be 2 Taxa", 2, results
.size());
245 //find misapplied names beginning with R
246 results
= taxonDao
.getTaxaByName(false, false, true, false, false, "R*", null, MatchMode
.BEGINNING
, null, null, null, null, null);
247 Assert
.assertEquals("There should be 1 Taxa", 1, results
.size());
249 //find all three misapplied names
250 results
= taxonDao
.getTaxaByName(false, false, true, false, false, "*", null, MatchMode
.BEGINNING
, null, null, null, null, null);
251 Assert
.assertEquals("There should be 3 Taxa", 3, results
.size());
255 * Test for all not covered possibilities of searches
258 @DataSet (loadStrategy
=CleanSweepInsertLoadStrategy
.class, value
="TaxonDaoHibernateImplTest.testGetTaxaByNameAndArea.xml")
259 public void testGetTaxaByNameVariants(){
260 List
<TaxonBase
> results
= taxonDao
.getTaxaByName(false, false, false, true, false, "c*", null, MatchMode
.BEGINNING
, null, null, null, null, null);
261 Assert
.assertEquals("There should be 2 Taxa",2, results
.size());
263 results
= taxonDao
.getTaxaByName(false, false, true, true, false, "R*", null, MatchMode
.BEGINNING
, null, null, null, null, null);
264 Assert
.assertEquals("There should be 1 Taxa", 1, results
.size());
266 results
= taxonDao
.getTaxaByName(false, true, true, true, false, "R*", null, MatchMode
.BEGINNING
, null, null, null, null, null);
267 Assert
.assertEquals("There should be 1 Taxa", 1, results
.size());
269 results
= taxonDao
.getTaxaByName(false, true, false, true, false, "c*", null, MatchMode
.BEGINNING
, null, null, null, null, null);
270 Assert
.assertEquals("There should be 2 Taxa", 2, results
.size());
272 results
= taxonDao
.getTaxaByName(true, false, false, true, false, "c*", null, MatchMode
.BEGINNING
, null, null, null, null, null);
273 Assert
.assertEquals("There should be 2 Taxa", 2, results
.size());
274 Classification classification
= classificationDao
.load(classificationUuid
);
275 results
= taxonDao
.getTaxaByName(false, false, false, true, false, "c*", classification
, MatchMode
.BEGINNING
, null, null, null, null, null);
276 Assert
.assertEquals("There should be 1 Taxa", 1, results
.size());
277 Set
<NamedArea
> namedAreas
= new HashSet
<>();
278 namedAreas
.add((NamedArea
)definedTermDao
.load(southernAmericaUuid
));
279 results
= taxonDao
.getTaxaByName(false, false, false, true, false, "c*", null, MatchMode
.BEGINNING
, namedAreas
, null, null, null, null);
280 Assert
.assertEquals("There should be 1 Taxa", 1, results
.size());
284 * Test method for {@link eu.etaxonomy.cdm.persistence.dao.hibernate.taxon.TaxonDaoHibernateImpl#getTaxaByName(java.lang.String, eu.etaxonomy.cdm.model.reference.Reference)}.
288 public void testGetTaxaByNameForEditor() {
289 Reference sec
= referenceDao
.findById(1);
290 assert sec
!= null : "sec must exist";
292 List
<UuidAndTitleCache
<IdentifiableEntity
>> results
= taxonDao
.getTaxaByNameForEditor(true, true, false,false, false, "Acher", null, MatchMode
.BEGINNING
, null, null);
293 assertNotNull("getTaxaByName should return a List", results
);
294 assertFalse("The list should not be empty", results
.isEmpty());
295 assertEquals(4, results
.size());
298 results
= taxonDao
.getTaxaByNameForEditor(true, true, false, false,false,"A",null, MatchMode
.BEGINNING
, null, null);
299 assertNotNull("getTaxaByName should return a List", results
);
300 assertEquals(7, results
.size());
303 results
= taxonDao
.getTaxaByNameForEditor(true, false,false, false,false, "A", null,MatchMode
.BEGINNING
, null, null);
304 assertNotNull("getTaxaByName should return a List", results
);
305 assertEquals(5, results
.size());
306 assertEquals(results
.get(0).getType(), Taxon
.class);
308 results
= taxonDao
.getTaxaByNameForEditor(false, true,false,false, false,"A", null,MatchMode
.BEGINNING
, null, null);
309 assertNotNull("getTaxaByName should return a List", results
);
310 assertEquals(2, results
.size());
311 assertEquals(results
.get(0).getType(), Synonym
.class);
313 results
= taxonDao
.getTaxaByNameForEditor(true, true,false,false,false,"Aus", null,MatchMode
.EXACT
, null, null);
314 assertNotNull("getTaxaByName should return a List", results
);
315 assertEquals("Results list should contain one entity",1,results
.size());
317 results
= taxonDao
.getTaxaByNameForEditor(true, true,true,false,false,"A", null,MatchMode
.BEGINNING
, null, null);
318 assertNotNull("getTaxaByName should return a List", results
);
319 assertEquals("Results list should contain one entity", 8, results
.size());
321 //TODO: test the search for misapplied names
327 * Test method for {@link eu.etaxonomy.cdm.persistence.dao.hibernate.taxon.TaxonDaoHibernateImpl#getTaxaByName(java.lang.String, eu.etaxonomy.cdm.model.reference.Reference)}
328 * restricting the search by a set of Areas.
331 @DataSet(loadStrategy
=CleanSweepInsertLoadStrategy
.class, value
="TaxonDaoHibernateImplTest.testGetTaxaByNameAndArea.xml")
332 public void testGetTaxaByNameAndArea() {
334 Set
<NamedArea
> namedAreas
= new HashSet
<>();
335 namedAreas
.add((NamedArea
)definedTermDao
.load(northernAmericaUuid
));
336 //namedAreas.add((NamedArea)definedTermDao.load(southernAmericaUuid));
337 //namedAreas.add((NamedArea)definedTermDao.load(antarcticaUuid));
339 Classification taxonmicTree
= classificationDao
.findByUuid(classificationUuid
);
341 // prepare some synonym relation ships for some tests
342 Synonym synAtroposAgassiz
= (Synonym
)taxonDao
.findByUuid(atroposAgassiz
);
343 Taxon taxonRethera
= (Taxon
)taxonDao
.findByUuid(rethera
);
344 taxonRethera
.addSynonym(synAtroposAgassiz
, SynonymType
.SYNONYM_OF());
345 logger
.warn("addSynonym(..)");
347 Synonym synAtroposLeach
= (Synonym
)taxonDao
.findByUuid(atroposLeach
);
348 Taxon taxonRetheraSecCdmtest
= (Taxon
)taxonDao
.findByUuid(retheraSecCdmtest
);
349 taxonRetheraSecCdmtest
.addSynonym(synAtroposLeach
, SynonymType
.SYNONYM_OF());
350 this.taxonDao
.save(taxonRetheraSecCdmtest
);
352 Taxon test
= (Taxon
)this.taxonDao
.findByUuid(retheraSecCdmtest
);
353 // Set<Synonym> synonyms3 = test.getSynonyms();
354 // 1. searching for a taxon (Rethera)
355 //long numberOfTaxa = taxonDao.countTaxaByName(Taxon.class, "Rethera", null, MatchMode.BEGINNING, namedAreas);
357 List
<TaxonBase
> results
= taxonDao
.getTaxaByName(true,false, false, false, false,"Rethera", null, MatchMode
.BEGINNING
, namedAreas
,
358 null, null, null, null);
359 assertNotNull("getTaxaByName should return a List", results
);
360 assertTrue("expected to find two taxa but found "+results
.size(), results
.size() == 2);
362 results
= taxonDao
.getTaxaByName(false,false, false, true, false,"com*", null, MatchMode
.BEGINNING
, namedAreas
,
363 null, null, null, null);
364 assertNotNull("getTaxaByName should return a List", results
);
365 assertTrue("expected to find one taxon but found "+results
.size(), results
.size() == 1);
367 // 2. searching for a taxon (Rethera) contained in a specific classification
368 results
= taxonDao
.getTaxaByName(true, false, false, false, false,"Rethera", taxonmicTree
, MatchMode
.BEGINNING
, namedAreas
,
369 null, null, null, null);
370 assertNotNull("getTaxaByName should return a List", results
);
371 assertTrue("expected to find one taxon but found "+results
.size(), results
.size() == 1);
374 // 3. searching for Synonyms
375 results
= taxonDao
.getTaxaByName(false, true, false, false, false,"Atropo", null, MatchMode
.ANYWHERE
, null,
376 null, null, null, null);
377 assertNotNull("getTaxaByName should return a List", results
);
378 /*System.err.println(results.get(0).getTitleCache() + " - " +results.get(1).getTitleCache() + " - " +results.get(2).getTitleCache() );
381 System.err.println(((Synonym)results.get(0)).getAcceptedTaxa().contains(taxonRethera)+ " - " +((Synonym)results.get(1)).getAcceptedTaxa().contains(taxonRethera)+ " - " +((Synonym)results.get(2)).getAcceptedTaxa().contains(taxonRethera)+ " - " );
383 assertTrue("expected to find three taxa but found "+results
.size(), results
.size() == 3);
385 // 4. searching for Synonyms
386 results
= taxonDao
.getTaxaByName(false, true, false, false, false,"Atropo", null, MatchMode
.BEGINNING
, null,
387 null, null, null, null);
388 assertNotNull("getTaxaByName should return a List", results
);
389 assertTrue("expected to find three taxa but found "+results
.size(), results
.size() == 3);
392 // 5. searching for a Synonyms and Taxa
393 results
= taxonDao
.getTaxaByName(true, true, false, false, false,"A", null, MatchMode
.BEGINNING
, namedAreas
,
394 null, null, null, null);
395 //only five taxa have a distribution
396 assertNotNull("getTaxaByName should return a List", results
);
397 assertTrue("expected to find 8 taxa but found "+results
.size(), results
.size() == 8);
402 * Test method for {@link eu.etaxonomy.cdm.persistence.dao.hibernate.taxon.TaxonDaoHibernateImpl#findByNameTitleCache(Class<? extends TaxonBase>clazz, String queryString, Classification classification, MatchMode matchMode, Set<NamedArea> namedAreas, Integer pageNumber, Integer pageSize, List<String> propertyPaths)}
403 * restricting the search by a set of Areas.
406 @DataSet(loadStrategy
=CleanSweepInsertLoadStrategy
.class, value
="TaxonDaoHibernateImplTest.testGetTaxaByNameAndArea.xml")
407 public void testFindByNameTitleCache() {
409 Set
<NamedArea
> namedAreas
= new HashSet
<NamedArea
>();
410 namedAreas
.add((NamedArea
)definedTermDao
.load(northernAmericaUuid
));
411 //namedAreas.add((NamedArea)definedTermDao.load(southernAmericaUuid));
412 //namedAreas.add((NamedArea)definedTermDao.load(antarcticaUuid));
414 Classification classification
= classificationDao
.findByUuid(classificationUuid
);
416 // prepare some synonym relation ships for some tests
417 Synonym synAtroposAgassiz
= (Synonym
)taxonDao
.findByUuid(atroposAgassiz
);
418 Taxon taxonRethera
= (Taxon
)taxonDao
.findByUuid(rethera
);
419 taxonRethera
.addSynonym(synAtroposAgassiz
, SynonymType
.SYNONYM_OF());
420 logger
.warn("addSynonym(..)");
421 this.taxonDao
.clear();
422 Synonym synAtroposLeach
= (Synonym
)taxonDao
.findByUuid(atroposLeach
);
423 Taxon taxonRetheraSecCdmtest
= (Taxon
)taxonDao
.findByUuid(retheraSecCdmtest
);
424 taxonRetheraSecCdmtest
.addSynonym(synAtroposLeach
, SynonymType
.SYNONYM_OF());
425 this.taxonDao
.clear();
426 // 1. searching for a taxon (Rethera)
427 //long numberOfTaxa = taxonDao.countTaxaByName(Taxon.class, "Rethera", null, MatchMode.BEGINNING, namedAreas);
429 List
<TaxonBase
> results
= taxonDao
.findByNameTitleCache(true, false, "Rethera Rothschild & Jordan, 1903", null, MatchMode
.EXACT
, namedAreas
,
430 null, null, null, null);
431 assertNotNull("getTaxaByName should return a List", results
);
432 assertTrue("expected to find two taxa but found "+results
.size(), results
.size() == 2);
434 // 2. searching for a taxon (Rethera) contained in a specific classification
435 results
= taxonDao
.findByNameTitleCache(true, false, "Rethera Rothschild & Jordan, 1903", classification
, MatchMode
.EXACT
, namedAreas
,
436 null, null, null, null);
437 assertNotNull("getTaxaByName should return a List", results
);
438 assertTrue("expected to find one taxon but found "+results
.size(), results
.size() == 1);
441 // 3. searching for Synonyms
442 results
= taxonDao
.findByNameTitleCache(false, true, "*Atropo", null, MatchMode
.ANYWHERE
, null,
443 null, null, null, null);
444 assertNotNull("getTaxaByName should return a List", results
);
446 assertTrue("expected to find two taxa but found "+results
.size(), results
.size() == 2);
448 // 4. searching for Synonyms
449 results
= taxonDao
.findByNameTitleCache(false, true, "Atropo", null, MatchMode
.BEGINNING
, null,
450 null, null, null, null);
451 assertNotNull("getTaxaByName should return a List", results
);
452 assertTrue("expected to find two taxa but found "+results
.size(), results
.size() == 2);
455 // 5. searching for a Synonyms and Taxa
456 // attache a synonym first
457 Synonym syn
= (Synonym
)taxonDao
.findByUuid(this.atroposLeach
);
458 Taxon tax
= (Taxon
) taxonDao
.findByUuid(rethera
);
459 tax
.addSynonym(syn
, SynonymType
.HETEROTYPIC_SYNONYM_OF());
462 results
= taxonDao
.findByNameTitleCache(true, true, "A", null, MatchMode
.BEGINNING
, namedAreas
,
463 null, null, null, null);
464 assertNotNull("getTaxaByName should return a List", results
);
465 assertTrue("expected to find 8 taxa but found "+results
.size(), results
.size() == 8);
469 @DataSet(loadStrategy
=CleanSweepInsertLoadStrategy
.class, value
="TaxonDaoHibernateImplTest.testGetTaxaByNameAndArea.xml")
470 public void testTaxonNameInTwoClassifications(){
471 int numberOfClassifications
= classificationDao
.count();
472 List
<String
> propertyPaths
= new ArrayList
<>();
473 propertyPaths
.add("taxonNodes");
474 List
<TaxonBase
> taxa
= taxonDao
.getTaxaByName(true, true, false, false, false,"P", null, MatchMode
.BEGINNING
, null, null, null, null, null);
475 Taxon taxon
= (Taxon
)taxa
.get(0);
476 Set
<TaxonNode
> nodes
= taxon
.getTaxonNodes();
477 assertTrue(nodes
.size() == 1);
478 //assertNotNull(taxa);
479 //assertTrue(taxa.size() > 0);
484 public void testFindByUuid() {
485 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(uuid
);
486 assertNotNull("findByUuid should return a taxon", taxon
);
487 assertFalse("findByUuid should not return a taxon with it's name initialized",Hibernate
.isInitialized(taxon
.getName()));
492 public void testLoad() {
493 List
<String
> propertyPaths
= new ArrayList
<>();
494 propertyPaths
.add("name");
495 propertyPaths
.add("sec");
496 Taxon taxon
= (Taxon
)taxonDao
.load(uuid
, propertyPaths
);
497 assertNotNull("findByUuid should return a taxon",taxon
);
498 assertTrue("load should return a taxon with it's name initialized, given that the property was specified in the method",Hibernate
.isInitialized(taxon
.getName()));
499 assertTrue("load should return a taxon with it's secundum reference initialized, given that the property was specified in the method",Hibernate
.isInitialized(taxon
.getSec()));
504 public void testCountTaxonRelationshipsByTaxon() {
505 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(sphingidae
);
506 assert taxon
!= null : "taxon must exist";
508 int numberOfRelatedTaxa
= taxonDao
.countTaxonRelationships(taxon
, TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN(), TaxonRelationship
.Direction
.relatedTo
);
509 assertEquals("countTaxonRelationships should return 8", 8, numberOfRelatedTaxa
);
514 public void testCountTaxaByName() {
515 long numberOfTaxa
= taxonDao
.countTaxaByName(true, false, false, false,false, "A", null, MatchMode
.BEGINNING
, null);
516 assertEquals(5, numberOfTaxa
);
517 numberOfTaxa
= taxonDao
.countTaxaByName(true, false, false, false, false,"Smerinthus kindermannii", null, MatchMode
.EXACT
, null);
518 assertEquals(1, numberOfTaxa
);
519 numberOfTaxa
= taxonDao
.countTaxaByName(false, true, false, false, false,"A", null, MatchMode
.BEGINNING
, null);
520 assertEquals(2, numberOfTaxa
);
521 numberOfTaxa
= taxonDao
.countTaxaByName(true, true, false, false, false,"A", null, MatchMode
.BEGINNING
, null);
522 assertEquals(7, numberOfTaxa
);
523 numberOfTaxa
= taxonDao
.countTaxaByName(true, true, false, false,false, "Aasfwerfwf fffe", null, MatchMode
.BEGINNING
, null);
524 assertEquals(0, numberOfTaxa
);
525 // FIXME implement test for search in specific classification
526 // Reference reference = referenceDao.findByUuid(UUID.fromString("596b1325-be50-4b0a-9aa2-3ecd610215f2"));
527 // numberOfTaxa = taxonDao.countTaxaByName("A*", MatchMode.BEGINNING, SelectMode.ALL, null, null);
528 // assertEquals(numberOfTaxa, 2);
533 public void testRelatedTaxa() {
534 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(sphingidae
);
535 assert taxon
!= null : "taxon must exist";
537 List
<String
> propertyPaths
= new ArrayList
<>();
538 propertyPaths
.add("fromTaxon");
539 propertyPaths
.add("fromTaxon.name");
540 List
<OrderHint
> orderHints
= new ArrayList
<>();
541 orderHints
.add(new OrderHint("relatedFrom.name.genusOrUninomial", SortOrder
.ASCENDING
));
542 orderHints
.add(new OrderHint("relatedFrom.name.specificEpithet", SortOrder
.ASCENDING
));
543 orderHints
.add(new OrderHint("relatedFrom.name.infraSpecificEpithet", SortOrder
.ASCENDING
));
545 List
<TaxonRelationship
> relatedTaxa
= taxonDao
.getTaxonRelationships(taxon
, TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN(), null, null, orderHints
,propertyPaths
, TaxonRelationship
.Direction
.relatedTo
);
546 assertNotNull("getRelatedTaxa should return a List",relatedTaxa
);
547 assertEquals("getRelatedTaxa should return all 8 related taxa", 8, relatedTaxa
.size());
548 assertTrue("getRelatedTaxa should return TaxonRelationship objects with the relatedFrom taxon initialized",Hibernate
.isInitialized(relatedTaxa
.get(0).getFromTaxon()));
549 assertTrue("getRelatedTaxa should return TaxonRelationship objects with the relatedFrom taxon initialized",Hibernate
.isInitialized(relatedTaxa
.get(0).getFromTaxon().getName()));
551 assertEquals("Acherontia should appear first in the list of related taxa", relatedTaxa
.get(0).getFromTaxon().getTitleCache(), "Acherontia Laspeyres, 1809 sec. cate-sphingidae.org");
552 assertEquals("Sphingonaepiopsis should appear last in the list of related taxa", "Sphingonaepiopsis Wallengren, 1858 sec. cate-sphingidae.org", relatedTaxa
.get(relatedTaxa
.size()-1).getFromTaxon().getTitleCache());
557 public void testGetRelatedTaxaPaged() {
558 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(sphingidae
);
559 assert taxon
!= null : "taxon must exist";
561 List
<String
> propertyPaths
= new ArrayList
<>();
562 propertyPaths
.add("fromTaxon");
563 propertyPaths
.add("fromTaxon.name");
565 List
<OrderHint
> orderHints
= new ArrayList
<>();
566 orderHints
.add(new OrderHint("relatedFrom.titleCache", SortOrder
.ASCENDING
));
569 List
<TaxonRelationship
> firstPage
= taxonDao
.getTaxonRelationships(taxon
,TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN(), pageSize
, 0, orderHints
,propertyPaths
, TaxonRelationship
.Direction
.relatedTo
);
570 List
<TaxonRelationship
> secondPage
= taxonDao
.getTaxonRelationships(taxon
,TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN(),pageSize
, 1, orderHints
,propertyPaths
, TaxonRelationship
.Direction
.relatedTo
);
571 List
<TaxonRelationship
> thirdPage
= taxonDao
.getTaxonRelationships(taxon
,TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN(), pageSize
, 2, orderHints
,propertyPaths
, TaxonRelationship
.Direction
.relatedTo
);
573 assertNotNull("getRelatedTaxa: 3, 0 should return a List",firstPage
);
574 assertEquals("getRelatedTaxa: 3, 0 should return a List with 3 elements", pageSize
,firstPage
.size());
575 assertNotNull("getRelatedTaxa: 3, 1 should return a List",secondPage
);
576 assertEquals("getRelatedTaxa: 3, 1 should return a List with 3 elements", pageSize
, secondPage
.size());
577 assertNotNull("getRelatedTaxa: 3, 2 should return a List",thirdPage
);
578 assertEquals("getRelatedTaxa: 3, 2 should return a List with 2 elements", 2, thirdPage
.size());
583 public void testCountSynonyms() {
584 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontia
);
585 assert taxon
!= null : "taxon must exist";
587 long numberOfRelatedSynonym
= taxonDao
.countSynonyms(taxon
,null);
588 assertEquals("countSynonyms should return 3", 3, numberOfRelatedSynonym
);
593 public void testGetSynonyms() {
594 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontia
);
595 assert taxon
!= null : "taxon must exist";
596 List
<String
> propertyPaths
= new ArrayList
<String
>();
597 propertyPaths
.add("synonym");
598 propertyPaths
.add("synonym.name");
600 List
<OrderHint
> orderHints
= new ArrayList
<>();
601 orderHints
.add(new OrderHint("titleCache", SortOrder
.ASCENDING
));
603 List
<Synonym
> synonyms
= taxonDao
.getSynonyms(taxon
, null, null, null,orderHints
,propertyPaths
);
605 assertNotNull("getSynonyms should return a List", synonyms
);
606 assertEquals("getSynonyms should return 3 synonyms", 3, synonyms
.size());
607 assertTrue("getSynonyms should return synonym objects with the synonym initialized", Hibernate
.isInitialized(synonyms
.get(0)));
612 public void testCountSynonymsByType() {
613 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontia
);
614 assert taxon
!= null : "taxon must exist";
616 long numberOfTaxonomicSynonyms
= taxonDao
.countSynonyms(taxon
, SynonymType
.HETEROTYPIC_SYNONYM_OF());
617 assertEquals("countSynonyms should return 4", 3, numberOfTaxonomicSynonyms
);
622 public void testSynonymsByType() {
623 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontia
);
624 assert taxon
!= null : "taxon must exist";
626 List
<Synonym
> synonyms
= taxonDao
.getSynonyms(taxon
, SynonymType
.HETEROTYPIC_SYNONYM_OF(), null, null,null,null);
628 assertNotNull("getSynonyms should return a List", synonyms
);
629 assertEquals("getSynonyms should return 4 Synonyms", 3, synonyms
.size());
634 public void testPageSynonyms(){
635 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontia
);
636 assert taxon
!= null : "taxon must exist";
639 List
<Synonym
> firstPage
= taxonDao
.getSynonyms(taxon
, null, pageSize
, 0,null,null);
640 List
<Synonym
> secondPage
= taxonDao
.getSynonyms(taxon
, null, pageSize
, 1,null,null);
642 assertNotNull("getSynonyms: 2, 0 should return a List",firstPage
);
643 assertEquals("getSynonyms: 2, 0 should return 2 synonyms", pageSize
,firstPage
.size());
644 assertNotNull("getSynonyms: 2, 1 should return a List",secondPage
);
645 assertEquals("getSynonyms: 2, 1 should return 1 synonym", 1, secondPage
.size());
650 public void testCountTaxonRelationships() {
651 long count
= taxonDao
.countTaxonRelationships(null);
652 assertEquals("There should be 11 relationships", 11, count
);
654 Set
<TaxonRelationshipType
> types
= new HashSet
<>();
655 count
= taxonDao
.countTaxonRelationships(types
);
656 assertEquals("Empty filter should return empty result", 0, count
);
658 types
.add(TaxonRelationshipType
.CONGRUENT_TO());
659 count
= taxonDao
.countTaxonRelationships(types
);
660 assertEquals("There should be no congruent relationship", 0, count
);
662 types
.add(TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN());
663 count
= taxonDao
.countTaxonRelationships(types
);
664 assertEquals("There should be 11 tax included relationships", 11, count
);
669 public void testlistTaxonRelationships() {
670 List
<TaxonRelationship
> rels
= taxonDao
.getTaxonRelationships(null, null, null, null, null);
671 assertEquals("There should be 11 relationships", 11, rels
.size());
673 rels
= taxonDao
.getTaxonRelationships(null, 2, 3, null, null);
674 assertEquals("There should be 11 relationships", 2, rels
.size());
676 Set
<TaxonRelationshipType
> types
= new HashSet
<>();
677 rels
= taxonDao
.getTaxonRelationships(types
, null, null, null, null);
678 assertEquals("Empty filter should return empty result", 0, rels
.size());
680 types
.add(TaxonRelationshipType
.CONGRUENT_TO());
681 rels
= taxonDao
.getTaxonRelationships(types
, null, null, null, null);
682 assertEquals("There should be no congruent relationship", 0, rels
.size());
684 types
.add(TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN());
685 rels
= taxonDao
.getTaxonRelationships(types
, null, null, null, null);
686 assertEquals("There should be 11 tax included relationships", 11, rels
.size());
690 @DataSet("TaxonNodeDaoHibernateImplTest.xml")
691 public void testListAcceptedTaxaFor() {
692 UUID acheontitia_ciprosus
= UUID
.fromString("3ef145f7-bd92-4a64-8afd-2b8203e00e02");
694 Synonym synonym
= (Synonym
)taxonDao
.findByUuid(acheontitia_ciprosus
);
695 assertNotNull("synonym must exist", synonym
);
697 Taxon taxon
= taxonDao
.acceptedTaxonFor(synonym
, null, null);
698 assertNotNull("listAcceptedTaxaFor should return a taxon", taxon
);
700 Classification classification
= classificationDao
.load(classificationUuid
);
701 assertNotNull("classification must exist", classification
);
703 taxon
= taxonDao
.acceptedTaxonFor(synonym
, classification
, null);
704 assertNull("listAcceptedTaxaFor should return not taxon due to classification filter", taxon
);
710 public void testGetTaxonMatchingUninomial() {
711 List
<TaxonBase
> result
= taxonDao
.findTaxaByName(Taxon
.class, "Smerinthus", "*", "*", "*","*",null,null,null);
713 assertNotNull("findTaxaByName should return a List", result
);
714 assertEquals("findTaxaByName should return two Taxa",2,result
.size());
715 assertEquals("findTaxaByName should return a Taxon with id 5",5,result
.get(0).getId());
720 public void testGetTaxonMatchingSpeciesBinomial() {
721 List
<TaxonBase
> result
= taxonDao
.findTaxaByName(Taxon
.class, "Smerinthus", null, "kindermannii", null,"*",null,null,null);
723 assertNotNull("findTaxaByName should return a List", result
);
724 assertEquals("findTaxaByName should return one Taxon",1,result
.size());
725 assertEquals("findTaxaByName should return a Taxon with id 8",8,result
.get(0).getId());
730 public void testGetTaxonMatchingTrinomial() {
731 List
<TaxonBase
> result
= taxonDao
.findTaxaByName(Taxon
.class,"Cryptocoryne", null,"purpurea","borneoensis","*",null,null,null);
733 assertNotNull("findTaxaByName should return a List", result
);
734 assertEquals("findTaxaByName should return one Taxon",1,result
.size());
735 assertEquals("findTaxaByName should return a Taxon with id 38",38,result
.get(0).getId());
740 public void testNegativeMatch() {
741 List
<TaxonBase
> result
= taxonDao
.findTaxaByName(Taxon
.class,"Acherontia", null,"atropos","dehli",null,null,null,null);
743 assertNotNull("findTaxaByName should return a List", result
);
744 assertTrue("findTaxaByName should return an empty List",result
.isEmpty());
749 public void testCountAllTaxa() {
750 int numberOfTaxa
= taxonDao
.count(Taxon
.class);
751 assertEquals("count should return 14 taxa", 14, numberOfTaxa
);
756 public void testListAllTaxa() {
757 List
<Taxon
> taxa
= taxonDao
.list(Taxon
.class,100, 0);
758 assertNotNull("list should return a List", taxa
);
759 assertEquals("list should return 14 taxa", 14, taxa
.size());
765 public void testDelete() {
766 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontia
);
767 assert taxon
!= null : "taxon must exist";
768 taxonDao
.delete(taxon
);
769 taxon
= (Taxon
)taxonDao
.findByUuid(acherontia
);
770 assert taxon
== null : "taxon must not exist";
774 // printDataSet(new FileOutputStream("test.xml"), TABLE_NAMES);
775 // } catch (FileNotFoundException e) {
776 // e.printStackTrace();
782 @ExpectedDataSet("TaxonDaoHibernateImplTest.testDelete-result.xml")
783 public void testDeleteWithMarker() {
784 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontia
);
785 taxon
.addMarker(Marker
.NewInstance(MarkerType
.IS_DOUBTFUL(), true));
786 taxonDao
.save(taxon
);
787 assert taxon
!= null : "taxon must exist";
789 taxonDao
.delete(taxon
);
790 commitAndStartNewTransaction(null);
791 taxon
= (Taxon
)taxonDao
.findByUuid(acherontia
);
792 assert taxon
== null : "taxon must not exist";
796 // printDataSet(new FileOutputStream("test.xml"), TABLE_NAMES);
797 // } catch (FileNotFoundException e) {
798 // e.printStackTrace();
803 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
804 public void testFindDeleted() {
805 TaxonBase
<?
> taxon
= taxonDao
.findByUuid(acherontia
);
806 assertNull("findByUuid should return null in this view", taxon
);
807 assertFalse("exist should return false in this view",taxonDao
.exists(acherontia
));
811 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
812 public void testFindDeletedInPreviousView() {
813 AuditEventContextHolder
.getContext().setAuditEvent(previousAuditEvent
);
814 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontia
);
815 assertNotNull("findByUuid should return a taxon in this view",taxon
);
816 assertTrue("exists should return true in this view", taxonDao
.exists(acherontia
));
819 assertEquals("There should be 3 relations to this taxon in this view",3,taxon
.getRelationsToThisTaxon().size());
820 } catch(Exception e
) {
821 fail("We should not experience any problems initializing proxies with envers");
826 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
827 public void testGetAuditEvents() {
828 TaxonBase
<?
> taxon
= taxonDao
.findByUuid(sphingidae
);
829 assert taxon
!= null : "taxon cannot be null";
831 List
<String
> propertyPaths
= new ArrayList
<>();
832 propertyPaths
.add("name");
833 propertyPaths
.add("createdBy");
834 propertyPaths
.add("updatedBy");
836 List
<AuditEventRecord
<TaxonBase
>> auditEvents
= taxonDao
.getAuditEvents(taxon
, null,null,null,propertyPaths
);
837 assertNotNull("getAuditEvents should return a list",auditEvents
);
838 assertFalse("the list should not be empty",auditEvents
.isEmpty());
839 assertEquals("There should be two AuditEventRecords in the list",2, auditEvents
.size());
843 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
844 public void testGetAuditEventsFromNow() {
845 AuditEventContextHolder
.getContext().setAuditEvent(previousAuditEvent
);
846 TaxonBase
<?
> taxon
= taxonDao
.findByUuid(sphingidae
);
847 assert taxon
!= null : "taxon cannot be null";
849 List
<AuditEventRecord
<TaxonBase
>> auditEvents
= taxonDao
.getAuditEvents(taxon
, null,null,AuditEventSort
.FORWARDS
,null);
850 assertNotNull("getAuditEvents should return a list",auditEvents
);
851 assertFalse("the list should not be empty",auditEvents
.isEmpty());
852 assertEquals("There should be one audit event in the list",1,auditEvents
.size());
856 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
857 public void testCountAuditEvents() {
858 TaxonBase
<?
> taxon
= taxonDao
.findByUuid(sphingidae
);
859 assert taxon
!= null : "taxon cannot be null";
861 int numberOfAuditEvents
= taxonDao
.countAuditEvents(taxon
, null);
862 assertEquals("countAuditEvents should return 2",numberOfAuditEvents
,2);
866 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
867 public void getPreviousAuditEvent() {
868 TaxonBase
<?
> taxon
= taxonDao
.findByUuid(sphingidae
);
869 assert taxon
!= null : "taxon cannot be null";
871 AuditEventRecord
<TaxonBase
> auditEvent
= taxonDao
.getPreviousAuditEvent(taxon
);
872 assertNotNull("getPreviousAuditEvent should not return null as there is at least one audit event prior to the current one",auditEvent
);
876 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
877 public void getPreviousAuditEventAtBeginning() {
878 AuditEventContextHolder
.getContext().setAuditEvent(previousAuditEvent
);
879 TaxonBase taxon
= taxonDao
.findByUuid(sphingidae
);
880 assert taxon
!= null : "taxon cannot be null";
882 AuditEventRecord
<TaxonBase
> auditEvent
= taxonDao
.getPreviousAuditEvent(taxon
);
883 assertNull("getPreviousAuditEvent should return null if we're at the first audit event anyway",auditEvent
);
887 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
888 public void getNextAuditEvent() {
889 AuditEventContextHolder
.getContext().setAuditEvent(previousAuditEvent
);
890 TaxonBase
<?
> taxon
= taxonDao
.findByUuid(sphingidae
);
891 assert taxon
!= null : "taxon cannot be null";
893 AuditEventRecord
<TaxonBase
> auditEvent
= taxonDao
.getNextAuditEvent(taxon
);
894 assertNotNull("getNextAuditEvent should not return null as there is at least one audit event after the current one",auditEvent
);
898 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
899 public void getNextAuditEventAtEnd() {
900 AuditEventContextHolder
.getContext().setAuditEvent(mostRecentAuditEvent
);
901 TaxonBase
<?
> taxon
= taxonDao
.findByUuid(sphingidae
);
902 assert taxon
!= null : "taxon cannot be null";
904 AuditEventRecord
<TaxonBase
> auditEvent
= taxonDao
.getNextAuditEvent(taxon
);
905 assertNull("getNextAuditEvent should return null as there no more audit events after the current one",auditEvent
);
909 @DataSet("TaxonDaoHibernateImplTest.testFind.xml")
910 public void testFind() {
911 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontiaLachesis
);
912 assert taxon
!= null : "taxon cannot be null";
914 assertEquals("getRelationsToThisTaxon should contain 1 TaxonRelationship in this view",1,taxon
.getRelationsToThisTaxon().size());
918 @DataSet("TaxonDaoHibernateImplTest.testFind.xml")
919 public void testFindInPreviousView() {
920 AuditEventContextHolder
.getContext().setAuditEvent(previousAuditEvent
);
921 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontiaLachesis
);
922 assert taxon
!= null : "taxon cannot be null";
924 assertTrue("getRelationsToThisTaxon should contain 0 TaxonRelationship in this view",taxon
.getRelationsToThisTaxon().isEmpty());
928 @DataSet("TaxonDaoHibernateImplTest.testFind.xml")
929 public void testGetRelations() {
930 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontiaLachesis
);
931 assert taxon
!= null : "taxon cannot be null";
933 List
<String
> propertyPaths
= new ArrayList
<>();
934 propertyPaths
.add("fromTaxon");
935 propertyPaths
.add("fromTaxon.name");
937 List
<OrderHint
> orderHints
= new ArrayList
<>();
938 orderHints
.add(new OrderHint("relatedFrom.titleCache", SortOrder
.ASCENDING
));
940 List
<TaxonRelationship
> taxonRelations
= taxonDao
.getTaxonRelationships(taxon
, TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN(), null, null,orderHints
,propertyPaths
, TaxonRelationship
.Direction
.relatedFrom
);
941 assertNotNull("getRelatedTaxa should return a list", taxonRelations
);
942 assertEquals("there should be one TaxonRelationship in the list in the current view",1,taxonRelations
.size());
943 assertTrue("TaxonRelationship.relatedFrom should be initialized",Hibernate
.isInitialized(taxonRelations
.get(0).getFromTaxon()));
944 assertTrue("TaxonRelationship.relatedFrom.name should be initialized",Hibernate
.isInitialized(taxonRelations
.get(0).getFromTaxon().getName()));
948 @DataSet("TaxonDaoHibernateImplTest.testFind.xml")
949 public void testCountRelations() {
950 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontiaLachesis
);
951 assert taxon
!= null : "taxon cannot be null";
952 assertEquals("countRelatedTaxa should return 1 in the current view",1, taxonDao
.countTaxonRelationships(taxon
,TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN(), TaxonRelationship
.Direction
.relatedTo
));
956 @DataSet("TaxonDaoHibernateImplTest.testFind.xml")
957 public void testGetRelationsInPreviousView() {
958 AuditEventContextHolder
.getContext().setAuditEvent(previousAuditEvent
);
959 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontiaLachesis
);
960 assert taxon
!= null : "taxon cannot be null";
962 List
<String
> propertyPaths
= new ArrayList
<String
>();
963 propertyPaths
.add("relatedFrom");
964 propertyPaths
.add("relatedFrom.name");
966 List
<OrderHint
> orderHints
= new ArrayList
<>();
967 orderHints
.add(new OrderHint("relatedFrom.titleCache", SortOrder
.ASCENDING
));
969 List
<TaxonRelationship
> taxonRelations
= taxonDao
.getTaxonRelationships(taxon
, TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN(), null, null,orderHints
,propertyPaths
, TaxonRelationship
.Direction
.relatedFrom
);
970 assertNotNull("getRelatedTaxa should return a list",taxonRelations
);
971 assertTrue("there should be no TaxonRelationships in the list in the prior view",taxonRelations
.isEmpty());
975 @DataSet("TaxonDaoHibernateImplTest.testFind.xml")
976 public void testCountRelationsInPreviousView() {
977 AuditEventContextHolder
.getContext().setAuditEvent(previousAuditEvent
);
978 Taxon taxon
= (Taxon
)taxonDao
.findByUuid(acherontiaLachesis
);
979 assert taxon
!= null : "taxon cannot be null";
980 assertEquals("countRelatedTaxa should return 0 in the current view",0, taxonDao
.countTaxonRelationships(taxon
,TaxonRelationshipType
.TAXONOMICALLY_INCLUDED_IN(), TaxonRelationship
.Direction
.relatedTo
));
985 public void testGroupTaxa() {
986 List
<Grouping
> groups
= new ArrayList
<>();
987 groups
.add(new GroupByCount("count",SortOrder
.DESCENDING
));
988 groups
.add(new Grouping("name.genusOrUninomial", "genus", "n", SortOrder
.ASCENDING
));
989 List
<Object
[]> results
= taxonDao
.group(null, null, null, groups
,null);
990 System
.out
.println("count\tname.genuOrUninomial");
991 for(Object
[] result
: results
) {
992 System
.out
.println(result
[0] + "\t" + result
[1]);
998 public void testGroupTaxaByClass() {
999 List
<Grouping
> groups
= new ArrayList
<>();
1000 groups
.add(new GroupByCount("count",SortOrder
.DESCENDING
));
1001 groups
.add(new Grouping("class", "class",null, SortOrder
.ASCENDING
));
1002 List
<Object
[]> results
= taxonDao
.group(null, null, null, groups
,null);
1003 System
.out
.println("count\tclass");
1004 for(Object
[] result
: results
) {
1005 System
.out
.println(result
[0] + "\t" + result
[1]);
1011 public void testNativeSQLOrder() {
1012 List
<OrderHint
> orderHints
= new ArrayList
<>();
1013 orderHints
.add(new NativeSqlOrderHint("case when {alias}.titleCache like 'C%' then 0 else 1 end",SortOrder
.ASCENDING
));
1015 List
<TaxonBase
> results
= taxonDao
.list(null, null, orderHints
);
1016 System
.out
.println("native SQL order");
1017 for(TaxonBase
<?
> result
: results
) {
1018 System
.out
.println(result
.getTitleCache());
1024 public void testGroupByDateTaxa() {
1025 List
<Grouping
> groups
= new ArrayList
<>();
1026 groups
.add(new GroupByCount("count",null));
1027 groups
.add(new GroupByDate("created", "dateGroup", SortOrder
.ASCENDING
, GroupByDate
.Resolution
.MONTH
));
1028 List
<Object
[]> results
= taxonDao
.group(null, null, null, groups
,null);
1029 System
.out
.println("count\tyear\tmonth");
1030 for(Object
[] result
: results
) {
1031 System
.out
.println(result
[0] + "\t" + result
[1] + "\t" + result
[2]);
1036 @DataSet ("TaxonDaoHibernateImplTest.testGetTaxaByNameAndArea.xml")
1037 public final void testGetTaxonNodeUuidAndTitleCacheOfAcceptedTaxaByClassification(){
1038 Classification classification
= classificationDao
.findByUuid(classificationUuid
);
1039 List
<UuidAndTitleCache
<TaxonNode
>> result
= taxonDao
.getTaxonNodeUuidAndTitleCacheOfAcceptedTaxaByClassification(classification
, null, null);
1040 assertNotNull(result
);
1041 assertEquals(5, result
.size());
1044 UUID excludeUUID
= UUID
.fromString("a9f42927-e507-4fda-9629-62073a908aae");
1045 List
<UUID
> excludeUUids
= new ArrayList
<>();
1046 excludeUUids
.add(excludeUUID
);
1047 result
= taxonDao
.getTaxonNodeUuidAndTitleCacheOfAcceptedTaxaByClassification(classification
, null, null);
1048 assertEquals(5, result
.size());
1052 result
= taxonDao
.getTaxonNodeUuidAndTitleCacheOfAcceptedTaxaByClassification(classification
, limit
, null);
1053 assertEquals(2, result
.size());
1056 String pattern
= "*Rothschi*";
1057 result
= taxonDao
.getTaxonNodeUuidAndTitleCacheOfAcceptedTaxaByClassification(classification
, 2, pattern
);
1058 assertNotNull(result
);
1059 assertEquals(1, result
.size());
1060 assertEquals("0b5846e5-b8d2-4ca9-ac51-099286ea4adc", result
.get(0).getUuid().toString());
1066 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
1067 //NOTE: There is a problem with loading AuditEvents if this test runs
1068 //stand alone or as first (one of the first) in the test suite. For some reason
1069 //the AuditEvent records from the @DataSet are not inserted into the database then,
1070 //while those inserted by the terms dataset are inserted as well as a completely new one.
1071 //This problem for some reason does not happen if not running at first place
1072 public void testGetAuditEventsByTypeWithRestrictions() {
1073 commitAndStartNewTransaction(new String
[]{"AUDITEVENT", "TAXONBASE_AUD"});
1075 List
<String
> propertyPaths
= new ArrayList
<String
>();
1076 propertyPaths
.add("name");
1077 propertyPaths
.add("createdBy");
1078 propertyPaths
.add("updatedBy");
1080 List
<AuditCriterion
> criteria
= new ArrayList
<>();
1081 criteria
.add(AuditEntity
.property("lsid_lsid").isNotNull());
1083 int count
= taxonDao
.countAuditEvents(TaxonBase
.class, null, null, null);
1085 List
<AuditEventRecord
<TaxonBase
>> auditEvents
= taxonDao
.getAuditEvents(TaxonBase
.class, previousAuditEvent
, mostRecentAuditEvent
, criteria
,null, null, AuditEventSort
.FORWARDS
, propertyPaths
);
1086 assertNotNull("getAuditEvents should return a list",auditEvents
);
1087 assertFalse("the list should not be empty",auditEvents
.isEmpty());
1088 assertEquals("There should be one AuditEventRecord in the list",1, auditEvents
.size());
1093 @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml")
1094 // @DataSets({ //for testing only
1095 // @DataSet("TaxonDaoHibernateImplTest.testFindDeleted.xml"),
1096 // @DataSet("TaxonDaoHibernateImplTest.testFindDeletedAuditEvents.xml")
1098 //NOTE: There is a problem with loading AuditEvents if this test runs
1099 //stand alone or as first (one of the first) in the test suite. For some reason
1100 //the AuditEvent records from the @DataSet are not inserted into the database then,
1101 //while those inserted by the terms dataset are inserted as well as a completely new one.
1102 //This problem for some reason does not happen if not running at first place
1103 public void testGetAuditEventsByTypeWithNoRestrictions() {
1104 printDataSet(System
.out
, new String
[]{"AUDITEVENT", "TAXONBASE_AUD"});
1105 commitAndStartNewTransaction(new String
[]{"AUDITEVENT", "TAXONBASE_AUD"});
1107 List
<String
> propertyPaths
= new ArrayList
<>();
1108 propertyPaths
.add("name");
1109 propertyPaths
.add("createdBy");
1110 propertyPaths
.add("updatedBy");
1111 int count
= taxonDao
.countAuditEvents(TaxonBase
.class, null, null, null);
1112 List
<AuditEventRecord
<TaxonBase
>> auditEvents
= taxonDao
.getAuditEvents(TaxonBase
.class, previousAuditEvent
, mostRecentAuditEvent
, null,null, null, AuditEventSort
.FORWARDS
, propertyPaths
);
1113 assertNotNull("getAuditEvents should return a list", auditEvents
);
1114 assertFalse("the list should not be empty", auditEvents
.isEmpty());
1115 assertEquals("There should be thirty eight AuditEventRecords in the list", 2, auditEvents
.size());
1120 @DataSet("TaxonDaoHibernateImplTest.testGetTaxaByNameAndArea.xml")
1121 public void testGetCommonName(){
1122 List
<Taxon
> commonNameResults
= taxonDao
.getTaxaByCommonName("common%", null,
1123 MatchMode
.BEGINNING
, null, null, null, null);
1125 assertNotNull("getTaxaByCommonName should return a list", commonNameResults
);
1126 assertFalse("the list should not be empty", commonNameResults
.isEmpty());
1127 assertEquals("There should be two taxa with common name", 2,commonNameResults
.size());
1129 List
<UuidAndTitleCache
<IdentifiableEntity
>> list
= taxonDao
.getTaxaByCommonNameForEditor("common%", null, MatchMode
.BEGINNING
, null);
1131 assertNotNull("getTaxaByCommonName should return a list", commonNameResults
);
1132 assertFalse("the list should not be empty", commonNameResults
.isEmpty());
1133 assertEquals("There should be two Taxon with common name", 2,commonNameResults
.size());
1139 public void testGetTitleCache(){
1140 UUID uuid
= UUID
.fromString("7b8b5cb3-37ba-4dba-91ac-4c6ffd6ac331");
1141 String titleCache
= taxonDao
.getTitleCache(uuid
, false);
1142 Assert
.assertEquals("Acherontia styx Westwood, 1847 sec. cate-sphingidae.org", titleCache
);
1143 titleCache
= taxonDao
.getTitleCache(uuid
, true);
1144 Assert
.assertEquals("Acherontia styxx Westwood, 1847 sec. cate-sphingidae.org", titleCache
);
1149 @DataSet("TaxonDaoHibernateImplTest.testPropertyPath.xml")
1150 public void testPropertyPath(){
1151 //Test that BeanInitializer also works on HiberanteProxys
1152 Classification c
= classificationDao
.load(UUID
.fromString("4bceea53-893f-4685-8c63-6dcec6e85ab1"));
1153 TaxonNode singleNode
= c
.getRootNode().getChildNodes().iterator().next();
1154 Taxon taxonProxy
= singleNode
.getTaxon();
1155 Assert
.assertTrue("Object to test should be a proxy ", taxonProxy
instanceof HibernateProxy
);
1157 List
<String
> propertyPaths
= new ArrayList
<>();
1158 propertyPaths
.add("taxonNodes");
1159 Taxon taxon
= (Taxon
)this.taxonDao
.load(
1160 UUID
.fromString("4a5bc930-844f-45ec-aea8-dd155e1ab25f"),
1162 Assert
.assertSame("Returned object should be the same proxy to assure that we ran initialization on this proxy", taxonProxy
, taxon
);
1170 public void createTestDataSet() throws FileNotFoundException
{
1171 // Classification classification = Classification.NewInstance("Test");
1172 // BotanicalName taxonNameBase = null;
1173 // Reference sec = null;
1174 // Taxon taxon = Taxon.NewInstance(taxonNameBase, sec);
1175 // classification.addChildTaxon(taxon, sec, null);
1177 // classificationDao.save(classification);
1178 // this.commitAndStartNewTransaction(null);
1180 // writeDbUnitDataSetFile(new String[] {
1181 // "CLASSIFICATION", "TAXONNAMEBASE",
1182 // "REFERENCE","TAXONNODE",
1183 // "TAXONBASE","LANGUAGESTRING",
1184 // "HIBERNATE_SEQUENCES" // IMPORTANT!!!
1186 // "testPropertyPath" );