Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

TASK-5610 - Create the CVDB endpoint analysis/clinical/cvdb/variant/summary and overwrite analysis/clinical/variant #2480

Open
wants to merge 33 commits into
base: release-3.x.x
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
c61a302
test: update test classes to be used by OpenCGA Enterprise tests, #TA…
jtarraga Feb 26, 2024
38d57aa
Merge branch 'develop' into TASK-5610
imedina Apr 11, 2024
39365be
Merge branch 'develop' into TASK-5610
jtarraga Apr 16, 2024
eca4214
Merge branch 'develop' into TASK-5610
jtarraga Jun 19, 2024
bfeb502
Merge branch 'develop' into TASK-5610
jtarraga Jul 1, 2024
67fc138
Merge branch 'TASK-5610' of https://github.com/opencb/opencga into TA…
jtarraga Jul 1, 2024
8a841f5
Merge branch 'develop' into TASK-5610
jtarraga Jul 2, 2024
d2e7b2e
Merge branch 'release-3.2.x' into TASK-5610
jtarraga Jul 22, 2024
e151da5
Preventive deleted long test
juanfeSanahuja Aug 14, 2024
0fa6e11
k8s: deleted nodeSelector kubernetes.io/role removed on k8s 1.29 #TAS…
juanrizetta Sep 5, 2024
ee9802f
pom: Update the cellbase dependency #TASK-6835
juanfeSanahuja Sep 6, 2024
6b8bf32
Merge pull request #2502 from opencb/TASK-6835
juanfeSanahuja Sep 6, 2024
a89b04f
Merge branch 'develop' into TASK-6458
juanrizetta Sep 6, 2024
4050b02
CICD: new SDLC Updating version number #TASK-6879
juanfeSanahuja Sep 18, 2024
a30b6f3
CICD: new SDLC Updating branches and version references #TASK-6879
juanfeSanahuja Sep 18, 2024
1f818cb
Merge pull request #2506 from opencb/TASK-6879-dev
juanfeSanahuja Sep 19, 2024
a94f7be
Merge branch 'release-3.x.x' into TASK-5610
jtarraga Sep 23, 2024
e6160e0
Merge branch 'release-3.2.x' into TASK-5610d
jtarraga Oct 2, 2024
bd04112
Merge branch 'develop' into TASK-6458
juanrizetta Oct 3, 2024
3b7a8df
Merge pull request #2501 from opencb/TASK-6458
juanrizetta Oct 3, 2024
6d19797
Port Patch 3.2.1 -> 4.0.0 XB 2.2.1 -> 3.0.0 #TASK-6780
juanfeSanahuja Oct 3, 2024
53eac91
Merge branch 'develop' into TASK-6780
juanfeSanahuja Oct 3, 2024
d1ba697
test: fix FamilyAnalysisTest JUnit tests, #TASK-6780
jtarraga Oct 8, 2024
1c9f023
Merge branch 'TASK-6780' of https://github.com/opencb/opencga into TA…
jtarraga Oct 8, 2024
d8116e9
Merge pull request #2513 from opencb/TASK-6780
juanfeSanahuja Oct 14, 2024
c53a2e7
Prepare Port Patch 3.3.0 -> 4.0.0 Xetabase 2.3.0 -> 3.0.0 #TASK-7097
juanfeSanahuja Oct 17, 2024
af4146d
Merge branch 'develop' into TASK-7097
juanfeSanahuja Oct 17, 2024
6ee003d
Merge pull request #2519 from opencb/TASK-7097
juanfeSanahuja Oct 21, 2024
3253853
core: add new CVDB index status in Clinical Analysis, #TASK-5610
pfurio Nov 18, 2024
c311286
Merge branch 'develop' into TASK-5610
jtarraga Nov 25, 2024
e390128
Merge branch 'TASK-5610' of https://github.com/opencb/opencga into TA…
jtarraga Nov 25, 2024
5cd5075
catalog: fix clinical analysis manager when updating clinical analysi…
jtarraga Nov 25, 2024
952687c
build: Fix method name for new endppoint and regenerated cli #TASK-5610
juanfeSanahuja Dec 9, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion opencga-analysis/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
<parent>
<groupId>org.opencb.opencga</groupId>
<artifactId>opencga</artifactId>
<version>3.3.0</version>
<version>4.0.0-SNAPSHOT</version>
<relativePath>../pom.xml</relativePath>
</parent>

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -109,10 +109,9 @@ public void tearDown() throws Exception {
}

