From 9fa10c702530eca4282838efa850ec7ca698f62a Mon Sep 17 00:00:00 2001 From: Philip Durbin Date: Tue, 29 Oct 2024 16:03:42 -0400 Subject: [PATCH] improve tests, start testing codeMeta20 --- doc/release-notes/10519-dataset-types.md | 10 +- .../iq/dataverse/api/DatasetTypesIT.java | 104 ++++++++++++++++-- 2 files changed, 101 insertions(+), 13 deletions(-) diff --git a/doc/release-notes/10519-dataset-types.md b/doc/release-notes/10519-dataset-types.md index 6cd039725f9..38c0a99b265 100644 --- a/doc/release-notes/10519-dataset-types.md +++ b/doc/release-notes/10519-dataset-types.md @@ -1,10 +1,14 @@ ## Metadata Blocks Can Be Associated with Dataset Types -Metadata blocks (e.g. "codemeta") can now be associated with dataset types (e.g. "software") using new superuser APIs. +Metadata blocks (e.g. "geospatial") can now be associated with dataset types (e.g. "software") using new superuser APIs. This will have the following effects for the APIs used by the new Dataverse UI: -- The list of fields shown when creating a dataset will include fields marked as "displayoncreate" (in the tsv/database) for metadata blocks (e.g. "codemeta") that are associated with the dataset type (e.g. "software") that is passed to the API. -- The metadata blocks shown when editing a dataset will include metadata blocks (e.g. "codemeta") that are associated with the dataset type (e.g. "software") that is passed to the API. +- The list of fields shown when creating a dataset will include fields marked as "displayoncreate" (in the tsv/database) for metadata blocks (e.g. "geospatial") that are associated with the dataset type (e.g. "software") that is passed to the API. +- The metadata blocks shown when editing a dataset will include metadata blocks (e.g. "geospatial") that are associated with the dataset type (e.g. "software") that is passed to the API. + +The Computational Workflow block is still considered experimental, but to test with it, you can load it like this: + +curl "http://localhost:8080/api/admin/datasetfield/load" -H "Content-type: text/tab-separated-values" -X POST --upload-file scripts/api/data/metadatablocks/codemeta.tsv For more information, see the guides and #10519. diff --git a/src/test/java/edu/harvard/iq/dataverse/api/DatasetTypesIT.java b/src/test/java/edu/harvard/iq/dataverse/api/DatasetTypesIT.java index 923d8d004ba..27f351a24c7 100644 --- a/src/test/java/edu/harvard/iq/dataverse/api/DatasetTypesIT.java +++ b/src/test/java/edu/harvard/iq/dataverse/api/DatasetTypesIT.java @@ -8,22 +8,15 @@ import static jakarta.ws.rs.core.Response.Status.BAD_REQUEST; import static jakarta.ws.rs.core.Response.Status.CREATED; import static jakarta.ws.rs.core.Response.Status.FORBIDDEN; -import static jakarta.ws.rs.core.Response.Status.NOT_FOUND; import static jakarta.ws.rs.core.Response.Status.OK; -import static jakarta.ws.rs.core.Response.Status.UNAUTHORIZED; import java.util.UUID; import org.hamcrest.CoreMatchers; import static org.hamcrest.CoreMatchers.equalTo; import static org.hamcrest.CoreMatchers.is; -import static org.hamcrest.CoreMatchers.not; import static org.hamcrest.CoreMatchers.nullValue; -import static org.hamcrest.MatcherAssert.assertThat; -import static org.hamcrest.Matchers.hasItemInArray; import static org.junit.jupiter.api.Assertions.assertEquals; -import static org.junit.jupiter.api.Assertions.assertNotEquals; -import static org.junit.jupiter.api.Assertions.assertNotNull; -import static org.junit.jupiter.api.Assertions.assertNull; import org.junit.jupiter.api.BeforeAll; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; public class DatasetTypesIT { @@ -360,7 +353,7 @@ public void testUpdateDatasetTypeLinksWithMetadataBlocks() { UtilIT.publishDataverseViaNativeApi(dataverseAlias, apiToken).then().assertThat().statusCode(OK.getStatusCode()); - System.out.println("listing " + dataverseAlias + "collection blocks with display on create using dataset type " + randomName); + System.out.println("listing " + dataverseAlias + " collection blocks with display on create using dataset type " + randomName); listBlocks = UtilIT.listMetadataBlocks(dataverseAlias, true, false, randomName, apiToken); listBlocks.prettyPrint(); listBlocks.then().assertThat() @@ -369,7 +362,7 @@ public void testUpdateDatasetTypeLinksWithMetadataBlocks() { .body("data[1].name", is("geospatial")) .body("data[2].name", nullValue()); - System.out.println("listing " + dataverseAlias + "collection blocks without display on create using dataset type " + randomName); + System.out.println("listing " + dataverseAlias + " collection blocks without display on create using dataset type " + randomName); listBlocks = UtilIT.listMetadataBlocks(dataverseAlias, false, false, randomName, apiToken); listBlocks.prettyPrint(); listBlocks.then().assertThat() @@ -392,4 +385,95 @@ public void testUpdateDatasetTypeLinksWithMetadataBlocks() { .body("data[0].name", is("citation")); } + /** + * This test is disabled because it relies on the experimental "codeMeta20" + * metadata block to be loaded. + */ + @Disabled + @Test + public void testLinkSoftwareToCodemeta() { + Response listBlocksAvailable = UtilIT.listMetadataBlocks(false, true); +// if (true) {return;} + + Response createUser = UtilIT.createRandomUser(); + createUser.then().assertThat().statusCode(OK.getStatusCode()); + String username = UtilIT.getUsernameFromResponse(createUser); + String apiToken = UtilIT.getApiTokenFromResponse(createUser); + UtilIT.setSuperuserStatus(username, true).then().assertThat().statusCode(OK.getStatusCode()); + + String metadataBlockToAssociateDatasetTypeWith = """ + ["codeMeta20"] +"""; + + String datasetType = "software"; + Response associateGeospatialWithDatasetType1 = UtilIT.updateDatasetTypeLinksWithMetadataBlocks(datasetType, metadataBlockToAssociateDatasetTypeWith, apiToken); + associateGeospatialWithDatasetType1.prettyPrint(); + associateGeospatialWithDatasetType1.then().assertThat(). + statusCode(OK.getStatusCode()) + .body("data.linkedMetadataBlocks.after[0]", CoreMatchers.is("codeMeta20")); + + Response createDataverse = UtilIT.createRandomDataverse(apiToken); + createDataverse.then().assertThat().statusCode(CREATED.getStatusCode()); + + String dataverseAlias = UtilIT.getAliasFromResponse(createDataverse); + Integer dataverseId = UtilIT.getDataverseIdFromResponse(createDataverse); + + UtilIT.publishDataverseViaNativeApi(dataverseAlias, apiToken).then().assertThat().statusCode(OK.getStatusCode()); + + Response listBlocks = null; + System.out.println("listing root collection blocks with display on create using dataset type " + datasetType); + listBlocks = UtilIT.listMetadataBlocks(":root", true, true, datasetType, apiToken); + listBlocks.prettyPrint(); + listBlocks.then().assertThat() + .statusCode(OK.getStatusCode()) + .body("data[0].name", is("citation")) + .body("data[1].name", is("codeMeta20")) + .body("data[2].name", nullValue()) + .body("data[0].fields.title.displayOnCreate", equalTo(true)); + // TODO: why not shown? +// .body("data[1].fields.codeVersion.displayOnCreate", equalTo(true)); + + System.out.println("listing root collection blocks with all fields (not display on create) using dataset type " + datasetType); + listBlocks = UtilIT.listMetadataBlocks(":root", false, true, datasetType, apiToken); + listBlocks.prettyPrint(); + listBlocks.then().assertThat() + .statusCode(OK.getStatusCode()) + // TODO: why is "fields" empty? + .body("data[0].name", is("citation")) + .body("data[1].name", is("codeMeta20")) + .body("data[2].name", nullValue()) + .body("data[0].fields.title.displayOnCreate", equalTo(true)) + .body("data[0].fields.subtitle.displayOnCreate", equalTo(false)); + // why not shown? +// .body("data[1].fields.codeVersion.displayOnCreate", equalTo(true)) +// .body("data[1].fields.issueTracker.displayOnCreate", equalTo(false)); + + System.out.println("listing " + dataverseAlias + " collection blocks with display on create using dataset type " + datasetType); + listBlocks = UtilIT.listMetadataBlocks(dataverseAlias, true, true, datasetType, apiToken); + listBlocks.prettyPrint(); + listBlocks.then().assertThat() + .statusCode(OK.getStatusCode()) + .body("data[0].name", is("citation")) + .body("data[1].name", is("codeMeta20")) + .body("data[2].name", nullValue()) + // why not shown? + .body("data[0].fields.title.displayOnCreate", equalTo(true)) + .body("data[1].fields.codeVersion.displayOnCreate", equalTo(true)); + + System.out.println("listing " + dataverseAlias + " collection blocks with all fields (not display on create) using dataset type " + datasetType); + listBlocks = UtilIT.listMetadataBlocks(dataverseAlias, false, true, datasetType, apiToken); + listBlocks.prettyPrint(); + listBlocks.then().assertThat() + .statusCode(OK.getStatusCode()) + // TODO: why is "fields" empty? + .body("data[0].name", is("citation")) + .body("data[1].name", is("codeMeta20")) + .body("data[2].name", nullValue()) + .body("data[0].fields.title.displayOnCreate", equalTo(true)) + .body("data[0].fields.subtitle.displayOnCreate", equalTo(false)) + .body("data[1].fields.codeVersion.displayOnCreate", equalTo(true)) + .body("data[1].fields.issueTracker.displayOnCreate", equalTo(false)); + + } + }