Skip to content

Commit

Permalink
test: improvements to Report Schema tests
Browse files Browse the repository at this point in the history
  • Loading branch information
sofia-gomes-onfido committed Jun 19, 2024
1 parent 0149a1c commit 37db5e3
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 24 deletions.
40 changes: 24 additions & 16 deletions src/test/java/com/onfido/integration/ReportSchemasTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -26,18 +26,18 @@ public void schemaOfDocumentReportIsValid() throws Exception {
document,
new CheckBuilder().reportNames(Arrays.asList(ReportName.DOCUMENT)));

DocumentReport documentReport =
(DocumentReport)
Report documentReport =
(Report)
repeatRequestUntilStatusChanges(
"findReport", new Object[] {check.getReportIds().get(0)}, COMPLETE, 10, 1000);
"findReport", new Object[] {check.getReportIds().get(0)}, COMPLETE, 15, 1000);

Assertions.assertEquals(COMPLETE, documentReport.getStatus());
Assertions.assertEquals(COMPLETE, documentReport.getReportShared().getStatus());
Assertions.assertEquals(ReportName.DOCUMENT, documentReport.getName());
Assertions.assertEquals(check.getId(), documentReport.getCheckId());
Assertions.assertNotNull(documentReport.getBreakdown());
Assertions.assertNotNull(documentReport.getProperties());
Assertions.assertNotNull(documentReport.getResult());
Assertions.assertNotNull(documentReport.getSubResult());
Assertions.assertEquals(check.getId(), documentReport.getReportShared().getCheckId());
Assertions.assertNotNull(((DocumentReport) documentReport.getActualInstance()).getBreakdown());
Assertions.assertNotNull(((DocumentReport) documentReport.getActualInstance()).getProperties());
Assertions.assertNotNull(documentReport.getReportShared().getResult());
Assertions.assertNotNull(documentReport.getReportShared().getSubResult());
}

@Test
Expand All @@ -51,18 +51,26 @@ public void schemaOfFacialSimilarityPhotoReportIsValid() throws Exception {
new CheckBuilder()
.reportNames(Arrays.asList(ReportName.FACIAL_SIMILARITY_PHOTO_FULLY_AUTO)));

FacialSimilarityPhotoFullyAutoReport facialSimilarityPhotoFullyAutoReport =
(FacialSimilarityPhotoFullyAutoReport)
Report facialSimilarityPhotoFullyAutoReport =
(Report)
repeatRequestUntilStatusChanges(
"findReport", new Object[] {check.getReportIds().get(0)}, COMPLETE, 10, 1000);

Assertions.assertEquals(COMPLETE, facialSimilarityPhotoFullyAutoReport.getStatus());
Assertions.assertEquals(
COMPLETE, facialSimilarityPhotoFullyAutoReport.getReportShared().getStatus());
Assertions.assertEquals(
ReportName.FACIAL_SIMILARITY_PHOTO_FULLY_AUTO,
facialSimilarityPhotoFullyAutoReport.getName());
Assertions.assertEquals(check.getId(), facialSimilarityPhotoFullyAutoReport.getCheckId());
Assertions.assertNotNull(facialSimilarityPhotoFullyAutoReport.getBreakdown());
Assertions.assertNotNull(facialSimilarityPhotoFullyAutoReport.getResult());
Assertions.assertNotNull(facialSimilarityPhotoFullyAutoReport.getProperties());
Assertions.assertEquals(
check.getId(), facialSimilarityPhotoFullyAutoReport.getReportShared().getCheckId());
Assertions.assertNotNull(
((FacialSimilarityPhotoFullyAutoReport)
facialSimilarityPhotoFullyAutoReport.getActualInstance())
.getBreakdown());
Assertions.assertNotNull(facialSimilarityPhotoFullyAutoReport.getReportShared().getResult());
Assertions.assertNotNull(
((FacialSimilarityPhotoFullyAutoReport)
facialSimilarityPhotoFullyAutoReport.getActualInstance())
.getProperties());
}
}
9 changes: 5 additions & 4 deletions src/test/java/com/onfido/integration/TestBase.java
Original file line number Diff line number Diff line change
Expand Up @@ -174,12 +174,13 @@ public Object repeatRequestUntilStatusChanges(
boolean isInstanceOfReport = instance instanceof Report;

if (isInstanceOfReport) {
instance = ((Report) instance).getActualInstance();
instance = ((Report) instance).getReportShared();
}

int iteration = 0;
Method getStatusMethod = instance.getClass().getMethod("getStatus");

while (!instance.getClass().getMethod("getStatus").invoke(instance).equals(status)) {
while (!getStatusMethod.invoke(instance).equals(status)) {
if (iteration > maxRetries) {
throw new RuntimeException("Status did not change in time");
}
Expand All @@ -188,12 +189,12 @@ public Object repeatRequestUntilStatusChanges(
Thread.sleep(sleepTime);

if (isInstanceOfReport) {
instance = ((Report) method.invoke(onfido, params)).getActualInstance();
instance = ((Report) method.invoke(onfido, params)).getReportShared();
} else {
instance = method.invoke(onfido, params);
}
}
return instance;
return method.invoke(onfido, params);
}

public Object repeatRequestUntilHttpCodeChanges(
Expand Down
7 changes: 3 additions & 4 deletions src/test/java/com/onfido/integration/WorkflowRunTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ public class WorkflowRunTest extends TestBase {
private UUID workflowRunId;

static final UUID WORKFLOW_ID = UUID.fromString("e8c921eb-0495-44fe-b655-bcdcaffdafe5");
static final UUID WORKFLOW_ID_TIMELINE = UUID.fromString("221f9d24-cf72-4762-ac4a-01bf3ccc09dd");

@BeforeEach
public void setup() throws Exception {
Expand Down Expand Up @@ -71,8 +72,7 @@ public void evidenceWorkflowRunTest() throws Exception {

@Test
public void generateTimelineFileTest() throws Exception {
UUID workflowId = UUID.fromString("221f9d24-cf72-4762-ac4a-01bf3ccc09dd");
UUID workflowRunId = createWorkflowRun(workflowId, applicantId).getId();
UUID workflowRunId = createWorkflowRun(WORKFLOW_ID_TIMELINE, applicantId).getId();

repeatRequestUntilStatusChanges(
"findWorkflowRun", new UUID[] {workflowRunId}, WorkflowRun.StatusEnum.APPROVED, 10, 1000);
Expand All @@ -84,8 +84,7 @@ public void generateTimelineFileTest() throws Exception {

@Test
public void findTimelineFileTest() throws Exception {
UUID workflowId = UUID.fromString("221f9d24-cf72-4762-ac4a-01bf3ccc09dd");
UUID workflowRunId = createWorkflowRun(workflowId, applicantId).getId();
UUID workflowRunId = createWorkflowRun(WORKFLOW_ID_TIMELINE, applicantId).getId();

repeatRequestUntilStatusChanges(
"findWorkflowRun", new UUID[] {workflowRunId}, WorkflowRun.StatusEnum.APPROVED, 10, 1000);
Expand Down

0 comments on commit 37db5e3

Please sign in to comment.