-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
113 additions
and
0 deletions.
There are no files selected for viewing
113 changes: 113 additions & 0 deletions
113
src/test/java/nl/knaw/dans/dvcli/command/CollectionCreateDatasetTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,113 @@ | ||
package nl.knaw.dans.dvcli.command; | ||
|
||
import nl.knaw.dans.dvcli.AbstractCapturingTest; | ||
import nl.knaw.dans.dvcli.action.Pair; | ||
import nl.knaw.dans.lib.dataverse.DataverseApi; | ||
import nl.knaw.dans.lib.dataverse.DataverseClient; | ||
import nl.knaw.dans.lib.dataverse.DataverseClientConfig; | ||
import org.junit.jupiter.api.Test; | ||
import org.mockito.Mockito; | ||
|
||
import java.net.URI; | ||
import java.util.HashMap; | ||
import java.util.List; | ||
|
||
import static org.assertj.core.api.Assertions.assertThat; | ||
|
||
public class CollectionCreateDatasetTest extends AbstractCapturingTest { | ||
@Test | ||
public void doCall_continues_on_unknownHost() throws Exception { | ||
|
||
var metadataKeys = new HashMap<String, String>(); | ||
var unknownHostConfig = new DataverseClientConfig(new URI("https://does.not.exist.dans.knaw.nl"), "apiToken"); | ||
var cmd = getCmd( | ||
metadataKeys, | ||
List.of( | ||
new Pair<>("A", new DataverseClient(unknownHostConfig).dataverse("A")), | ||
new Pair<>("B", new DataverseClient(unknownHostConfig).dataverse("B")), | ||
new Pair<>("C", new DataverseClient(unknownHostConfig).dataverse("B")) | ||
) | ||
); | ||
|
||
// method under test | ||
cmd.doCall(); | ||
|
||
assertThat(stdout.toString()).isEqualTo(""" | ||
INFO Starting batch processing | ||
INFO Processing item 1 of 3 | ||
DEBUG buildUri: https://does.not.exist.dans.knaw.nl/api/dataverses/A/datasets | ||
INFO Processing item 2 of 3 | ||
DEBUG buildUri: https://does.not.exist.dans.knaw.nl/api/dataverses/B/datasets | ||
INFO Processing item 3 of 3 | ||
DEBUG buildUri: https://does.not.exist.dans.knaw.nl/api/dataverses/B/datasets | ||
INFO Finished batch processing of 3 items | ||
"""); | ||
assertThat(stderr.toString()).isEqualTo(""" | ||
A: FAILED: Exception type = UnknownHostException, message = does.not.exist.dans.knaw.nl: Name or service not known | ||
B: FAILED: Exception type = UnknownHostException, message = does.not.exist.dans.knaw.nl | ||
C: FAILED: Exception type = UnknownHostException, message = does.not.exist.dans.knaw.nl | ||
"""); // TODO implement fail fast in BatchProcessor for these type of exceptions? | ||
} | ||
|
||
@Test | ||
public void doCall_() throws Exception { | ||
|
||
var metadataKeys = new HashMap<String, String>(); | ||
|
||
// TODO mock response properly, CollectionAssignRole would be more interesting to test | ||
var api = Mockito.mock(DataverseApi.class); | ||
Mockito.when(api.createDataset("A", metadataKeys)).thenReturn(null); | ||
Mockito.when(api.createDataset("B", metadataKeys)).thenReturn(null); | ||
|
||
var cmd = getCmd( | ||
metadataKeys, | ||
List.of( | ||
new Pair<>("A", api), | ||
new Pair<>("B", api) | ||
) | ||
); | ||
|
||
// method under test | ||
cmd.doCall(); | ||
|
||
assertThat(stdout.toString()).isEqualTo(""" | ||
INFO Starting batch processing | ||
INFO Processing item 1 of 2 | ||
INFO Processing item 2 of 2 | ||
INFO Finished batch processing of 2 items | ||
"""); | ||
assertThat(stderr.toString()).isEqualTo(""" | ||
A: FAILED: Exception type = NullPointerException, message = Cannot invoke "nl.knaw.dans.lib.dataverse.DataverseHttpResponse.getEnvelopeAsString()" because "r" is null | ||
B: FAILED: Exception type = NullPointerException, message = Cannot invoke "nl.knaw.dans.lib.dataverse.DataverseHttpResponse.getEnvelopeAsString()" because "r" is null | ||
"""); | ||
|
||
// verify(api, times(1)).createDataset("A", any()); | ||
// verify(api, times(1)).createDataset("B"); | ||
// verifyNoMoreInteractions(api); | ||
} | ||
|
||
private static CollectionCreateDataset getCmd(HashMap<String, String> metadataKeys, final List<Pair<String, DataverseApi>> pairs) throws NoSuchFieldException, IllegalAccessException { | ||
var cmd = new CollectionCreateDataset(); | ||
|
||
// set private fields | ||
|
||
var datasetField = CollectionCreateDataset.class.getDeclaredField("dataset"); | ||
datasetField.setAccessible(true); | ||
datasetField.set(cmd, "src/test/resources/debug-etc/config.yml"); // invalid json file | ||
|
||
var metadataKeysField = CollectionCreateDataset.class.getDeclaredField("metadataKeys"); | ||
metadataKeysField.setAccessible(true); | ||
metadataKeysField.set(cmd, metadataKeys); | ||
|
||
var collectionCmdField = CollectionCreateDataset.class.getDeclaredField("collectionCmd"); | ||
collectionCmdField.setAccessible(true); | ||
collectionCmdField.set(cmd, new CollectionCmd(new DataverseClient(null)) { | ||
|
||
@Override | ||
protected List<Pair<String, DataverseApi>> getItems() { | ||
return pairs; | ||
} | ||
}); | ||
return cmd; | ||
} | ||
} |