@Test
public void creationTest() {
public void creationTest() throws IOException {
PedigreeGraph pedigreeGraph = family.getPedigreeGraph();
assertTrue(pedigreeGraph.getBase64().startsWith("iVBORw0KGgoAAAANSUhEUgAAAeA"));
assertTrue(pedigreeGraph.getBase64().endsWith("AIDB6Bwfs3Rj5UIf81hI8AAAAASUVORK5CYII="));
assertEquals(runAndGetPedigreeImageB64(family), pedigreeGraph.getBase64());
}

@Test
Expand All @@ -130,7 +129,7 @@ public void twoMemberFamilyTest() throws CatalogException {
}

@Test
public void threeMemberNoDisorderFamilyTest() throws CatalogException {
public void threeMemberNoDisorderFamilyTest() throws CatalogException, IOException {
FamilyUpdateParams updateParams = new FamilyUpdateParams();

QueryOptions queryOptions = new QueryOptions()
Expand All @@ -140,33 +139,30 @@ public void threeMemberNoDisorderFamilyTest() throws CatalogException {
.first();

PedigreeGraph pedigreeGraph = updatedFamily.getPedigreeGraph();
assertTrue(pedigreeGraph.getBase64().startsWith("iVBORw0KGgoAAAANSUhEUgAAAeAAAAH"));
assertTrue(pedigreeGraph.getBase64().endsWith("2WENFPAsd1MAAAAASUVORK5CYII="));
assertEquals(runAndGetPedigreeImageB64(updatedFamily), pedigreeGraph.getBase64());
}

@Test
public void threeGenerationFamilyTest() throws CatalogException {
public void threeGenerationFamilyTest() throws CatalogException, IOException {
Family threeGenFamily = createThreeGenerationFamily("Cos-Cos", true).first();
PedigreeGraph pedigreeGraph = threeGenFamily.getPedigreeGraph();
assertTrue(pedigreeGraph.getBase64().startsWith("iVBORw0KGgoAAAANSUhEUgAAAeAAAAHgCA"));
assertTrue(pedigreeGraph.getBase64().endsWith("h9S2DROnwXOvwAAAABJRU5ErkJggg=="));
assertEquals(runAndGetPedigreeImageB64(threeGenFamily), pedigreeGraph.getBase64());
}

@Test
public void threeGenerationFamilyWithoutDisorderTest() throws CatalogException {
public void threeGenerationFamilyWithoutDisorderTest() throws CatalogException, IOException {
Family threeGenFamily = createThreeGenerationFamily("Hello-Hello", false).first();
PedigreeGraph pedigreeGraph = threeGenFamily.getPedigreeGraph();
assertTrue(pedigreeGraph.getBase64().startsWith("iVBORw0KGgoAAAANSUhEUgAAAeAAAAHgC"));
assertTrue(pedigreeGraph.getBase64().endsWith("wNJj9EVvh8HVQAAAABJRU5ErkJggg=="));
assertEquals(runAndGetPedigreeImageB64(threeGenFamily), pedigreeGraph.getBase64());
}

@Test
public void test2Member2GenerationFamilyTest() throws CatalogException {
public void test2Member2GenerationFamilyTest() throws CatalogException, IOException {
Family family = create2Member2GenerationDummyFamily("Colo-Colo", "father222-sample", "child2222-sample").first();

PedigreeGraph pedigreeGraph = family.getPedigreeGraph();
assertTrue(pedigreeGraph.getBase64().startsWith("iVBORw0KGgoAAAANSUhEUgAAA"));
assertTrue(pedigreeGraph.getBase64().endsWith("qkAAAAASUVORK5CYII="));

assertEquals(runAndGetPedigreeImageB64(family), pedigreeGraph.getBase64());
}

@Test
Expand Down Expand Up @@ -205,9 +201,6 @@ public void testPedigreeGraphAnalysis() throws ToolException, IOException {
false, sessionIdUser);

String b64Image = PedigreeGraphUtils.getB64Image(outDir);
MatcherAssert.assertThat(b64Image, CoreMatchers.startsWith("iVBORw0KGgoAAAANSUhEUgAAAeAAAAHg"));
MatcherAssert.assertThat(b64Image, CoreMatchers.endsWith("s3Rj5UIf81hI8AAAAASUVORK5CYII="));

assertEquals(family.getPedigreeGraph().getBase64(), b64Image);
}

Expand Down Expand Up @@ -477,4 +470,12 @@ private static DataResult<Family> create2Member2GenerationDummyFamily(String fam

return familyOpenCGAResult;
}


public String runAndGetPedigreeImageB64(Family family) throws IOException {
Path scratchDir = Paths.get(opencga.createTmpOutdir());
PedigreeGraph pedigreeGraph = PedigreeGraphUtils.getPedigreeGraph(family, opencga.getOpencgaHome(), scratchDir);
return pedigreeGraph.getBase64();

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@
*/
public class OpenCGATestExternalResource extends ExternalResource {

private final CatalogManagerExternalResource catalogManagerExternalResource = new CatalogManagerExternalResource();
private final CatalogManagerExternalResource catalogManagerExternalResource;
private Path opencgaHome;
private String storageEngine;
private boolean initiated = false;
Expand All @@ -72,21 +72,27 @@ public class OpenCGATestExternalResource extends ExternalResource {
private StorageConfiguration storageConfiguration;
private StorageEngineFactory storageEngineFactory;
private ToolRunner toolRunner;

protected Path sourceAnalysisPath;

public static HadoopVariantStorageTest.HadoopExternalResource hadoopExternalResource
= new HadoopVariantStorageTest.HadoopExternalResource();

public OpenCGATestExternalResource() {
this(false);
this(false, Paths.get("../opencga-app/app/analysis/"));
}

public OpenCGATestExternalResource(boolean storageHadoop) {
this(storageHadoop, Paths.get("../opencga-app/app/analysis/"));
}

public OpenCGATestExternalResource(boolean storageHadoop, Path sourceAnalysisPath) {
if (storageHadoop) {
this.storageEngine = HadoopVariantStorageEngine.STORAGE_ENGINE_ID;
} else {
this.storageEngine = DummyVariantStorageEngine.STORAGE_ENGINE_ID;
}
this.sourceAnalysisPath = sourceAnalysisPath;
catalogManagerExternalResource = new CatalogManagerExternalResource(sourceAnalysisPath);
}

@Override
Expand Down
4 changes: 4 additions & 0 deletions opencga-app/app/misc/clients/rest_client_generator.py
Original file line number Diff line number Diff line change
Expand Up @@ -219,6 +219,7 @@ def get_method_name(self, endpoint, category):
method_name = '_'.join([items[2], items[0]])
elif len(items) == 4:
# e.g. /{apiVersion}/operation/variant/sample/genotype/index
#analysis/clinical/cvdb/variant/{variantIds}/stats
if not self.any_arg(items):
method_name = '_'.join([items[0], items[1], items[2], items[3]])
# /{apiVersion}/analysis/clinical/{clinicalAnalysis}/interpretation/{interpretationId}/merge
Expand All @@ -227,6 +228,9 @@ def get_method_name(self, endpoint, category):
# /{apiVersion}/admin/users/{user}/groups/update
elif self.all_arg([items[1]]) and not self.any_arg([items[0], items[2], items[3]]):
method_name = '_'.join([items[0], items[3], items[2]])
# /{apiVersion}/analysis/clinical/cvdb/variant/{variantIds}/stats
elif self.all_arg([items[2]]) and not self.any_arg([items[0], items[1], items[3]]):
method_name = '_'.join([items[0], items[1], items[3]])
elif len(items) == 5:
# e.g. /{apiVersion}/files/{file}/annotationSets/{annotationSet}/annotations/update
if self.all_arg([items[0], items[2]]) and not self.any_arg([items[1], items[3], items[4]]):
Expand Down
2 changes: 1 addition & 1 deletion opencga-app/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
<parent>
<groupId>org.opencb.opencga</groupId>
<artifactId>opencga</artifactId>
<version>3.3.0</version>
<version>4.0.0-SNAPSHOT</version>
<relativePath>../pom.xml</relativePath>
</parent>

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
package org.opencb.opencga.app.migrations.v4.v4_0_0.catalog;

import com.mongodb.client.model.Filters;
import com.mongodb.client.model.Updates;
import org.bson.Document;
import org.bson.conversions.Bson;
import org.opencb.opencga.catalog.db.api.ClinicalAnalysisDBAdaptor;
import org.opencb.opencga.catalog.db.mongodb.OrganizationMongoDBAdaptorFactory;
import org.opencb.opencga.catalog.migration.Migration;
import org.opencb.opencga.catalog.migration.MigrationTool;
import org.opencb.opencga.core.models.clinical.ClinicalStatusValue;
import org.opencb.opencga.core.models.clinical.CvdbIndexStatus;

import java.util.Arrays;

@Migration(id = "add_cvdb_index_to_clinical_analysis",
description = "Add CVDB index status to Clinical Analysis #TASK-5610", version = "4.0.0",
language = Migration.MigrationLanguage.JAVA, domain = Migration.MigrationDomain.CATALOG, date = 20241118)
public class ClinicalCvdbIndexMigration extends MigrationTool {

@Override
protected void run() throws Exception {
Bson closedCaseQuery = Filters.and(
Filters.exists(ClinicalAnalysisDBAdaptor.QueryParams.INTERNAL_CVDB_INDEX.key(), false),
Filters.eq("status.type", ClinicalStatusValue.ClinicalStatusType.CLOSED)
);
Bson openCaseQuery = Filters.and(
Filters.exists(ClinicalAnalysisDBAdaptor.QueryParams.INTERNAL_CVDB_INDEX.key(), false),
Filters.ne("status.type", ClinicalStatusValue.ClinicalStatusType.CLOSED)
);
CvdbIndexStatus pendingCvdbIndexStatus = new CvdbIndexStatus(CvdbIndexStatus.PENDING);
Document pendingCvdbIndexDoc = convertToDocument(pendingCvdbIndexStatus);
Bson updateClosedCase = Updates.set(ClinicalAnalysisDBAdaptor.QueryParams.INTERNAL_CVDB_INDEX.key(), pendingCvdbIndexDoc);

CvdbIndexStatus noneCvdbIndexStatus = new CvdbIndexStatus(CvdbIndexStatus.NONE);
Document noneCvdbIndexDoc = convertToDocument(noneCvdbIndexStatus);
Bson updateOpenCase = Updates.set(ClinicalAnalysisDBAdaptor.QueryParams.INTERNAL_CVDB_INDEX.key(), noneCvdbIndexDoc);

for (String collection : Arrays.asList(OrganizationMongoDBAdaptorFactory.CLINICAL_ANALYSIS_COLLECTION,
OrganizationMongoDBAdaptorFactory.CLINICAL_ANALYSIS_ARCHIVE_COLLECTION,
OrganizationMongoDBAdaptorFactory.DELETED_CLINICAL_ANALYSIS_COLLECTION)) {
getMongoCollection(collection).updateMany(closedCaseQuery, updateClosedCase);
getMongoCollection(collection).updateMany(openCaseQuery, updateOpenCase);
}
}

}
2 changes: 1 addition & 1 deletion opencga-catalog/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
<parent>
<groupId>org.opencb.opencga</groupId>
<artifactId>opencga</artifactId>
<version>3.3.0</version>
<version>4.0.0-SNAPSHOT</version>
<relativePath>../pom.xml</relativePath>
</parent>

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,7 @@ enum QueryParams implements QueryParam {
INTERNAL_STATUS("internal.status", TEXT_ARRAY, ""),
INTERNAL_STATUS_ID("internal.status.id", TEXT, ""),
INTERNAL_STATUS_DATE("internal.status.date", TEXT, ""),
INTERNAL_CVDB_INDEX("internal.cvdbIndex", OBJECT, ""),
QUALITY_CONTROL("qualityControl", OBJECT, ""),
QUALITY_CONTROL_SUMMARY("qualityControl.summary", TEXT, ""),
CONSENT("consent", OBJECT, ""),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,10 @@
import org.opencb.opencga.core.common.JacksonUtils;
import org.opencb.opencga.core.common.TimeUtils;
import org.opencb.opencga.core.config.Configuration;
import org.opencb.opencga.core.models.clinical.*;
import org.opencb.opencga.core.models.clinical.ClinicalAnalysis;
import org.opencb.opencga.core.models.clinical.ClinicalAnalysisPermissions;
import org.opencb.opencga.core.models.clinical.FlagValueParam;
import org.opencb.opencga.core.models.clinical.Interpretation;
import org.opencb.opencga.core.models.common.AnnotationSet;
import org.opencb.opencga.core.models.common.Enums;
import org.opencb.opencga.core.models.common.FlagAnnotation;
Expand Down Expand Up @@ -451,7 +454,7 @@ UpdateDocument parseAndValidateUpdateParams(ObjectMap parameters, List<ClinicalA
String[] acceptedObjectParams = {QueryParams.FAMILY.key(), QueryParams.DISORDER.key(), QUALITY_CONTROL.key(),
QueryParams.PROBAND.key(), QueryParams.ALERTS.key(), QueryParams.INTERNAL_STATUS.key(), QueryParams.PRIORITY.key(),
QueryParams.CONSENT.key(), QueryParams.STATUS.key(), QueryParams.INTERPRETATION.key(), REPORT.key(),
REQUEST.key(), RESPONSIBLE.key(), ATTRIBUTES.key(), };
INTERNAL_CVDB_INDEX.key(), REQUEST.key(), RESPONSIBLE.key(), ATTRIBUTES.key(), };
filterObjectParams(parameters, document.getSet(), acceptedObjectParams);

if (parameters.containsKey(INTERPRETATION.key()) && parameters.get(INTERPRETATION.key()) == null) {
Expand Down
Loading