Skip to content

Commit

Permalink
fix: improved model tests and tightened some scenarios
Browse files Browse the repository at this point in the history
  • Loading branch information
pieterlukasse committed Mar 6, 2024
1 parent a08162d commit 6b46606
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 14 deletions.
37 changes: 23 additions & 14 deletions tests/models_tests/models_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -281,8 +281,8 @@ func TestQueryFilterByCohortPairsHelper(t *testing.T) {
query = models.QueryFilterByCohortPairsHelper(filterCohortPairs, resultsDataSource, population.Id, "unionAndIntersect").
Select("subject_id")
_ = query.Scan(&subjectIds)
// in this case we expect overlap the size of the largestCohort-5:
if len(subjectIds) != (largestCohort.CohortSize - 5) {
// in this case we expect overlap the size of the largestCohort-6 (where 6 is the size of the overlap between extendedCopyOfSecondLargestCohort and largestCohort):
if len(subjectIds) != (largestCohort.CohortSize - 6) {
t.Errorf("Expected %d overlap, found %d", largestCohort.CohortSize-5, len(subjectIds))
}

Expand All @@ -304,7 +304,7 @@ func TestQueryFilterByCohortPairsHelper(t *testing.T) {
Select("subject_id")
_ = query.Scan(&subjectIds)
// in this case we expect same as previous test above:
if len(subjectIds) != (largestCohort.CohortSize - 5) {
if len(subjectIds) != (largestCohort.CohortSize - 6) {
t.Errorf("Expected %d overlap, found %d", largestCohort.CohortSize-5, len(subjectIds))
}

Expand Down Expand Up @@ -495,8 +495,10 @@ func TestRetrieveBreakdownStatsBySourceIdAndCohortIdAndConceptIdsAndCohortPairsW
if len(stats) > len(stats2) {
t.Errorf("First query is more restrictive, so its stats should not be larger than stats2 of second query. Got %d and %d", len(stats), len(stats2))
}
// test filtering with smallest cohort, lenght should be 1, since that's the size of the smallest cohort:
// setting the same cohort id here (artificial...normally it should be two different ids):

// test filtering with secondLargestCohort, smallest and largestCohort.
// Lenght of result set should be 2 persons (one HIS, one ASN), since there is a overlap of 1 between secondLargestCohort and smallest cohort,
// and overlap of 2 between secondLargestCohort and largestCohort, BUT only 1 has a HARE value:
filterCohortPairs = []utils.CustomDichotomousVariableDef{
{
CohortDefinitionId1: smallestCohort.Id,
Expand All @@ -506,7 +508,14 @@ func TestRetrieveBreakdownStatsBySourceIdAndCohortIdAndConceptIdsAndCohortPairsW
stats3, _ := conceptModel.RetrieveBreakdownStatsBySourceIdAndCohortIdAndConceptIdsAndCohortPairs(testSourceId,
secondLargestCohort.Id, filterIds, filterCohortPairs, breakdownConceptId)
if len(stats3) != 2 {
t.Errorf("Expected only two items in resultset, found %d", len(stats))
t.Errorf("Expected only two items in resultset, found %d", len(stats3))
}
countPersons := 0
for _, stat := range stats3 {
countPersons = countPersons + stat.NpersonsInCohortWithValue
}
if countPersons != 2 {
t.Errorf("Expected only two persons in resultset, found %d", countPersons)
}
}

Expand Down Expand Up @@ -731,9 +740,9 @@ func TestRetrieveHistogramDataBySourceIdAndCohortIdAndConceptIdsAndCohortPairs(t
filterConceptIds := []int64{}
filterCohortPairs := []utils.CustomDichotomousVariableDef{}
data, _ := cohortDataModel.RetrieveHistogramDataBySourceIdAndCohortIdAndConceptIdsAndCohortPairs(testSourceId, largestCohort.Id, histogramConceptId, filterConceptIds, filterCohortPairs)
// everyone in the largestCohort has the histogramConceptId:
if len(data) != largestCohort.CohortSize {
t.Errorf("expected 10 or more histogram data but got %d", len(data))
// everyone in the largestCohort has the histogramConceptId, but one person has NULL in the value_as_number:
if len(data) != largestCohort.CohortSize-1 {
t.Errorf("expected %d histogram data but got %d", largestCohort.CohortSize, len(data))
}

// now filter on the extendedCopyOfSecondLargestCohort
Expand Down Expand Up @@ -873,11 +882,11 @@ func TestRetrieveCohortOverlapStats(t *testing.T) {
CohortDefinitionId2: extendedCopyOfSecondLargestCohort.Id,
ProvidedName: "test"},
}
// then we expect overlap of 5 for extendedCopyOfSecondLargestCohort and largestCohort:
// then we expect overlap of 6 for extendedCopyOfSecondLargestCohort and largestCohort:
stats, _ = cohortDataModel.RetrieveCohortOverlapStats(testSourceId, caseCohortId, controlCohortId,
otherFilterConceptIds, filterCohortPairs)
if stats.CaseControlOverlap != 5 {
t.Errorf("Expected nr persons to be %d, found %d", 5, stats.CaseControlOverlap)
if stats.CaseControlOverlap != 6 {
t.Errorf("Expected nr persons to be %d, found %d", 6, stats.CaseControlOverlap)
}

// extra test: different parameters that should return the same as above ^:
Expand All @@ -886,10 +895,10 @@ func TestRetrieveCohortOverlapStats(t *testing.T) {
filterCohortPairs = []utils.CustomDichotomousVariableDef{}
otherFilterConceptIds = []int64{histogramConceptId} // extra filter, to cover this part of the code...
// then we expect overlap of 5 for extendedCopyOfSecondLargestCohort and largestCohort (the filter on histogramConceptId should not matter
// since all in largestCohort have an observation for this concept id):
// since all in largestCohort have an observation for this concept id except one person who has it but has value_as_number as NULL):
stats2, _ := cohortDataModel.RetrieveCohortOverlapStats(testSourceId, caseCohortId, controlCohortId,
otherFilterConceptIds, filterCohortPairs)
if stats2.CaseControlOverlap != stats.CaseControlOverlap {
if stats2.CaseControlOverlap != stats.CaseControlOverlap-1 {
t.Errorf("Expected nr persons to be %d, found %d", stats.CaseControlOverlap, stats2.CaseControlOverlap)
}

Expand Down
2 changes: 2 additions & 0 deletions tests/setup_local_db/test_data_results_and_cdm.sql
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ values
(nextval('observation_id_seq'), 3,0,'1993-10-24','1993-10-24 00:00:00',38000276,NULL,'M',0,0,0,NULL,81,0,'713197008',0,NULL,NULL,NULL,0,NULL),
(nextval('observation_id_seq'), 3,0,'1967-12-02','1967-12-02 00:00:00',38000276,NULL,NULL,0,0,0,NULL,114,0,'53741008',0,NULL,NULL,NULL,0,NULL),
(nextval('observation_id_seq'), 4,0,'2012-06-06','2012-06-06 00:00:00',38000276,NULL,NULL,0,0,0,NULL,170,0,'403191005',0,NULL,NULL,NULL,0,NULL),
-- person 5 has null in value_as_number here:
(nextval('observation_id_seq'), 5,2000006885,'1993-11-17','1993-11-17 00:00:00',38000276,NULL,NULL,0,0,0,NULL,179,0,'162864005',0,NULL,NULL,NULL,0,NULL),
(nextval('observation_id_seq'), 5,0,'2014-01-31','2014-01-31 00:00:00',38000276,NULL,NULL,0,0,0,NULL,197,0,'278860009',0,NULL,NULL,NULL,0,NULL),
(nextval('observation_id_seq'), 6,2000006885,'2014-01-31','2014-01-31 00:00:00',38000276,5.41,NULL,0,0,0,NULL,197,0,'278860009',0,NULL,NULL,NULL,0,NULL),
Expand Down Expand Up @@ -156,6 +157,7 @@ values
(32,9),
(32,10),
-- extra large cohort for testing histogram: (aka "largestCohort" in models_test.go script)
(4,5),
(4,6),
(4,7),
(4,8),
Expand Down

0 comments on commit 6b46606

Please sign in to comment.