diff --git a/src/main/resources/org/cbioportal/persistence/mybatisclickhouse/StudyViewFilterMapper.xml b/src/main/resources/org/cbioportal/persistence/mybatisclickhouse/StudyViewFilterMapper.xml index bafd4f511ef..1c527c87a68 100644 --- a/src/main/resources/org/cbioportal/persistence/mybatisclickhouse/StudyViewFilterMapper.xml +++ b/src/main/resources/org/cbioportal/persistence/mybatisclickhouse/StudyViewFilterMapper.xml @@ -244,18 +244,39 @@ - - AND match(attribute_value, '^[\d\.]+$') + + AND match(attribute_value, '^>?=?[-+]?[0-9]*[.,]?[0-9]+$') + + + AND match(attribute_value, '^<?=?[-+]?[0-9]*[.,]?[0-9]+$') + + + AND match(attribute_value, '^[-+]?[0-9]*[.,]?[0-9]+$') + + - AND abs(minus(cast(attribute_value as float), ${dataFilterValue.start})) < exp(-11) + AND abs( + minus( + + + , + ${dataFilterValue.start} + ) + ) < exp(-11) - AND cast(attribute_value as float) > ${dataFilterValue.start} + AND + + + > ${dataFilterValue.start} - AND cast(attribute_value as float) <= ${dataFilterValue.end} + AND + + + <= ${dataFilterValue.end} diff --git a/src/main/resources/org/cbioportal/persistence/mybatisclickhouse/StudyViewMapper.xml b/src/main/resources/org/cbioportal/persistence/mybatisclickhouse/StudyViewMapper.xml index 36008ede532..f1017801f91 100644 --- a/src/main/resources/org/cbioportal/persistence/mybatisclickhouse/StudyViewMapper.xml +++ b/src/main/resources/org/cbioportal/persistence/mybatisclickhouse/StudyViewMapper.xml @@ -620,6 +620,29 @@ + + + multiIf( + (startsWith(${attribute_value}, '<=') OR startsWith(${attribute_value}, '>=')), + cast(substr(${attribute_value}, 3) as float), + startsWith(${attribute_value}, '<'), + cast(substr(${attribute_value}, 2) as float) - exp(-10), + startsWith(${attribute_value}, '>'), + cast(substr(${attribute_value}, 2) as float) + exp(-10), + cast(${attribute_value} as float) + ) + + ${attribute_value}='' diff --git a/src/test/java/org/cbioportal/persistence/mybatisclickhouse/StudyViewMapperClinicalDataCountTest.java b/src/test/java/org/cbioportal/persistence/mybatisclickhouse/StudyViewMapperClinicalDataCountTest.java index 17847278f9c..7c6ec1431bb 100644 --- a/src/test/java/org/cbioportal/persistence/mybatisclickhouse/StudyViewMapperClinicalDataCountTest.java +++ b/src/test/java/org/cbioportal/persistence/mybatisclickhouse/StudyViewMapperClinicalDataCountTest.java @@ -187,12 +187,12 @@ public void getMutationCountsFilteredByAge() { } @Test - public void getMutationCountsFilteredByAgeWithSpecialValues() { + public void getMutationCountsFilteredByAgeWithOpenStartValues() { StudyViewFilter studyViewFilter = new StudyViewFilter(); studyViewFilter.setStudyIds(List.of(STUDY_GENIE_PUB)); // filter patients with age less than 20 - // (there are 4 patients within this range, which are 301,302,303, and 306) + // (there are 4 patients within this range, which are 301, 302, 303, and 306) ClinicalDataFilter filter = buildClinicalDataFilter("age", null, 20); studyViewFilter.setClinicalDataFilters(List.of(filter)); @@ -207,17 +207,44 @@ public void getMutationCountsFilteredByAgeWithSpecialValues() { Collections.emptyList() ); - // TODO commented out tests below are failing due to a known issue - // (https://github.com/cBioPortal/rfc80-team/issues/32) - // assertEquals(4, mutationCountsFiltered.size()); - // assertEquals(1, findClinicaDataCount(mutationCountsFiltered, "11")); // patient 301 - // assertEquals(1, findClinicaDataCount(mutationCountsFiltered, "6")); // patient 302 - // assertEquals(1, findClinicaDataCount(mutationCountsFiltered, "4")); // patient 303 + assertEquals(4, mutationCountsFiltered.size()); + assertEquals(1, findClinicaDataCount(mutationCountsFiltered, "11")); // patient 301 + assertEquals(1, findClinicaDataCount(mutationCountsFiltered, "6")); // patient 302 + assertEquals(1, findClinicaDataCount(mutationCountsFiltered, "4")); // patient 303 assertEquals(1, findClinicaDataCount(mutationCountsFiltered, "2")); // patient 306 // no patients/samples with NA assertEquals(0, findClinicaDataCount(mutationCountsFiltered, "NA")); } + + @Test + public void getMutationCountsFilteredByAgeWithOpenEndValues() { + StudyViewFilter studyViewFilter = new StudyViewFilter(); + studyViewFilter.setStudyIds(List.of(STUDY_GENIE_PUB)); + + // filter patients with age greater than 80 + // (there are 4 patients within this range, which are 317, 318, 319, 304, and 305) + ClinicalDataFilter filter = buildClinicalDataFilter("age", 80, null); + studyViewFilter.setClinicalDataFilters(List.of(filter)); + + var mutationCountsFiltered = studyViewMapper.getClinicalDataCounts( + studyViewFilter, + CategorizedClinicalDataCountFilter + .getBuilder() + .setPatientNumericalClinicalDataFilters(List.of(filter)) + .build(), + true, + List.of("mutation_count"), + Collections.emptyList() + ); + + assertEquals(3, mutationCountsFiltered.size()); + assertEquals(1, findClinicaDataCount(mutationCountsFiltered, "4")); // patient 304 + assertEquals(1, findClinicaDataCount(mutationCountsFiltered, "2")); // patient 305 + + // patients/samples with NA data: 317, 318, and 319 + assertEquals(3, findClinicaDataCount(mutationCountsFiltered, "NA")); + } private ClinicalDataFilter buildClinicalDataFilter(String attributeId, Integer start, Integer end) { DataFilterValue value = new DataFilterValue();