-
Notifications
You must be signed in to change notification settings - Fork 19
/
AuthorisationRequestSummaryStructuredLoggingTest.java
93 lines (75 loc) · 4.5 KB
/
AuthorisationRequestSummaryStructuredLoggingTest.java
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package uk.gov.pay.connector.gateway.util;
import net.logstash.logback.argument.StructuredArgument;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.mockito.Mock;
import org.mockito.junit.jupiter.MockitoExtension;
import uk.gov.pay.connector.gateway.model.AuthorisationRequestSummary;
import static net.logstash.logback.argument.StructuredArguments.kv;
import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.Matchers.is;
import static org.hamcrest.collection.ArrayMatching.arrayContaining;
import static org.hamcrest.collection.IsArrayWithSize.emptyArray;
import static org.mockito.BDDMockito.given;
import static uk.gov.pay.connector.gateway.model.AuthorisationRequestSummary.Presence.NOT_APPLICABLE;
import static uk.gov.pay.connector.gateway.model.AuthorisationRequestSummary.Presence.NOT_PRESENT;
import static uk.gov.pay.connector.gateway.model.AuthorisationRequestSummary.Presence.PRESENT;
import static uk.gov.pay.connector.gateway.util.AuthorisationRequestSummaryStructuredLogging.BILLING_ADDRESS;
import static uk.gov.pay.connector.gateway.util.AuthorisationRequestSummaryStructuredLogging.DATA_FOR_3DS;
import static uk.gov.pay.connector.gateway.util.AuthorisationRequestSummaryStructuredLogging.DATA_FOR_3DS2;
import static uk.gov.pay.connector.gateway.util.AuthorisationRequestSummaryStructuredLogging.WORLDPAY_3DS_FLEX_DEVICE_DATA_COLLECTION_RESULT;
@ExtendWith(MockitoExtension.class)
class AuthorisationRequestSummaryStructuredLoggingTest {
@Mock private AuthorisationRequestSummary mockAuthorisationRequestSummary;
private final AuthorisationRequestSummaryStructuredLogging structuredLogging = new AuthorisationRequestSummaryStructuredLogging();
@Test
void createArgsWithAllPresent() {
given(mockAuthorisationRequestSummary.billingAddress()).willReturn(PRESENT);
given(mockAuthorisationRequestSummary.dataFor3ds()).willReturn(PRESENT);
given(mockAuthorisationRequestSummary.dataFor3ds2()).willReturn(PRESENT);
given(mockAuthorisationRequestSummary.deviceDataCollectionResult()).willReturn(PRESENT);
StructuredArgument[] result = structuredLogging.createArgs(mockAuthorisationRequestSummary);
assertThat(result, arrayContaining(
kv(BILLING_ADDRESS, true),
kv(DATA_FOR_3DS, true),
kv(DATA_FOR_3DS2, true),
kv(WORLDPAY_3DS_FLEX_DEVICE_DATA_COLLECTION_RESULT, true)
));
}
@Test
void createArgsWithAllNotPresent() {
given(mockAuthorisationRequestSummary.billingAddress()).willReturn(NOT_PRESENT);
given(mockAuthorisationRequestSummary.dataFor3ds()).willReturn(NOT_PRESENT);
given(mockAuthorisationRequestSummary.dataFor3ds2()).willReturn(NOT_PRESENT);
given(mockAuthorisationRequestSummary.deviceDataCollectionResult()).willReturn(NOT_PRESENT);
StructuredArgument[] result = structuredLogging.createArgs(mockAuthorisationRequestSummary);
assertThat(result, is(arrayContaining(
kv(BILLING_ADDRESS, false),
kv(DATA_FOR_3DS, false),
kv(DATA_FOR_3DS2, false),
kv(WORLDPAY_3DS_FLEX_DEVICE_DATA_COLLECTION_RESULT, false)
)));
}
@Test
void createArgsWithAllNotApplicable() {
given(mockAuthorisationRequestSummary.billingAddress()).willReturn(NOT_APPLICABLE);
given(mockAuthorisationRequestSummary.dataFor3ds()).willReturn(NOT_APPLICABLE);
given(mockAuthorisationRequestSummary.dataFor3ds2()).willReturn(NOT_APPLICABLE);
given(mockAuthorisationRequestSummary.deviceDataCollectionResult()).willReturn(NOT_APPLICABLE);
StructuredArgument[] result = structuredLogging.createArgs(mockAuthorisationRequestSummary);
assertThat(result, is(emptyArray()));
}
@Test
void createArgsWithMixture() {
given(mockAuthorisationRequestSummary.billingAddress()).willReturn(PRESENT);
given(mockAuthorisationRequestSummary.dataFor3ds()).willReturn(PRESENT);
given(mockAuthorisationRequestSummary.dataFor3ds2()).willReturn(NOT_APPLICABLE);
given(mockAuthorisationRequestSummary.deviceDataCollectionResult()).willReturn(NOT_PRESENT);
StructuredArgument[] result = structuredLogging.createArgs(mockAuthorisationRequestSummary);
assertThat(result, is(arrayContaining(
kv(BILLING_ADDRESS, true),
kv(DATA_FOR_3DS, true),
kv(WORLDPAY_3DS_FLEX_DEVICE_DATA_COLLECTION_RESULT, false)
)));
}
}