-
Notifications
You must be signed in to change notification settings - Fork 541
Expand file tree
/
Copy pathFitsIT.java
More file actions
78 lines (62 loc) · 3.68 KB
/
FitsIT.java
File metadata and controls
78 lines (62 loc) · 3.68 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
package edu.harvard.iq.dataverse.api;
import com.jayway.restassured.RestAssured;
import static com.jayway.restassured.path.json.JsonPath.with;
import com.jayway.restassured.response.Response;
import java.io.IOException;
import java.util.List;
import java.util.Map;
import javax.json.Json;
import javax.json.JsonObject;
import static javax.ws.rs.core.Response.Status.CREATED;
import static javax.ws.rs.core.Response.Status.OK;
import static org.hamcrest.CoreMatchers.equalTo;
import static org.junit.Assert.assertTrue;
import org.junit.BeforeClass;
import org.junit.Test;
public class FitsIT {
@BeforeClass
public static void setUp() {
RestAssured.baseURI = UtilIT.getRestAssuredBaseUri();
}
@Test
public void testAstroFieldsFromFits() throws IOException {
Response createUser = UtilIT.createRandomUser();
createUser.then().assertThat().statusCode(OK.getStatusCode());
String apiToken = UtilIT.getApiTokenFromResponse(createUser);
String username = UtilIT.getUsernameFromResponse(createUser);
Response createDataverseResponse = UtilIT.createRandomDataverse(apiToken);
createDataverseResponse.prettyPrint();
createDataverseResponse.then().assertThat()
.statusCode(CREATED.getStatusCode());
String dataverseAlias = UtilIT.getAliasFromResponse(createDataverseResponse);
Response setMetadataBlocks = UtilIT.setMetadataBlocks(dataverseAlias, Json.createArrayBuilder().add("citation").add("astrophysics"), apiToken);
setMetadataBlocks.prettyPrint();
setMetadataBlocks.then().assertThat().statusCode(OK.getStatusCode());
Response createDataset = UtilIT.createRandomDatasetViaNativeApi(dataverseAlias, apiToken);
createDataset.prettyPrint();
createDataset.then().assertThat()
.statusCode(CREATED.getStatusCode());
Integer datasetId = UtilIT.getDatasetIdFromResponse(createDataset);
String datasetPid = UtilIT.getDatasetPersistentIdFromResponse(createDataset);
// "FOS 2 x 2064 primary array spectrum containing the flux and wavelength arrays, plus a small table extension"
// from https://fits.gsfc.nasa.gov/fits_samples.html
String pathToFile = "src/test/resources/fits/FOSy19g0309t_c2f.fits";
Response uploadFile = UtilIT.uploadFileViaNative(datasetId.toString(), pathToFile, apiToken);
uploadFile.prettyPrint();
uploadFile.then().assertThat().statusCode(OK.getStatusCode());
Response getJson = UtilIT.nativeGet(datasetId, apiToken);
getJson.prettyPrint();
getJson.then().assertThat()
.statusCode(OK.getStatusCode())
.body("data.latestVersion.metadataBlocks.astrophysics.fields[0].value[0]", equalTo("Image"));
// a bit more precise than the check for "Image" above (but annoyingly fiddly)
List<JsonObject> astroTypeFromNativeGet = with(getJson.body().asString()).param("astroType", "astroType")
.getJsonObject("data.latestVersion.metadataBlocks.astrophysics.fields.findAll { fields -> fields.typeName == astroType }");
Map firstAstroTypeFromNativeGet = astroTypeFromNativeGet.get(0);
assertTrue(firstAstroTypeFromNativeGet.toString().contains("Image"));
List<JsonObject> coverageTemportalFromNativeGet = with(getJson.body().asString()).param("coverageTemporal", "coverage.Temporal")
.getJsonObject("data.latestVersion.metadataBlocks.astrophysics.fields.findAll { fields -> fields.typeName == coverageTemporal }");
Map firstcoverageTemporalFromNativeGet = coverageTemportalFromNativeGet.get(0);
assertTrue(firstcoverageTemporalFromNativeGet.toString().contains("1993"));
}
}