From bc91a301bb088bc2b4c39e534cbef2ea9c33c2e8 Mon Sep 17 00:00:00 2001 From: Artem Dvornichenko Date: Thu, 29 Jun 2023 11:59:34 +0300 Subject: [PATCH 01/10] API-7197: Updated version to 3.11.0 --- CHANGES.MD | 6 ++++++ README.md | 4 ++-- build.gradle | 2 +- src/main/java/com/siftscience/Constants.java | 2 +- src/test/java/com/siftscience/SiftRequestTest.java | 2 +- 5 files changed, 11 insertions(+), 5 deletions(-) diff --git a/CHANGES.MD b/CHANGES.MD index 6c1f07c..c5bf05c 100644 --- a/CHANGES.MD +++ b/CHANGES.MD @@ -1,3 +1,9 @@ +3.11.0 (2023-06-29) +================= +- Add support for `$user_email` field to `$add_item_to_cart`, `$add_promotion`, `$content_status`, `$flag_content`, `$remove_item_from_cart` and `$update_password` events +- Add support for `$shipping_carrier` and `$shipping_tracking_numbers` fields to `$create_order` and `$update_order` events +- Add support for `reason` field to `flag_content` event + 3.10.0 (2023-06-06) ================= - Remove support for `$keyless_user_id` field for Events API diff --git a/README.md b/README.md index 8045302..5359da2 100644 --- a/README.md +++ b/README.md @@ -13,13 +13,13 @@ Java 1.7 or later. com.siftscience sift-java - 3.10.0 + 3.11.0 ``` ### Gradle ``` dependencies { - compile 'com.siftscience:sift-java:3.10.0' + compile 'com.siftscience:sift-java:3.11.0' } ``` ### Other diff --git a/build.gradle b/build.gradle index b94dd71..fe04259 100644 --- a/build.gradle +++ b/build.gradle @@ -5,7 +5,7 @@ apply plugin: 'signing' apply plugin: 'java-library-distribution' group = 'com.siftscience' -version = '3.10.0' +version = '3.11.0' repositories { mavenCentral() diff --git a/src/main/java/com/siftscience/Constants.java b/src/main/java/com/siftscience/Constants.java index 31e08d7..3663f94 100644 --- a/src/main/java/com/siftscience/Constants.java +++ b/src/main/java/com/siftscience/Constants.java @@ -3,6 +3,6 @@ public class Constants { public static final String API_VERSION = "v205"; - public static final String LIB_VERSION = "3.8.0"; + public static final String LIB_VERSION = "3.11.0"; public static final String USER_AGENT_HEADER = String.format("SiftScience/%s sift-java/%s", API_VERSION, LIB_VERSION); } diff --git a/src/test/java/com/siftscience/SiftRequestTest.java b/src/test/java/com/siftscience/SiftRequestTest.java index 4245d00..5aa61c5 100644 --- a/src/test/java/com/siftscience/SiftRequestTest.java +++ b/src/test/java/com/siftscience/SiftRequestTest.java @@ -37,7 +37,7 @@ public void testUserAgentHeader() throws Exception { // Verify the request. RecordedRequest recordedRequest = server.takeRequest(); - Assert.assertEquals("SiftScience/v205 sift-java/3.8.0", recordedRequest.getHeader("User-Agent")); + Assert.assertEquals("SiftScience/v205 sift-java/3.11.0", recordedRequest.getHeader("User-Agent")); } } From 33480443212677cd4141f0e3338237d95ce9aa8e Mon Sep 17 00:00:00 2001 From: Artem Dvornichenko Date: Thu, 29 Jun 2023 13:17:04 +0300 Subject: [PATCH 02/10] API-7197: Added support for $user_email field to $add_item_to_cart, $add_promotion, $content_status, $flag_content, $remove_item_from_cart and $update_password events --- .../siftscience/model/AddItemToCartFieldSet.java | 10 ++++++++++ .../siftscience/model/AddPromotionFieldSet.java | 10 ++++++++++ .../siftscience/model/ContentStatusFieldSet.java | 10 ++++++++++ .../com/siftscience/model/FlagContentFieldSet.java | 10 ++++++++++ .../model/RemoveItemFromCartFieldSet.java | 10 ++++++++++ .../siftscience/model/UpdatePasswordFieldSet.java | 10 ++++++++++ .../com/siftscience/AddItemToCartEventTest.java | 8 ++++++-- .../com/siftscience/AddPromotionEventTest.java | 8 ++++++-- .../com/siftscience/ContentStatusEventTest.java | 8 ++++++-- .../java/com/siftscience/FlagContentEventTest.java | 14 ++++++++++---- .../siftscience/RemoveItemFromCartEventTest.java | 8 ++++++-- .../com/siftscience/UpdatePasswordEventTest.java | 10 ++++++++-- 12 files changed, 102 insertions(+), 14 deletions(-) diff --git a/src/main/java/com/siftscience/model/AddItemToCartFieldSet.java b/src/main/java/com/siftscience/model/AddItemToCartFieldSet.java index 15dd5f9..eed3032 100644 --- a/src/main/java/com/siftscience/model/AddItemToCartFieldSet.java +++ b/src/main/java/com/siftscience/model/AddItemToCartFieldSet.java @@ -9,6 +9,7 @@ public static AddItemToCartFieldSet fromJson(String json) { } @Expose @SerializedName("$item") private Item item; + @Expose @SerializedName("$user_email") private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override @@ -25,6 +26,15 @@ public AddItemToCartFieldSet setItem(Item item) { return this; } + public String getUserEmail() { + return userEmail; + } + + public AddItemToCartFieldSet setUserEmail(String userEmail) { + this.userEmail = userEmail; + return this; + } + public String getVerificationPhoneNumber() { return verificationPhoneNumber; } diff --git a/src/main/java/com/siftscience/model/AddPromotionFieldSet.java b/src/main/java/com/siftscience/model/AddPromotionFieldSet.java index 9836e59..a22e1ad 100644 --- a/src/main/java/com/siftscience/model/AddPromotionFieldSet.java +++ b/src/main/java/com/siftscience/model/AddPromotionFieldSet.java @@ -11,6 +11,7 @@ public static AddPromotionFieldSet fromJson(String json) { } @Expose @SerializedName("$promotions") private List promotions; + @Expose @SerializedName("$user_email") private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override @@ -27,6 +28,15 @@ public AddPromotionFieldSet setPromotions(List promotions) { return this; } + public String getUserEmail() { + return userEmail; + } + + public AddPromotionFieldSet setUserEmail(String userEmail) { + this.userEmail = userEmail; + return this; + } + public String getVerificationPhoneNumber() { return verificationPhoneNumber; } diff --git a/src/main/java/com/siftscience/model/ContentStatusFieldSet.java b/src/main/java/com/siftscience/model/ContentStatusFieldSet.java index 47c108c..26a160c 100644 --- a/src/main/java/com/siftscience/model/ContentStatusFieldSet.java +++ b/src/main/java/com/siftscience/model/ContentStatusFieldSet.java @@ -10,6 +10,7 @@ public static ContentStatusFieldSet fromJson(String json) { @Expose @SerializedName("$content_id") private String contentId; @Expose @SerializedName("$status") private String status; + @Expose @SerializedName("$user_email") private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override @@ -35,6 +36,15 @@ public ContentStatusFieldSet setContentId(String contentId) { return this; } + public String getUserEmail() { + return userEmail; + } + + public ContentStatusFieldSet setUserEmail(String userEmail) { + this.userEmail = userEmail; + return this; + } + public String getVerificationPhoneNumber() { return verificationPhoneNumber; } diff --git a/src/main/java/com/siftscience/model/FlagContentFieldSet.java b/src/main/java/com/siftscience/model/FlagContentFieldSet.java index 4c39ab9..afa8559 100644 --- a/src/main/java/com/siftscience/model/FlagContentFieldSet.java +++ b/src/main/java/com/siftscience/model/FlagContentFieldSet.java @@ -10,6 +10,7 @@ public static FlagContentFieldSet fromJson(String json) { @Expose @SerializedName("$content_id") private String contentId; @Expose @SerializedName("$flagged_by") private String flaggedBy; + @Expose @SerializedName("$user_email") private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override @@ -35,6 +36,15 @@ public FlagContentFieldSet setFlaggedBy(String flaggedBy) { return this; } + public String getUserEmail() { + return userEmail; + } + + public FlagContentFieldSet setUserEmail(String userEmail) { + this.userEmail = userEmail; + return this; + } + public String getVerificationPhoneNumber() { return verificationPhoneNumber; } diff --git a/src/main/java/com/siftscience/model/RemoveItemFromCartFieldSet.java b/src/main/java/com/siftscience/model/RemoveItemFromCartFieldSet.java index 1d320a0..290204e 100644 --- a/src/main/java/com/siftscience/model/RemoveItemFromCartFieldSet.java +++ b/src/main/java/com/siftscience/model/RemoveItemFromCartFieldSet.java @@ -9,6 +9,7 @@ public static RemoveItemFromCartFieldSet fromJson(String json) { } @Expose @SerializedName("$item") private Item item; + @Expose @SerializedName("$user_email") private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override @@ -25,6 +26,15 @@ public RemoveItemFromCartFieldSet setItem(Item item) { return this; } + public String getUserEmail() { + return userEmail; + } + + public RemoveItemFromCartFieldSet setUserEmail(String userEmail) { + this.userEmail = userEmail; + return this; + } + public String getVerificationPhoneNumber() { return verificationPhoneNumber; } diff --git a/src/main/java/com/siftscience/model/UpdatePasswordFieldSet.java b/src/main/java/com/siftscience/model/UpdatePasswordFieldSet.java index 2f86905..f4eab23 100644 --- a/src/main/java/com/siftscience/model/UpdatePasswordFieldSet.java +++ b/src/main/java/com/siftscience/model/UpdatePasswordFieldSet.java @@ -10,6 +10,7 @@ public static UpdatePasswordFieldSet fromJson(String json) { @Expose @SerializedName("$reason") private String reason; @Expose @SerializedName("$status") private String status; + @Expose @SerializedName("$user_email") private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override @@ -31,6 +32,15 @@ public UpdatePasswordFieldSet setStatus(String status) { return this; } + public String getUserEmail() { + return userEmail; + } + + public UpdatePasswordFieldSet setUserEmail(String userEmail) { + this.userEmail = userEmail; + return this; + } + public String getVerificationPhoneNumber() { return verificationPhoneNumber; } diff --git a/src/test/java/com/siftscience/AddItemToCartEventTest.java b/src/test/java/com/siftscience/AddItemToCartEventTest.java index 4ac4ac7..002fb16 100644 --- a/src/test/java/com/siftscience/AddItemToCartEventTest.java +++ b/src/test/java/com/siftscience/AddItemToCartEventTest.java @@ -1,6 +1,7 @@ package com.siftscience; import com.siftscience.model.AddItemToCartFieldSet; +import com.siftscience.model.EventResponseBody; import okhttp3.OkHttpClient; import okhttp3.mockwebserver.MockResponse; import okhttp3.mockwebserver.MockWebServer; @@ -34,6 +35,7 @@ public void testAddItemToCart() throws Exception { " \"$color\" : \"Texas Tea\",\n" + " \"$quantity\" : 2\n" + " },\n" + + " \"$user_email\" : \"billy_jones_301@email.com\",\n" + " \"$verification_phone_number\" : \"+12345678901\"\n" + "}"; @@ -57,13 +59,14 @@ public void testAddItemToCart() throws Exception { .build()); // Build and execute the request against the mock server. - SiftRequest request = client.buildRequest(new AddItemToCartFieldSet() + SiftRequest request = client.buildRequest(new AddItemToCartFieldSet() .setUserId("billy_jones_301") .setSessionId("gigtleqddo84l8cm15qe4il") .setItem(TestUtils.sampleItem2()) + .setUserEmail("billy_jones_301@email.com") .setVerificationPhoneNumber("+12345678901")); - SiftResponse siftResponse = request.send(); + SiftResponse siftResponse = request.send(); // Verify the request. RecordedRequest request1 = server.takeRequest(); @@ -74,6 +77,7 @@ public void testAddItemToCart() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/AddPromotionEventTest.java b/src/test/java/com/siftscience/AddPromotionEventTest.java index dba13d4..fd921c5 100644 --- a/src/test/java/com/siftscience/AddPromotionEventTest.java +++ b/src/test/java/com/siftscience/AddPromotionEventTest.java @@ -5,6 +5,7 @@ import java.util.List; import com.siftscience.model.AddPromotionFieldSet; +import com.siftscience.model.EventResponseBody; import com.siftscience.model.Promotion; import okhttp3.OkHttpClient; import okhttp3.mockwebserver.MockResponse; @@ -34,6 +35,7 @@ public void testAddPromotion() throws Exception { " }\n" + " }\n" + " ],\n" + + " \"$user_email\" : \"billy_jones_301@email.com\",\n" + " \"$verification_phone_number\" : \"+12345678901\"\n" + "}"; @@ -61,12 +63,13 @@ public void testAddPromotion() throws Exception { promotions.add(TestUtils.samplePromotion3()); // Build and execute the request against the mock server. - SiftRequest request = client.buildRequest(new AddPromotionFieldSet() + SiftRequest request = client.buildRequest(new AddPromotionFieldSet() .setUserId("billy_jones_301") .setPromotions(promotions) + .setUserEmail("billy_jones_301@email.com") .setVerificationPhoneNumber("+12345678901")); - SiftResponse siftResponse = request.send(); + SiftResponse siftResponse = request.send(); // Verify the request. RecordedRequest request1 = server.takeRequest(); @@ -77,6 +80,7 @@ public void testAddPromotion() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/ContentStatusEventTest.java b/src/test/java/com/siftscience/ContentStatusEventTest.java index 5abb7f5..f5f4eb4 100644 --- a/src/test/java/com/siftscience/ContentStatusEventTest.java +++ b/src/test/java/com/siftscience/ContentStatusEventTest.java @@ -3,6 +3,7 @@ import static java.net.HttpURLConnection.HTTP_OK; import com.siftscience.model.ContentStatusFieldSet; +import com.siftscience.model.EventResponseBody; import okhttp3.OkHttpClient; import okhttp3.mockwebserver.MockResponse; import okhttp3.mockwebserver.MockWebServer; @@ -20,6 +21,7 @@ public void testContentStatus() throws Exception { " \"$user_id\" : \"billy_jones_301\",\n" + " \"$content_id\" : \"9671500641\",\n" + " \"$status\" : \"$paused\",\n" + + " \"$user_email\" : \"billy_jones_301@email.com\",\n" + " \"$verification_phone_number\" : \"+12345678901\"\n" + "}"; @@ -44,13 +46,14 @@ public void testContentStatus() throws Exception { .build()); // Build and execute the request against the mock server. - SiftRequest request = client.buildRequest(new ContentStatusFieldSet() + SiftRequest request = client.buildRequest(new ContentStatusFieldSet() .setUserId("billy_jones_301") .setContentId("9671500641") .setStatus("$paused") + .setUserEmail("billy_jones_301@email.com") .setVerificationPhoneNumber("+12345678901")); - SiftResponse siftResponse = request.send(); + SiftResponse siftResponse = request.send(); // Verify the request. RecordedRequest request1 = server.takeRequest(); @@ -61,6 +64,7 @@ public void testContentStatus() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/FlagContentEventTest.java b/src/test/java/com/siftscience/FlagContentEventTest.java index a06a0cc..81bb917 100644 --- a/src/test/java/com/siftscience/FlagContentEventTest.java +++ b/src/test/java/com/siftscience/FlagContentEventTest.java @@ -2,6 +2,7 @@ import static java.net.HttpURLConnection.HTTP_OK; +import com.siftscience.model.EventResponseBody; import com.siftscience.model.FlagContentFieldSet; import okhttp3.OkHttpClient; import okhttp3.mockwebserver.MockResponse; @@ -20,7 +21,9 @@ public void testFlagContent() throws Exception { " \"$user_id\" : \"billy_jones_301\",\n" + " \"$content_id\" : \"9671500641\",\n" + "\n" + - " \"$flagged_by\" : \"jamieli89\"\n" + + " \"$flagged_by\" : \"jamieli89\",\n" + + " \"$user_email\" : \"billy_jones_301@email.com\",\n" + + " \"$verification_phone_number\" : \"+12345678901\"\n" + "}"; @@ -44,12 +47,14 @@ public void testFlagContent() throws Exception { .build()); // Build and execute the request against the mock server. - SiftRequest request = client.buildRequest(new FlagContentFieldSet() + SiftRequest request = client.buildRequest(new FlagContentFieldSet() .setUserId("billy_jones_301") .setContentId("9671500641") - .setFlaggedBy("jamieli89")); + .setFlaggedBy("jamieli89") + .setUserEmail("billy_jones_301@email.com") + .setVerificationPhoneNumber("+12345678901")); - SiftResponse siftResponse = request.send(); + SiftResponse siftResponse = request.send(); // Verify the request. RecordedRequest request1 = server.takeRequest(); @@ -60,6 +65,7 @@ public void testFlagContent() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/RemoveItemFromCartEventTest.java b/src/test/java/com/siftscience/RemoveItemFromCartEventTest.java index c174d2c..c2fd457 100644 --- a/src/test/java/com/siftscience/RemoveItemFromCartEventTest.java +++ b/src/test/java/com/siftscience/RemoveItemFromCartEventTest.java @@ -2,6 +2,7 @@ import static java.net.HttpURLConnection.HTTP_OK; +import com.siftscience.model.EventResponseBody; import com.siftscience.model.RemoveItemFromCartFieldSet; import okhttp3.OkHttpClient; import okhttp3.mockwebserver.MockResponse; @@ -33,6 +34,7 @@ public void testRemoveItemFromCart() throws Exception { " \"$tags\" : [\"Awesome\", \"Wintertime specials\"],\n" + " \"$color\" : \"Texas Tea\"\n" + " },\n" + + " \"$user_email\" : \"billy_jones_301@email.com\",\n" + " \"$verification_phone_number\" : \"+12345678901\"\n" + "}"; @@ -56,13 +58,14 @@ public void testRemoveItemFromCart() throws Exception { .build()); // Build and execute the request against the mock server. - SiftRequest request = client.buildRequest(new RemoveItemFromCartFieldSet() + SiftRequest request = client.buildRequest(new RemoveItemFromCartFieldSet() .setUserId("billy_jones_301") .setSessionId("gigtleqddo84l8cm15qe4il") .setItem(TestUtils.sampleItem2()) + .setUserEmail("billy_jones_301@email.com") .setVerificationPhoneNumber("+12345678901")); - SiftResponse siftResponse = request.send(); + SiftResponse siftResponse = request.send(); // Verify the request. RecordedRequest request1 = server.takeRequest(); @@ -73,6 +76,7 @@ public void testRemoveItemFromCart() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/UpdatePasswordEventTest.java b/src/test/java/com/siftscience/UpdatePasswordEventTest.java index 71bbeff..a7f18a0 100644 --- a/src/test/java/com/siftscience/UpdatePasswordEventTest.java +++ b/src/test/java/com/siftscience/UpdatePasswordEventTest.java @@ -3,6 +3,7 @@ import static java.net.HttpURLConnection.HTTP_OK; import com.siftscience.model.App; +import com.siftscience.model.EventResponseBody; import com.siftscience.model.UpdatePasswordFieldSet; import okhttp3.OkHttpClient; import okhttp3.mockwebserver.MockResponse; @@ -35,6 +36,8 @@ public void testUpdatePassword() throws Exception { " \"$reason\" : \"$forced_reset\",\n" + " \"$status\" : \"$success\",\n" + " \"$ip\" : \"128.148.1.135\",\n" + + " \"$user_email\" : \"billy_jones_301@email.com\",\n" + + " \"$verification_phone_number\" : \"+12345678901\"\n" + "}"; MockWebServer server = new MockWebServer(); @@ -62,6 +65,8 @@ public void testUpdatePassword() throws Exception { .setReason("$forced_reset") .setStatus("$success") .setIp("128.148.1.135") + .setUserEmail("billy_jones_301@email.com") + .setVerificationPhoneNumber("+12345678901") .setApp(new App() .setAppName("Calculator") .setAppVersion("3.2.7") @@ -70,8 +75,8 @@ public void testUpdatePassword() throws Exception { .setDeviceUniqueId("A3D261E4-DE0A-470B-9E4A-720F3D3D22E6") .setOperatingSystem("iOS")); - SiftRequest request = client.buildRequest(fieldSet); - SiftResponse siftResponse = request.send(); + SiftRequest request = client.buildRequest(fieldSet); + SiftResponse siftResponse = request.send(); //Verify the request RecordedRequest request1 = server.takeRequest(); @@ -82,6 +87,7 @@ public void testUpdatePassword() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); server.shutdown(); From 1035e7da00da8ad507855cac97c1c3eb53a0f79b Mon Sep 17 00:00:00 2001 From: Artem Dvornichenko Date: Thu, 29 Jun 2023 13:22:38 +0300 Subject: [PATCH 03/10] API-7197: Moved $user_email field definition to field set constants --- src/main/java/com/siftscience/FieldSet.java | 1 + src/main/java/com/siftscience/model/AddItemToCartFieldSet.java | 2 +- src/main/java/com/siftscience/model/AddPromotionFieldSet.java | 2 +- src/main/java/com/siftscience/model/BaseAccountFieldSet.java | 2 +- src/main/java/com/siftscience/model/BaseOrderFieldSet.java | 2 +- src/main/java/com/siftscience/model/ContentStatusFieldSet.java | 2 +- src/main/java/com/siftscience/model/CustomEventFieldSet.java | 2 +- src/main/java/com/siftscience/model/FlagContentFieldSet.java | 2 +- src/main/java/com/siftscience/model/LoginFieldSet.java | 2 +- .../java/com/siftscience/model/RemoveItemFromCartFieldSet.java | 2 +- src/main/java/com/siftscience/model/TransactionFieldSet.java | 2 +- src/main/java/com/siftscience/model/UpdatePasswordFieldSet.java | 2 +- 12 files changed, 12 insertions(+), 11 deletions(-) diff --git a/src/main/java/com/siftscience/FieldSet.java b/src/main/java/com/siftscience/FieldSet.java index 0c361bb..bc88ef8 100644 --- a/src/main/java/com/siftscience/FieldSet.java +++ b/src/main/java/com/siftscience/FieldSet.java @@ -36,6 +36,7 @@ public abstract class FieldSet> { public static final String TIME = "$time"; public static final String IS_BAD = "$is_bad"; public static final String ABUSE_TYPE = "$abuse_type"; + public static final String USER_EMAIL = "$user_email"; public static final String VERIFICATION_PHONE_NUMBER = "$verification_phone_number"; // Serialization happens in two stages. First, the object is serialized with `defaultGson` diff --git a/src/main/java/com/siftscience/model/AddItemToCartFieldSet.java b/src/main/java/com/siftscience/model/AddItemToCartFieldSet.java index eed3032..5879004 100644 --- a/src/main/java/com/siftscience/model/AddItemToCartFieldSet.java +++ b/src/main/java/com/siftscience/model/AddItemToCartFieldSet.java @@ -9,7 +9,7 @@ public static AddItemToCartFieldSet fromJson(String json) { } @Expose @SerializedName("$item") private Item item; - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override diff --git a/src/main/java/com/siftscience/model/AddPromotionFieldSet.java b/src/main/java/com/siftscience/model/AddPromotionFieldSet.java index a22e1ad..83155b9 100644 --- a/src/main/java/com/siftscience/model/AddPromotionFieldSet.java +++ b/src/main/java/com/siftscience/model/AddPromotionFieldSet.java @@ -11,7 +11,7 @@ public static AddPromotionFieldSet fromJson(String json) { } @Expose @SerializedName("$promotions") private List promotions; - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override diff --git a/src/main/java/com/siftscience/model/BaseAccountFieldSet.java b/src/main/java/com/siftscience/model/BaseAccountFieldSet.java index 392518e..9c42907 100644 --- a/src/main/java/com/siftscience/model/BaseAccountFieldSet.java +++ b/src/main/java/com/siftscience/model/BaseAccountFieldSet.java @@ -7,7 +7,7 @@ public abstract class BaseAccountFieldSet> extends BaseAppBrowserSiteBrandFieldSet { - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName("$name") private String name; @Expose @SerializedName("$phone") private String phone; @Expose @SerializedName("$referrer_user_id") private String referrerUserId; diff --git a/src/main/java/com/siftscience/model/BaseOrderFieldSet.java b/src/main/java/com/siftscience/model/BaseOrderFieldSet.java index d12e556..9bfebde 100644 --- a/src/main/java/com/siftscience/model/BaseOrderFieldSet.java +++ b/src/main/java/com/siftscience/model/BaseOrderFieldSet.java @@ -8,7 +8,7 @@ public abstract class BaseOrderFieldSet> extends BaseAppBrowserSiteBrandFieldSet { @Expose @SerializedName("$order_id") private String orderId; - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName("$amount") private Long amount; @Expose @SerializedName("$currency_code") private String currencyCode; @Expose @SerializedName("$billing_address") private Address billingAddress; diff --git a/src/main/java/com/siftscience/model/ContentStatusFieldSet.java b/src/main/java/com/siftscience/model/ContentStatusFieldSet.java index 26a160c..f7f447e 100644 --- a/src/main/java/com/siftscience/model/ContentStatusFieldSet.java +++ b/src/main/java/com/siftscience/model/ContentStatusFieldSet.java @@ -10,7 +10,7 @@ public static ContentStatusFieldSet fromJson(String json) { @Expose @SerializedName("$content_id") private String contentId; @Expose @SerializedName("$status") private String status; - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override diff --git a/src/main/java/com/siftscience/model/CustomEventFieldSet.java b/src/main/java/com/siftscience/model/CustomEventFieldSet.java index e10dae2..1f89ba7 100644 --- a/src/main/java/com/siftscience/model/CustomEventFieldSet.java +++ b/src/main/java/com/siftscience/model/CustomEventFieldSet.java @@ -9,7 +9,7 @@ public static CustomEventFieldSet fromJson(String json) { } @Expose @SerializedName(EVENT_TYPE) private String eventType; - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName("$name") private String name; @Expose @SerializedName("$phone") private String phone; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; diff --git a/src/main/java/com/siftscience/model/FlagContentFieldSet.java b/src/main/java/com/siftscience/model/FlagContentFieldSet.java index afa8559..da3c9be 100644 --- a/src/main/java/com/siftscience/model/FlagContentFieldSet.java +++ b/src/main/java/com/siftscience/model/FlagContentFieldSet.java @@ -10,7 +10,7 @@ public static FlagContentFieldSet fromJson(String json) { @Expose @SerializedName("$content_id") private String contentId; @Expose @SerializedName("$flagged_by") private String flaggedBy; - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override diff --git a/src/main/java/com/siftscience/model/LoginFieldSet.java b/src/main/java/com/siftscience/model/LoginFieldSet.java index f6bfa1c..01d16df 100644 --- a/src/main/java/com/siftscience/model/LoginFieldSet.java +++ b/src/main/java/com/siftscience/model/LoginFieldSet.java @@ -15,7 +15,7 @@ public static LoginFieldSet fromJson(String json) { @Expose @SerializedName("$username") private String username; @Expose @SerializedName("$social_sign_on_type") private String socialSignOnType; @Expose @SerializedName("$account_types") private List accountTypes; - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override diff --git a/src/main/java/com/siftscience/model/RemoveItemFromCartFieldSet.java b/src/main/java/com/siftscience/model/RemoveItemFromCartFieldSet.java index 290204e..8916ced 100644 --- a/src/main/java/com/siftscience/model/RemoveItemFromCartFieldSet.java +++ b/src/main/java/com/siftscience/model/RemoveItemFromCartFieldSet.java @@ -9,7 +9,7 @@ public static RemoveItemFromCartFieldSet fromJson(String json) { } @Expose @SerializedName("$item") private Item item; - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override diff --git a/src/main/java/com/siftscience/model/TransactionFieldSet.java b/src/main/java/com/siftscience/model/TransactionFieldSet.java index 3b376cd..a5c3f48 100644 --- a/src/main/java/com/siftscience/model/TransactionFieldSet.java +++ b/src/main/java/com/siftscience/model/TransactionFieldSet.java @@ -8,7 +8,7 @@ public class TransactionFieldSet extends BaseAppBrowserSiteBrandFieldSet { @Expose @SerializedName("$amount") private Long amount; @Expose @SerializedName("$currency_code") private String currencyCode; - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName("$transaction_type") private String transactionType; @Expose @SerializedName("$transaction_status") private String transactionStatus; @Expose @SerializedName("$order_id") private String orderId; diff --git a/src/main/java/com/siftscience/model/UpdatePasswordFieldSet.java b/src/main/java/com/siftscience/model/UpdatePasswordFieldSet.java index f4eab23..abaafa4 100644 --- a/src/main/java/com/siftscience/model/UpdatePasswordFieldSet.java +++ b/src/main/java/com/siftscience/model/UpdatePasswordFieldSet.java @@ -10,7 +10,7 @@ public static UpdatePasswordFieldSet fromJson(String json) { @Expose @SerializedName("$reason") private String reason; @Expose @SerializedName("$status") private String status; - @Expose @SerializedName("$user_email") private String userEmail; + @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @Override From efb3be4b5a5042ca421b227907ca78b9dc9a8010 Mon Sep 17 00:00:00 2001 From: Artem Dvornichenko Date: Thu, 29 Jun 2023 13:56:47 +0300 Subject: [PATCH 04/10] API-7197: Added support for $shipping_carrier and $shipping_tracking_numbers fields to $create_order and $update_order events --- .../siftscience/model/BaseOrderFieldSet.java | 20 ++++++++++++++ .../com/siftscience/UpdateOrderEventTest.java | 27 +++++++++++++++---- 2 files changed, 42 insertions(+), 5 deletions(-) diff --git a/src/main/java/com/siftscience/model/BaseOrderFieldSet.java b/src/main/java/com/siftscience/model/BaseOrderFieldSet.java index 9bfebde..10abbb7 100644 --- a/src/main/java/com/siftscience/model/BaseOrderFieldSet.java +++ b/src/main/java/com/siftscience/model/BaseOrderFieldSet.java @@ -19,6 +19,8 @@ public abstract class BaseOrderFieldSet> @Expose @SerializedName("$seller_user_id") private String sellerUserId; @Expose @SerializedName("$promotions") private List promotions; @Expose @SerializedName("$shipping_method") private String shippingMethod; + @Expose @SerializedName("shipping_carrier") private String shippingCarrier; + @Expose @SerializedName("shipping_tracking_numbers") private List shippingTrackingNumbers; @Expose @SerializedName("$bookings") private List bookings; @Expose @SerializedName("$ordered_from") private OrderedFrom orderedFrom; @Expose @SerializedName("$merchant_profile") private MerchantProfile merchantProfile; @@ -146,6 +148,24 @@ public T setShippingMethod(String shippingMethod) { return (T) this; } + public String getShippingCarrier() { + return shippingCarrier; + } + + public T setShippingCarrier(String shippingCarrier) { + this.shippingCarrier = shippingCarrier; + return (T) this; + } + + public List getShippingTrackingNumbers() { + return shippingTrackingNumbers; + } + + public T setShippingTrackingNumbers(List shippingTrackingNumbers) { + this.shippingTrackingNumbers = shippingTrackingNumbers; + return (T) this; + } + public OrderedFrom getOrderedFrom() { return orderedFrom; } diff --git a/src/test/java/com/siftscience/UpdateOrderEventTest.java b/src/test/java/com/siftscience/UpdateOrderEventTest.java index 50ec55b..f6edf7a 100644 --- a/src/test/java/com/siftscience/UpdateOrderEventTest.java +++ b/src/test/java/com/siftscience/UpdateOrderEventTest.java @@ -3,10 +3,12 @@ import static java.net.HttpURLConnection.HTTP_OK; import java.io.IOException; import java.util.ArrayList; +import java.util.Arrays; import java.util.List; import com.siftscience.model.Booking; import com.siftscience.model.DigitalOrder; +import com.siftscience.model.EventResponseBody; import com.siftscience.model.Item; import com.siftscience.model.PaymentMethod; import com.siftscience.model.Promotion; @@ -67,6 +69,8 @@ public void testUpdateOrderEventWithBookings() throws JSONException, IOException " },\n" + " \"$expedited_shipping\" : true,\n" + " \"$shipping_method\" : \"$physical\",\n" + + " \"shipping_carrier\" : \"The Best Carrier\",\n" + + " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$bookings\": [\n" + " {\n" + " \"$booking_type\": \"$flight\",\n" + @@ -182,7 +186,7 @@ public void testUpdateOrderEventWithBookings() throws JSONException, IOException promotionList.add(TestUtils.samplePromotion1()); // Build and execute the request against the mock server. - SiftRequest request = client.buildRequest( + SiftRequest request = client.buildRequest( new UpdateOrderFieldSet() .setUserId("billy_jones_301") .setSessionId("gigtleqddo84l8cm15qe4il") @@ -195,6 +199,8 @@ public void testUpdateOrderEventWithBookings() throws JSONException, IOException .setShippingAddress(TestUtils.sampleAddress2()) .setExpeditedShipping(true) .setShippingMethod("$physical") + .setShippingCarrier("The Best Carrier") + .setShippingTrackingNumbers(Arrays.asList("track-1", "track-2")) .setBookings(bookingList) .setSellerUserId("slinkys_emporium") .setPromotions(promotionList) @@ -203,7 +209,7 @@ public void testUpdateOrderEventWithBookings() throws JSONException, IOException .setCustomField("shipping_choice", "FedEx Ground Courier") .setCustomField("is_first_time_buyer", false)); - SiftResponse siftResponse = request.send(); + SiftResponse siftResponse = request.send(); // Verify the request. RecordedRequest request1 = server.takeRequest(); @@ -214,6 +220,7 @@ public void testUpdateOrderEventWithBookings() throws JSONException, IOException // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); @@ -264,6 +271,8 @@ public void testUpdateOrderEventWithItems() throws JSONException, IOException, I " },\n" + " \"$expedited_shipping\" : true,\n" + " \"$shipping_method\" : \"$physical\",\n" + + " \"shipping_carrier\" : \"The Best Carrier\",\n" + + " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$items\" : [\n" + " {\n" + " \"$item_id\" : \"12344321\",\n" + @@ -349,7 +358,7 @@ public void testUpdateOrderEventWithItems() throws JSONException, IOException, I // Build and execute the request against the mock server. - SiftRequest request = client.buildRequest( + SiftRequest request = client.buildRequest( new UpdateOrderFieldSet() .setUserId("billy_jones_301") .setSessionId("gigtleqddo84l8cm15qe4il") @@ -362,6 +371,8 @@ public void testUpdateOrderEventWithItems() throws JSONException, IOException, I .setShippingAddress(TestUtils.sampleAddress2()) .setExpeditedShipping(true) .setShippingMethod("$physical") + .setShippingCarrier("The Best Carrier") + .setShippingTrackingNumbers(Arrays.asList("track-1", "track-2")) .setItems(itemList) .setSellerUserId("slinkys_emporium") .setPromotions(promotionList) @@ -369,7 +380,7 @@ public void testUpdateOrderEventWithItems() throws JSONException, IOException, I .setCustomField("coupon_code", "dollarMadness") .setCustomField("shipping_choice", "FedEx Ground Courier") .setCustomField("is_first_time_buyer", false)); - SiftResponse siftResponse = request.send(); + SiftResponse siftResponse = request.send(); // Verify the request. RecordedRequest request1 = server.takeRequest(); @@ -380,6 +391,7 @@ public void testUpdateOrderEventWithItems() throws JSONException, IOException, I // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); @@ -433,6 +445,8 @@ public void testUpdateOrderEventWithSiteBrandOrderedFromFields() " },\n" + " \"$expedited_shipping\": true,\n" + " \"$shipping_method\": \"$physical\",\n" + + " \"shipping_carrier\" : \"The Best Carrier\",\n" + + " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$ordered_from\" : {\n" + " \"$store_id\" : \"123\",\n" + " \"$store_address\" : {\n" + @@ -488,7 +502,9 @@ public void testUpdateOrderEventWithSiteBrandOrderedFromFields() .setPaymentMethods(paymentMethodList) .setShippingAddress(TestUtils.sampleAddress2()) .setExpeditedShipping(true) - .setShippingMethod("$physical")); + .setShippingMethod("$physical") + .setShippingCarrier("The Best Carrier") + .setShippingTrackingNumbers(Arrays.asList("track-1", "track-2"))); EventResponse siftResponse = request.send(); @@ -501,6 +517,7 @@ public void testUpdateOrderEventWithSiteBrandOrderedFromFields() // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); From 0097b7dd946334d1a8c9a6ae34cb7cc96220bc5c Mon Sep 17 00:00:00 2001 From: Artem Dvornichenko Date: Thu, 29 Jun 2023 14:19:07 +0300 Subject: [PATCH 05/10] API-7197: Update unit tests for $create_order event --- .../com/siftscience/CreateOrderEventTest.java | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/src/test/java/com/siftscience/CreateOrderEventTest.java b/src/test/java/com/siftscience/CreateOrderEventTest.java index 9272867..74f88f0 100644 --- a/src/test/java/com/siftscience/CreateOrderEventTest.java +++ b/src/test/java/com/siftscience/CreateOrderEventTest.java @@ -3,6 +3,7 @@ import static java.net.HttpURLConnection.HTTP_OK; import java.io.IOException; import java.util.ArrayList; +import java.util.Arrays; import java.util.List; import com.siftscience.model.Booking; @@ -67,6 +68,8 @@ public void testCreateOrderEventWithBookings() throws JSONException, IOException " },\n" + " \"$expedited_shipping\" : true,\n" + " \"$shipping_method\" : \"$physical\",\n" + + " \"shipping_carrier\" : \"The Best Carrier\",\n" + + " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$bookings\": [\n" + " {\n" + " \"$booking_type\": \"$flight\",\n" + @@ -196,6 +199,8 @@ public void testCreateOrderEventWithBookings() throws JSONException, IOException .setShippingAddress(TestUtils.sampleAddress2()) .setExpeditedShipping(true) .setShippingMethod("$physical") + .setShippingCarrier("The Best Carrier") + .setShippingTrackingNumbers(Arrays.asList("track-1", "track-2")) .setBookings(bookingList) .setSellerUserId("slinkys_emporium") .setPromotions(promotionList) @@ -216,6 +221,7 @@ public void testCreateOrderEventWithBookings() throws JSONException, IOException // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); @@ -267,6 +273,8 @@ public void testCreateOrderEventWithItems() throws JSONException, IOException, " },\n" + " \"$expedited_shipping\" : true,\n" + " \"$shipping_method\" : \"$physical\",\n" + + " \"shipping_carrier\" : \"The Best Carrier\",\n" + + " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$items\" : [\n" + " {\n" + " \"$item_id\" : \"12344321\",\n" + @@ -365,6 +373,8 @@ public void testCreateOrderEventWithItems() throws JSONException, IOException, .setShippingAddress(TestUtils.sampleAddress2()) .setExpeditedShipping(true) .setShippingMethod("$physical") + .setShippingCarrier("The Best Carrier") + .setShippingTrackingNumbers(Arrays.asList("track-1", "track-2")) .setItems(itemList) .setSellerUserId("slinkys_emporium") .setPromotions(promotionList) @@ -384,6 +394,7 @@ public void testCreateOrderEventWithItems() throws JSONException, IOException, // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); @@ -437,6 +448,8 @@ public void testCreateOrderEventwithSiteBrandOrderedFromFields() throws " },\n" + " \"$expedited_shipping\": true,\n" + " \"$shipping_method\": \"$physical\",\n" + + " \"shipping_carrier\" : \"The Best Carrier\",\n" + + " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$ordered_from\" : {\n" + " \"$store_id\" : \"123\",\n" + " \"$store_address\" : {\n" + @@ -494,6 +507,8 @@ public void testCreateOrderEventwithSiteBrandOrderedFromFields() throws .setShippingAddress(TestUtils.sampleAddress2()) .setExpeditedShipping(true) .setShippingMethod("$physical") + .setShippingCarrier("The Best Carrier") + .setShippingTrackingNumbers(Arrays.asList("track-1", "track-2")) .setVerificationPhoneNumber("+12345678901")); EventResponse siftResponse = request.send(); @@ -507,6 +522,7 @@ public void testCreateOrderEventwithSiteBrandOrderedFromFields() throws // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); + Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); From 893ef6554a97af540e655480ec886b914c975996 Mon Sep 17 00:00:00 2001 From: Artem Dvornichenko Date: Thu, 29 Jun 2023 15:48:31 +0300 Subject: [PATCH 06/10] API-7197: Added support for $reason field to $flag_content event --- CHANGES.MD | 2 +- .../model/FlagContentFieldSet.java | 32 +++++++++++++++++++ .../com/siftscience/FlagContentEventTest.java | 2 ++ 3 files changed, 35 insertions(+), 1 deletion(-) diff --git a/CHANGES.MD b/CHANGES.MD index c5bf05c..4d1d339 100644 --- a/CHANGES.MD +++ b/CHANGES.MD @@ -2,7 +2,7 @@ ================= - Add support for `$user_email` field to `$add_item_to_cart`, `$add_promotion`, `$content_status`, `$flag_content`, `$remove_item_from_cart` and `$update_password` events - Add support for `$shipping_carrier` and `$shipping_tracking_numbers` fields to `$create_order` and `$update_order` events -- Add support for `reason` field to `flag_content` event +- Add support for `$reason` field to `$flag_content` event 3.10.0 (2023-06-06) ================= diff --git a/src/main/java/com/siftscience/model/FlagContentFieldSet.java b/src/main/java/com/siftscience/model/FlagContentFieldSet.java index da3c9be..a348505 100644 --- a/src/main/java/com/siftscience/model/FlagContentFieldSet.java +++ b/src/main/java/com/siftscience/model/FlagContentFieldSet.java @@ -8,8 +8,31 @@ public static FlagContentFieldSet fromJson(String json) { return gson.fromJson(json, FlagContentFieldSet.class); } + public enum FlagContentReason { + TOXIC("$toxic"), + IRRELEVANT("$irrelevant"), + COMMERCIAL("$commercial"), + PHISHING("$phishing"), + PRIVATE("$private"), + SCAM("$scam"), + COPYRIGHT("$copyright"), + OTHER("$other"); + + public final String value; + + FlagContentReason(String value) { + this.value = value; + } + + @Override + public String toString() { + return value; + } + } + @Expose @SerializedName("$content_id") private String contentId; @Expose @SerializedName("$flagged_by") private String flaggedBy; + @Expose @SerializedName("$reason") private String reason; @Expose @SerializedName(USER_EMAIL) private String userEmail; @Expose @SerializedName(VERIFICATION_PHONE_NUMBER) private String verificationPhoneNumber; @@ -36,6 +59,15 @@ public FlagContentFieldSet setFlaggedBy(String flaggedBy) { return this; } + public String getReason() { + return reason; + } + + public FlagContentFieldSet setReason(FlagContentReason reason) { + this.reason = reason.value; + return this; + } + public String getUserEmail() { return userEmail; } diff --git a/src/test/java/com/siftscience/FlagContentEventTest.java b/src/test/java/com/siftscience/FlagContentEventTest.java index 81bb917..300db0c 100644 --- a/src/test/java/com/siftscience/FlagContentEventTest.java +++ b/src/test/java/com/siftscience/FlagContentEventTest.java @@ -22,6 +22,7 @@ public void testFlagContent() throws Exception { " \"$content_id\" : \"9671500641\",\n" + "\n" + " \"$flagged_by\" : \"jamieli89\",\n" + + " \"$reason\" : \"$toxic\",\n" + " \"$user_email\" : \"billy_jones_301@email.com\",\n" + " \"$verification_phone_number\" : \"+12345678901\"\n" + "}"; @@ -51,6 +52,7 @@ public void testFlagContent() throws Exception { .setUserId("billy_jones_301") .setContentId("9671500641") .setFlaggedBy("jamieli89") + .setReason(FlagContentFieldSet.FlagContentReason.TOXIC) .setUserEmail("billy_jones_301@email.com") .setVerificationPhoneNumber("+12345678901")); From 4d5229079afe99f01494c941af7eda36cda83244 Mon Sep 17 00:00:00 2001 From: Artem Dvornichenko Date: Fri, 30 Jun 2023 12:50:20 +0300 Subject: [PATCH 07/10] API-7197: Fix shipping fields naming --- src/main/java/com/siftscience/model/BaseOrderFieldSet.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/siftscience/model/BaseOrderFieldSet.java b/src/main/java/com/siftscience/model/BaseOrderFieldSet.java index 10abbb7..98faefb 100644 --- a/src/main/java/com/siftscience/model/BaseOrderFieldSet.java +++ b/src/main/java/com/siftscience/model/BaseOrderFieldSet.java @@ -19,8 +19,8 @@ public abstract class BaseOrderFieldSet> @Expose @SerializedName("$seller_user_id") private String sellerUserId; @Expose @SerializedName("$promotions") private List promotions; @Expose @SerializedName("$shipping_method") private String shippingMethod; - @Expose @SerializedName("shipping_carrier") private String shippingCarrier; - @Expose @SerializedName("shipping_tracking_numbers") private List shippingTrackingNumbers; + @Expose @SerializedName("$shipping_carrier") private String shippingCarrier; + @Expose @SerializedName("$shipping_tracking_numbers") private List shippingTrackingNumbers; @Expose @SerializedName("$bookings") private List bookings; @Expose @SerializedName("$ordered_from") private OrderedFrom orderedFrom; @Expose @SerializedName("$merchant_profile") private MerchantProfile merchantProfile; From 072653dbc238148b33575e96ae15ddb3f7cec933 Mon Sep 17 00:00:00 2001 From: Artem Dvornichenko Date: Fri, 30 Jun 2023 12:58:15 +0300 Subject: [PATCH 08/10] API-7197: Fix unit tests --- .../java/com/siftscience/CreateOrderEventTest.java | 12 ++++++------ .../java/com/siftscience/UpdateOrderEventTest.java | 12 ++++++------ 2 files changed, 12 insertions(+), 12 deletions(-) diff --git a/src/test/java/com/siftscience/CreateOrderEventTest.java b/src/test/java/com/siftscience/CreateOrderEventTest.java index 74f88f0..a067432 100644 --- a/src/test/java/com/siftscience/CreateOrderEventTest.java +++ b/src/test/java/com/siftscience/CreateOrderEventTest.java @@ -68,8 +68,8 @@ public void testCreateOrderEventWithBookings() throws JSONException, IOException " },\n" + " \"$expedited_shipping\" : true,\n" + " \"$shipping_method\" : \"$physical\",\n" + - " \"shipping_carrier\" : \"The Best Carrier\",\n" + - " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + + " \"$shipping_carrier\" : \"The Best Carrier\",\n" + + " \"$shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$bookings\": [\n" + " {\n" + " \"$booking_type\": \"$flight\",\n" + @@ -273,8 +273,8 @@ public void testCreateOrderEventWithItems() throws JSONException, IOException, " },\n" + " \"$expedited_shipping\" : true,\n" + " \"$shipping_method\" : \"$physical\",\n" + - " \"shipping_carrier\" : \"The Best Carrier\",\n" + - " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + + " \"$shipping_carrier\" : \"The Best Carrier\",\n" + + " \"$shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$items\" : [\n" + " {\n" + " \"$item_id\" : \"12344321\",\n" + @@ -448,8 +448,8 @@ public void testCreateOrderEventwithSiteBrandOrderedFromFields() throws " },\n" + " \"$expedited_shipping\": true,\n" + " \"$shipping_method\": \"$physical\",\n" + - " \"shipping_carrier\" : \"The Best Carrier\",\n" + - " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + + " \"$shipping_carrier\" : \"The Best Carrier\",\n" + + " \"$shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$ordered_from\" : {\n" + " \"$store_id\" : \"123\",\n" + " \"$store_address\" : {\n" + diff --git a/src/test/java/com/siftscience/UpdateOrderEventTest.java b/src/test/java/com/siftscience/UpdateOrderEventTest.java index f6edf7a..f8e34ae 100644 --- a/src/test/java/com/siftscience/UpdateOrderEventTest.java +++ b/src/test/java/com/siftscience/UpdateOrderEventTest.java @@ -69,8 +69,8 @@ public void testUpdateOrderEventWithBookings() throws JSONException, IOException " },\n" + " \"$expedited_shipping\" : true,\n" + " \"$shipping_method\" : \"$physical\",\n" + - " \"shipping_carrier\" : \"The Best Carrier\",\n" + - " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + + " \"$shipping_carrier\" : \"The Best Carrier\",\n" + + " \"$shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$bookings\": [\n" + " {\n" + " \"$booking_type\": \"$flight\",\n" + @@ -271,8 +271,8 @@ public void testUpdateOrderEventWithItems() throws JSONException, IOException, I " },\n" + " \"$expedited_shipping\" : true,\n" + " \"$shipping_method\" : \"$physical\",\n" + - " \"shipping_carrier\" : \"The Best Carrier\",\n" + - " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + + " \"$shipping_carrier\" : \"The Best Carrier\",\n" + + " \"$shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$items\" : [\n" + " {\n" + " \"$item_id\" : \"12344321\",\n" + @@ -445,8 +445,8 @@ public void testUpdateOrderEventWithSiteBrandOrderedFromFields() " },\n" + " \"$expedited_shipping\": true,\n" + " \"$shipping_method\": \"$physical\",\n" + - " \"shipping_carrier\" : \"The Best Carrier\",\n" + - " \"shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + + " \"$shipping_carrier\" : \"The Best Carrier\",\n" + + " \"$shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + " \"$ordered_from\" : {\n" + " \"$store_id\" : \"123\",\n" + " \"$store_address\" : {\n" + From 10c5c9d1620ea49d9fab0df53be9c677911989bc Mon Sep 17 00:00:00 2001 From: Artem Dvornichenko Date: Thu, 6 Jul 2023 12:16:06 +0300 Subject: [PATCH 09/10] API-7197: Add unit tests for null shipping carrier / tracking number in create/update order event --- .../siftscience/AddItemToCartEventTest.java | 2 +- .../siftscience/AddPromotionEventTest.java | 2 +- .../siftscience/ContentStatusEventTest.java | 2 +- .../com/siftscience/CreateOrderEventTest.java | 340 +++++++++++++++++- .../com/siftscience/FlagContentEventTest.java | 2 +- .../RemoveItemFromCartEventTest.java | 2 +- .../com/siftscience/UpdateOrderEventTest.java | 340 +++++++++++++++++- .../siftscience/UpdatePasswordEventTest.java | 2 +- 8 files changed, 680 insertions(+), 12 deletions(-) diff --git a/src/test/java/com/siftscience/AddItemToCartEventTest.java b/src/test/java/com/siftscience/AddItemToCartEventTest.java index 002fb16..6cec72a 100644 --- a/src/test/java/com/siftscience/AddItemToCartEventTest.java +++ b/src/test/java/com/siftscience/AddItemToCartEventTest.java @@ -76,8 +76,8 @@ public void testAddItemToCart() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/AddPromotionEventTest.java b/src/test/java/com/siftscience/AddPromotionEventTest.java index fd921c5..b1c3fdd 100644 --- a/src/test/java/com/siftscience/AddPromotionEventTest.java +++ b/src/test/java/com/siftscience/AddPromotionEventTest.java @@ -79,8 +79,8 @@ public void testAddPromotion() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/ContentStatusEventTest.java b/src/test/java/com/siftscience/ContentStatusEventTest.java index f5f4eb4..431d5db 100644 --- a/src/test/java/com/siftscience/ContentStatusEventTest.java +++ b/src/test/java/com/siftscience/ContentStatusEventTest.java @@ -63,8 +63,8 @@ public void testContentStatus() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/CreateOrderEventTest.java b/src/test/java/com/siftscience/CreateOrderEventTest.java index a067432..c83f3bf 100644 --- a/src/test/java/com/siftscience/CreateOrderEventTest.java +++ b/src/test/java/com/siftscience/CreateOrderEventTest.java @@ -1,11 +1,13 @@ package com.siftscience; +import static java.net.HttpURLConnection.HTTP_BAD_REQUEST; import static java.net.HttpURLConnection.HTTP_OK; import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; import java.util.List; +import com.siftscience.exception.InvalidFieldException; import com.siftscience.model.Booking; import com.siftscience.model.CreateOrderFieldSet; import com.siftscience.model.DigitalOrder; @@ -220,14 +222,346 @@ public void testCreateOrderEventWithBookings() throws JSONException, IOException // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); server.shutdown(); } + @Test + public void testCreateOrderEventWithBookingsShippingCarrierIsNull() + throws IOException, InterruptedException { + + // The expected JSON payload of the request. + String expectedRequestBody = "{\n" + + " \"$type\" : \"$create_order\",\n" + + " \"$api_key\" : \"YOUR_API_KEY\",\n" + + " \"$user_id\" : \"billy_jones_301\",\n" + + "\n" + + " \"$session_id\" : \"gigtleqddo84l8cm15qe4il\",\n" + + " \"$order_id\" : \"ORDER-28168441\",\n" + + " \"$user_email\" : \"bill@gmail.com\",\n" + + " \"$amount\" : 115940000,\n" + + " \"$currency_code\" : \"USD\",\n" + + " \"$billing_address\" : {\n" + + " \"$name\" : \"Bill Jones\",\n" + + " \"$phone\" : \"1-415-555-6041\",\n" + + " \"$address_1\" : \"2100 Main Street\",\n" + + " \"$address_2\" : \"Apt 3B\",\n" + + " \"$city\" : \"New London\",\n" + + " \"$region\" : \"New Hampshire\",\n" + + " \"$country\" : \"US\",\n" + + " \"$zipcode\" : \"03257\"\n" + + " },\n" + + " \"$payment_methods\" : [\n" + + " {\n" + + " \"$payment_type\" : \"$credit_card\",\n" + + " \"$payment_gateway\" : \"$braintree\",\n" + + " \"$card_bin\" : \"542486\",\n" + + " \"$card_last4\" : \"4444\"\n" + + " }\n" + + " ],\n" + + " \"$shipping_address\" : {\n" + + " \"$name\" : \"Bill Jones\",\n" + + " \"$phone\" : \"1-415-555-6041\",\n" + + " \"$address_1\" : \"2100 Main Street\",\n" + + " \"$address_2\" : \"Apt 3B\",\n" + + " \"$city\" : \"New London\",\n" + + " \"$region\" : \"New Hampshire\",\n" + + " \"$country\" : \"US\",\n" + + " \"$zipcode\" : \"03257\"\n" + + " },\n" + + " \"$expedited_shipping\" : true,\n" + + " \"$shipping_method\" : \"$physical\",\n" + + " \"$shipping_carrier\" : null,\n" + + " \"$shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + + " \"$bookings\": [\n" + + " {\n" + + " \"$booking_type\": \"$flight\",\n" + + " \"$title\": \"SFO - LAS, 2 Adults\",\n" + + " \"$start_time\": 12038412903,\n" + + " \"$end_time\": 12048412903,\n" + + " \"$guests\": [\n" + + " {\n" + + " \"$name\": \"John Doe\",\n" + + " \"$birth_date\": \"1985-01-19\",\n" + + " \"$loyalty_program\": \"skymiles\",\n" + + " \"$loyalty_program_id\": \"PSOV34DF\",\n" + + " \"$phone\": \"1-415-555-6040\",\n" + + " \"$email\": \"jdoe@domain.com\"\n" + + " },\n" + + " {\n" + + " \"$name\": \"Jane Doe\"\n" + + " }\n" + + " ],\n" + + " \"$segments\": [\n" + + " {\n" + + " \"$departure_address\":\n" + + " {\n" + + " \"$name\": \"Bill Jones\",\n" + + " \"$phone\": \"1-415-555-6040\",\n" + + " \"$address_1\": \"2100 Main Street\",\n" + + " \"$address_2\": \"Apt 3B\",\n" + + " \"$city\": \"New London\",\n" + + " \"$region\": \"New Hampshire\",\n" + + " \"$country\": \"US\",\n" + + " \"$zipcode\": \"03257\"\n" + + " },\n" + + " \"$arrival_address\":\n" + + " {\n" + + " \"$name\": \"Bill Jones\",\n" + + " \"$phone\": \"1-415-555-6041\",\n" + + " \"$address_1\": \"2100 Main Street\",\n" + + " \"$address_2\": \"Apt 3B\",\n" + + " \"$city\": \"New London\",\n" + + " \"$region\": \"New Hampshire\",\n" + + " \"$country\": \"US\",\n" + + " \"$zipcode\": \"03257\"\n" + + " },\n" + + " \"$start_time\": 2190121220,\n" + + " \"$end_time\": 2290122129,\n" + + " \"$vessel_number\": \"LH454\",\n" + + " \"$fare_class\": \"Premium Economy\",\n" + + " \"$departure_airport_code\": \"SFO\",\n" + + " \"$arrival_airport_code\": \"LAS\"\n" + + " }\n" + + " ],\n" + + " \"$price\": 49900000,\n" + + " \"$currency_code\": \"USD\",\n" + + " \"$quantity\": 1,\n" + + " \"$tags\": [\n" + + " \"team-123\",\n" + + " \"region-123\"\n" + + " ]\n" + + " }\n" + + " ],\n" + + "\n" + + "}"; + + // Start a new mock server and enqueue a mock response. + MockWebServer server = new MockWebServer(); + MockResponse response = new MockResponse(); + response.setResponseCode(HTTP_BAD_REQUEST); + response.setBody("{\n" + + " \"status\" : 53,\n" + + " \"error_message\" : \"Invalid field value(s) for fields: $.$shipping_carrier, $.$shipping_tracking_numbers. Please check the documentation for valid field values.\",\n" + + " \"time\" : 1327604222,\n" + + " \"request\" : \"" + TestUtils.unescapeJson(expectedRequestBody) + "\"\n" + + "}"); + server.enqueue(response); + server.start(); + + // Create a new client and link it to the mock server. + SiftClient client = new SiftClient("YOUR_API_KEY", "YOUR_ACCOUNT_ID", + new OkHttpClient.Builder() + .addInterceptor(OkHttpUtils.urlRewritingInterceptor(server)) + .build()); + + // Build the request body. + // Payment methods. + List paymentMethodList = new ArrayList<>(); + paymentMethodList.add(TestUtils.samplePaymentMethod1()); + + // Bookings + List bookingList = new ArrayList<>(); + bookingList.add(TestUtils.sampleBooking()); + + // Build and execute the request against the mock server. + EventRequest request = client.buildRequest( + new CreateOrderFieldSet() + .setUserId("billy_jones_301") + .setSessionId("gigtleqddo84l8cm15qe4il") + .setOrderId("ORDER-28168441") + .setUserEmail("bill@gmail.com") + .setAmount(115940000L) + .setCurrencyCode("USD") + .setBillingAddress(TestUtils.sampleAddress2()) + .setPaymentMethods(paymentMethodList) + .setShippingAddress(TestUtils.sampleAddress2()) + .setExpeditedShipping(true) + .setShippingMethod("$physical") + .setShippingCarrier(null) + .setShippingTrackingNumbers(Arrays.asList("track-1", "track-2")) + .setBookings(bookingList)); + + Assert.assertThrows(InvalidFieldException.class, request::send); + + // Verify the request. + RecordedRequest request1 = server.takeRequest(); + Assert.assertEquals("POST", request1.getMethod()); + Assert.assertEquals("/v205/events", request1.getPath()); + + server.shutdown(); + } + + @Test + public void testCreateOrderEventWithBookingsShippingTrackingNumberIsNull() + throws IOException, InterruptedException { + + // The expected JSON payload of the request. + String expectedRequestBody = "{\n" + + " \"$type\" : \"$create_order\",\n" + + " \"$api_key\" : \"YOUR_API_KEY\",\n" + + " \"$user_id\" : \"billy_jones_301\",\n" + + "\n" + + " \"$session_id\" : \"gigtleqddo84l8cm15qe4il\",\n" + + " \"$order_id\" : \"ORDER-28168441\",\n" + + " \"$user_email\" : \"bill@gmail.com\",\n" + + " \"$amount\" : 115940000,\n" + + " \"$currency_code\" : \"USD\",\n" + + " \"$billing_address\" : {\n" + + " \"$name\" : \"Bill Jones\",\n" + + " \"$phone\" : \"1-415-555-6041\",\n" + + " \"$address_1\" : \"2100 Main Street\",\n" + + " \"$address_2\" : \"Apt 3B\",\n" + + " \"$city\" : \"New London\",\n" + + " \"$region\" : \"New Hampshire\",\n" + + " \"$country\" : \"US\",\n" + + " \"$zipcode\" : \"03257\"\n" + + " },\n" + + " \"$payment_methods\" : [\n" + + " {\n" + + " \"$payment_type\" : \"$credit_card\",\n" + + " \"$payment_gateway\" : \"$braintree\",\n" + + " \"$card_bin\" : \"542486\",\n" + + " \"$card_last4\" : \"4444\"\n" + + " }\n" + + " ],\n" + + " \"$shipping_address\" : {\n" + + " \"$name\" : \"Bill Jones\",\n" + + " \"$phone\" : \"1-415-555-6041\",\n" + + " \"$address_1\" : \"2100 Main Street\",\n" + + " \"$address_2\" : \"Apt 3B\",\n" + + " \"$city\" : \"New London\",\n" + + " \"$region\" : \"New Hampshire\",\n" + + " \"$country\" : \"US\",\n" + + " \"$zipcode\" : \"03257\"\n" + + " },\n" + + " \"$expedited_shipping\" : true,\n" + + " \"$shipping_method\" : \"$physical\",\n" + + " \"$shipping_carrier\" : \"The Best Carrier\",\n" + + " \"$shipping_tracking_numbers\" : [null],\n" + + " \"$bookings\": [\n" + + " {\n" + + " \"$booking_type\": \"$flight\",\n" + + " \"$title\": \"SFO - LAS, 2 Adults\",\n" + + " \"$start_time\": 12038412903,\n" + + " \"$end_time\": 12048412903,\n" + + " \"$guests\": [\n" + + " {\n" + + " \"$name\": \"John Doe\",\n" + + " \"$birth_date\": \"1985-01-19\",\n" + + " \"$loyalty_program\": \"skymiles\",\n" + + " \"$loyalty_program_id\": \"PSOV34DF\",\n" + + " \"$phone\": \"1-415-555-6040\",\n" + + " \"$email\": \"jdoe@domain.com\"\n" + + " },\n" + + " {\n" + + " \"$name\": \"Jane Doe\"\n" + + " }\n" + + " ],\n" + + " \"$segments\": [\n" + + " {\n" + + " \"$departure_address\":\n" + + " {\n" + + " \"$name\": \"Bill Jones\",\n" + + " \"$phone\": \"1-415-555-6040\",\n" + + " \"$address_1\": \"2100 Main Street\",\n" + + " \"$address_2\": \"Apt 3B\",\n" + + " \"$city\": \"New London\",\n" + + " \"$region\": \"New Hampshire\",\n" + + " \"$country\": \"US\",\n" + + " \"$zipcode\": \"03257\"\n" + + " },\n" + + " \"$arrival_address\":\n" + + " {\n" + + " \"$name\": \"Bill Jones\",\n" + + " \"$phone\": \"1-415-555-6041\",\n" + + " \"$address_1\": \"2100 Main Street\",\n" + + " \"$address_2\": \"Apt 3B\",\n" + + " \"$city\": \"New London\",\n" + + " \"$region\": \"New Hampshire\",\n" + + " \"$country\": \"US\",\n" + + " \"$zipcode\": \"03257\"\n" + + " },\n" + + " \"$start_time\": 2190121220,\n" + + " \"$end_time\": 2290122129,\n" + + " \"$vessel_number\": \"LH454\",\n" + + " \"$fare_class\": \"Premium Economy\",\n" + + " \"$departure_airport_code\": \"SFO\",\n" + + " \"$arrival_airport_code\": \"LAS\"\n" + + " }\n" + + " ],\n" + + " \"$price\": 49900000,\n" + + " \"$currency_code\": \"USD\",\n" + + " \"$quantity\": 1,\n" + + " \"$tags\": [\n" + + " \"team-123\",\n" + + " \"region-123\"\n" + + " ]\n" + + " }\n" + + " ],\n" + + "\n" + + "}"; + + // Start a new mock server and enqueue a mock response. + MockWebServer server = new MockWebServer(); + MockResponse response = new MockResponse(); + response.setResponseCode(HTTP_BAD_REQUEST); + response.setBody("{\n" + + " \"status\" : 53,\n" + + " \"error_message\" : \"Invalid field value(s) for fields: $.$shipping_tracking_numbers[0]. Please check the documentation for valid field values.\",\n" + + " \"time\" : 1327604222,\n" + + " \"request\" : \"" + TestUtils.unescapeJson(expectedRequestBody) + "\"\n" + + "}"); + server.enqueue(response); + server.start(); + + // Create a new client and link it to the mock server. + SiftClient client = new SiftClient("YOUR_API_KEY", "YOUR_ACCOUNT_ID", + new OkHttpClient.Builder() + .addInterceptor(OkHttpUtils.urlRewritingInterceptor(server)) + .build()); + + // Build the request body. + // Payment methods. + List paymentMethodList = new ArrayList<>(); + paymentMethodList.add(TestUtils.samplePaymentMethod1()); + + // Bookings + List bookingList = new ArrayList<>(); + bookingList.add(TestUtils.sampleBooking()); + + // Build and execute the request against the mock server. + EventRequest request = client.buildRequest( + new CreateOrderFieldSet() + .setUserId("billy_jones_301") + .setSessionId("gigtleqddo84l8cm15qe4il") + .setOrderId("ORDER-28168441") + .setUserEmail("bill@gmail.com") + .setAmount(115940000L) + .setCurrencyCode("USD") + .setBillingAddress(TestUtils.sampleAddress2()) + .setPaymentMethods(paymentMethodList) + .setShippingAddress(TestUtils.sampleAddress2()) + .setExpeditedShipping(true) + .setShippingMethod("$physical") + .setShippingCarrier("The Best Carrier") + .setShippingTrackingNumbers(Arrays.asList((String) null)) + .setBookings(bookingList)); + + Assert.assertThrows(InvalidFieldException.class, request::send); + + // Verify the request. + RecordedRequest request1 = server.takeRequest(); + Assert.assertEquals("POST", request1.getMethod()); + Assert.assertEquals("/v205/events", request1.getPath()); + + server.shutdown(); + } + @Test public void testCreateOrderEventWithItems() throws JSONException, IOException, InterruptedException { @@ -393,8 +727,8 @@ public void testCreateOrderEventWithItems() throws JSONException, IOException, // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); @@ -521,8 +855,8 @@ public void testCreateOrderEventwithSiteBrandOrderedFromFields() throws // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/FlagContentEventTest.java b/src/test/java/com/siftscience/FlagContentEventTest.java index 300db0c..b09ca73 100644 --- a/src/test/java/com/siftscience/FlagContentEventTest.java +++ b/src/test/java/com/siftscience/FlagContentEventTest.java @@ -66,8 +66,8 @@ public void testFlagContent() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/RemoveItemFromCartEventTest.java b/src/test/java/com/siftscience/RemoveItemFromCartEventTest.java index c2fd457..5b294ea 100644 --- a/src/test/java/com/siftscience/RemoveItemFromCartEventTest.java +++ b/src/test/java/com/siftscience/RemoveItemFromCartEventTest.java @@ -75,8 +75,8 @@ public void testRemoveItemFromCart() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/UpdateOrderEventTest.java b/src/test/java/com/siftscience/UpdateOrderEventTest.java index f8e34ae..fea32d2 100644 --- a/src/test/java/com/siftscience/UpdateOrderEventTest.java +++ b/src/test/java/com/siftscience/UpdateOrderEventTest.java @@ -1,11 +1,13 @@ package com.siftscience; +import static java.net.HttpURLConnection.HTTP_BAD_REQUEST; import static java.net.HttpURLConnection.HTTP_OK; import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; import java.util.List; +import com.siftscience.exception.InvalidFieldException; import com.siftscience.model.Booking; import com.siftscience.model.DigitalOrder; import com.siftscience.model.EventResponseBody; @@ -219,14 +221,346 @@ public void testUpdateOrderEventWithBookings() throws JSONException, IOException // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); server.shutdown(); } + @Test + public void testUpdateOrderEventWithBookingsShippingCarrierIsNull() throws IOException, + InterruptedException { + + // The expected JSON payload of the request. + String expectedRequestBody = "{\n" + + " \"$type\" : \"$update_order\",\n" + + " \"$api_key\" : \"YOUR_API_KEY\",\n" + + " \"$user_id\" : \"billy_jones_301\",\n" + + "\n" + + " \"$session_id\" : \"gigtleqddo84l8cm15qe4il\",\n" + + " \"$order_id\" : \"ORDER-28168441\",\n" + + " \"$user_email\" : \"bill@gmail.com\",\n" + + " \"$amount\" : 115940000,\n" + + " \"$currency_code\" : \"USD\",\n" + + " \"$billing_address\" : {\n" + + " \"$name\" : \"Bill Jones\",\n" + + " \"$phone\" : \"1-415-555-6041\",\n" + + " \"$address_1\" : \"2100 Main Street\",\n" + + " \"$address_2\" : \"Apt 3B\",\n" + + " \"$city\" : \"New London\",\n" + + " \"$region\" : \"New Hampshire\",\n" + + " \"$country\" : \"US\",\n" + + " \"$zipcode\" : \"03257\"\n" + + " },\n" + + " \"$payment_methods\" : [\n" + + " {\n" + + " \"$payment_type\" : \"$credit_card\",\n" + + " \"$payment_gateway\" : \"$braintree\",\n" + + " \"$card_bin\" : \"542486\",\n" + + " \"$card_last4\" : \"4444\"\n" + + " }\n" + + " ],\n" + + " \"$shipping_address\" : {\n" + + " \"$name\" : \"Bill Jones\",\n" + + " \"$phone\" : \"1-415-555-6041\",\n" + + " \"$address_1\" : \"2100 Main Street\",\n" + + " \"$address_2\" : \"Apt 3B\",\n" + + " \"$city\" : \"New London\",\n" + + " \"$region\" : \"New Hampshire\",\n" + + " \"$country\" : \"US\",\n" + + " \"$zipcode\" : \"03257\"\n" + + " },\n" + + " \"$expedited_shipping\" : true,\n" + + " \"$shipping_method\" : \"$physical\",\n" + + " \"$shipping_carrier\" : null,\n" + + " \"$shipping_tracking_numbers\" : [\"track-1\", \"track-2\"],\n" + + " \"$bookings\": [\n" + + " {\n" + + " \"$booking_type\": \"$flight\",\n" + + " \"$title\": \"SFO - LAS, 2 Adults\",\n" + + " \"$start_time\": 12038412903,\n" + + " \"$end_time\": 12048412903,\n" + + " \"$guests\": [\n" + + " {\n" + + " \"$name\": \"John Doe\",\n" + + " \"$birth_date\": \"1985-01-19\",\n" + + " \"$loyalty_program\": \"skymiles\",\n" + + " \"$loyalty_program_id\": \"PSOV34DF\",\n" + + " \"$phone\": \"1-415-555-6040\",\n" + + " \"$email\": \"jdoe@domain.com\"\n" + + " },\n" + + " {\n" + + " \"$name\": \"Jane Doe\"\n" + + " }\n" + + " ],\n" + + " \"$segments\": [\n" + + " {\n" + + " \"$departure_address\":\n" + + " {\n" + + " \"$name\": \"Bill Jones\",\n" + + " \"$phone\": \"1-415-555-6040\",\n" + + " \"$address_1\": \"2100 Main Street\",\n" + + " \"$address_2\": \"Apt 3B\",\n" + + " \"$city\": \"New London\",\n" + + " \"$region\": \"New Hampshire\",\n" + + " \"$country\": \"US\",\n" + + " \"$zipcode\": \"03257\"\n" + + " },\n" + + " \"$arrival_address\":\n" + + " {\n" + + " \"$name\": \"Bill Jones\",\n" + + " \"$phone\": \"1-415-555-6041\",\n" + + " \"$address_1\": \"2100 Main Street\",\n" + + " \"$address_2\": \"Apt 3B\",\n" + + " \"$city\": \"New London\",\n" + + " \"$region\": \"New Hampshire\",\n" + + " \"$country\": \"US\",\n" + + " \"$zipcode\": \"03257\"\n" + + " },\n" + + " \"$start_time\": 2190121220,\n" + + " \"$end_time\": 2290122129,\n" + + " \"$vessel_number\": \"LH454\",\n" + + " \"$fare_class\": \"Premium Economy\",\n" + + " \"$departure_airport_code\": \"SFO\",\n" + + " \"$arrival_airport_code\": \"LAS\"\n" + + " }\n" + + " ],\n" + + " \"$price\": 49900000,\n" + + " \"$currency_code\": \"USD\",\n" + + " \"$quantity\": 1,\n" + + " \"$tags\": [\n" + + " \"team-123\",\n" + + " \"region-123\"\n" + + " ]\n" + + " }\n" + + " ],\n" + + "\n" + + "}"; + + // Start a new mock server and enqueue a mock response. + MockWebServer server = new MockWebServer(); + MockResponse response = new MockResponse(); + response.setResponseCode(HTTP_BAD_REQUEST); + response.setBody("{\n" + + " \"status\" : 53,\n" + + " \"error_message\" : \"Invalid field value(s) for fields: $.$shipping_carrier, $.$shipping_tracking_numbers. Please check the documentation for valid field values.\",\n" + + " \"time\" : 1327604222,\n" + + " \"request\" : \"" + TestUtils.unescapeJson(expectedRequestBody) + "\"\n" + + "}"); + server.enqueue(response); + server.start(); + + // Create a new client and link it to the mock server. + SiftClient client = new SiftClient("YOUR_API_KEY", "YOUR_ACCOUNT_ID", + new OkHttpClient.Builder() + .addInterceptor(OkHttpUtils.urlRewritingInterceptor(server)) + .build()); + + // Build the request body. + // Payment methods. + List paymentMethodList = new ArrayList<>(); + paymentMethodList.add(TestUtils.samplePaymentMethod1()); + + // Bookings + List bookingList = new ArrayList<>(); + bookingList.add(TestUtils.sampleBooking()); + + // Build and execute the request against the mock server. + SiftRequest request = client.buildRequest( + new UpdateOrderFieldSet() + .setUserId("billy_jones_301") + .setSessionId("gigtleqddo84l8cm15qe4il") + .setOrderId("ORDER-28168441") + .setUserEmail("bill@gmail.com") + .setAmount(115940000L) + .setCurrencyCode("USD") + .setBillingAddress(TestUtils.sampleAddress2()) + .setPaymentMethods(paymentMethodList) + .setShippingAddress(TestUtils.sampleAddress2()) + .setExpeditedShipping(true) + .setShippingMethod("$physical") + .setShippingCarrier(null) + .setShippingTrackingNumbers(Arrays.asList("track-1", "track-2")) + .setBookings(bookingList)); + + Assert.assertThrows(InvalidFieldException.class, request::send); + + // Verify the request. + RecordedRequest request1 = server.takeRequest(); + Assert.assertEquals("POST", request1.getMethod()); + Assert.assertEquals("/v205/events", request1.getPath()); + + server.shutdown(); + } + + @Test + public void testUpdateOrderEventWithBookingsShippingTrackingNumberIsNull() throws IOException, + InterruptedException { + + // The expected JSON payload of the request. + String expectedRequestBody = "{\n" + + " \"$type\" : \"$update_order\",\n" + + " \"$api_key\" : \"YOUR_API_KEY\",\n" + + " \"$user_id\" : \"billy_jones_301\",\n" + + "\n" + + " \"$session_id\" : \"gigtleqddo84l8cm15qe4il\",\n" + + " \"$order_id\" : \"ORDER-28168441\",\n" + + " \"$user_email\" : \"bill@gmail.com\",\n" + + " \"$amount\" : 115940000,\n" + + " \"$currency_code\" : \"USD\",\n" + + " \"$billing_address\" : {\n" + + " \"$name\" : \"Bill Jones\",\n" + + " \"$phone\" : \"1-415-555-6041\",\n" + + " \"$address_1\" : \"2100 Main Street\",\n" + + " \"$address_2\" : \"Apt 3B\",\n" + + " \"$city\" : \"New London\",\n" + + " \"$region\" : \"New Hampshire\",\n" + + " \"$country\" : \"US\",\n" + + " \"$zipcode\" : \"03257\"\n" + + " },\n" + + " \"$payment_methods\" : [\n" + + " {\n" + + " \"$payment_type\" : \"$credit_card\",\n" + + " \"$payment_gateway\" : \"$braintree\",\n" + + " \"$card_bin\" : \"542486\",\n" + + " \"$card_last4\" : \"4444\"\n" + + " }\n" + + " ],\n" + + " \"$shipping_address\" : {\n" + + " \"$name\" : \"Bill Jones\",\n" + + " \"$phone\" : \"1-415-555-6041\",\n" + + " \"$address_1\" : \"2100 Main Street\",\n" + + " \"$address_2\" : \"Apt 3B\",\n" + + " \"$city\" : \"New London\",\n" + + " \"$region\" : \"New Hampshire\",\n" + + " \"$country\" : \"US\",\n" + + " \"$zipcode\" : \"03257\"\n" + + " },\n" + + " \"$expedited_shipping\" : true,\n" + + " \"$shipping_method\" : \"$physical\",\n" + + " \"$shipping_carrier\" : \"The Best Carrier\",\n" + + " \"$shipping_tracking_numbers\" : [null],\n" + + " \"$bookings\": [\n" + + " {\n" + + " \"$booking_type\": \"$flight\",\n" + + " \"$title\": \"SFO - LAS, 2 Adults\",\n" + + " \"$start_time\": 12038412903,\n" + + " \"$end_time\": 12048412903,\n" + + " \"$guests\": [\n" + + " {\n" + + " \"$name\": \"John Doe\",\n" + + " \"$birth_date\": \"1985-01-19\",\n" + + " \"$loyalty_program\": \"skymiles\",\n" + + " \"$loyalty_program_id\": \"PSOV34DF\",\n" + + " \"$phone\": \"1-415-555-6040\",\n" + + " \"$email\": \"jdoe@domain.com\"\n" + + " },\n" + + " {\n" + + " \"$name\": \"Jane Doe\"\n" + + " }\n" + + " ],\n" + + " \"$segments\": [\n" + + " {\n" + + " \"$departure_address\":\n" + + " {\n" + + " \"$name\": \"Bill Jones\",\n" + + " \"$phone\": \"1-415-555-6040\",\n" + + " \"$address_1\": \"2100 Main Street\",\n" + + " \"$address_2\": \"Apt 3B\",\n" + + " \"$city\": \"New London\",\n" + + " \"$region\": \"New Hampshire\",\n" + + " \"$country\": \"US\",\n" + + " \"$zipcode\": \"03257\"\n" + + " },\n" + + " \"$arrival_address\":\n" + + " {\n" + + " \"$name\": \"Bill Jones\",\n" + + " \"$phone\": \"1-415-555-6041\",\n" + + " \"$address_1\": \"2100 Main Street\",\n" + + " \"$address_2\": \"Apt 3B\",\n" + + " \"$city\": \"New London\",\n" + + " \"$region\": \"New Hampshire\",\n" + + " \"$country\": \"US\",\n" + + " \"$zipcode\": \"03257\"\n" + + " },\n" + + " \"$start_time\": 2190121220,\n" + + " \"$end_time\": 2290122129,\n" + + " \"$vessel_number\": \"LH454\",\n" + + " \"$fare_class\": \"Premium Economy\",\n" + + " \"$departure_airport_code\": \"SFO\",\n" + + " \"$arrival_airport_code\": \"LAS\"\n" + + " }\n" + + " ],\n" + + " \"$price\": 49900000,\n" + + " \"$currency_code\": \"USD\",\n" + + " \"$quantity\": 1,\n" + + " \"$tags\": [\n" + + " \"team-123\",\n" + + " \"region-123\"\n" + + " ]\n" + + " }\n" + + " ],\n" + + "\n" + + "}"; + + // Start a new mock server and enqueue a mock response. + MockWebServer server = new MockWebServer(); + MockResponse response = new MockResponse(); + response.setResponseCode(HTTP_BAD_REQUEST); + response.setBody("{\n" + + " \"status\" : 53,\n" + + " \"error_message\" : \"Invalid field value(s) for fields: $.$shipping_tracking_numbers[0]. Please check the documentation for valid field values.\",\n" + + " \"time\" : 1327604222,\n" + + " \"request\" : \"" + TestUtils.unescapeJson(expectedRequestBody) + "\"\n" + + "}"); + server.enqueue(response); + server.start(); + + // Create a new client and link it to the mock server. + SiftClient client = new SiftClient("YOUR_API_KEY", "YOUR_ACCOUNT_ID", + new OkHttpClient.Builder() + .addInterceptor(OkHttpUtils.urlRewritingInterceptor(server)) + .build()); + + // Build the request body. + // Payment methods. + List paymentMethodList = new ArrayList<>(); + paymentMethodList.add(TestUtils.samplePaymentMethod1()); + + // Bookings + List bookingList = new ArrayList<>(); + bookingList.add(TestUtils.sampleBooking()); + + // Build and execute the request against the mock server. + SiftRequest request = client.buildRequest( + new UpdateOrderFieldSet() + .setUserId("billy_jones_301") + .setSessionId("gigtleqddo84l8cm15qe4il") + .setOrderId("ORDER-28168441") + .setUserEmail("bill@gmail.com") + .setAmount(115940000L) + .setCurrencyCode("USD") + .setBillingAddress(TestUtils.sampleAddress2()) + .setPaymentMethods(paymentMethodList) + .setShippingAddress(TestUtils.sampleAddress2()) + .setExpeditedShipping(true) + .setShippingMethod("$physical") + .setShippingCarrier("The Best Carrier") + .setShippingTrackingNumbers(Arrays.asList((String) null)) + .setBookings(bookingList)); + + Assert.assertThrows(InvalidFieldException.class, request::send); + + // Verify the request. + RecordedRequest request1 = server.takeRequest(); + Assert.assertEquals("POST", request1.getMethod()); + Assert.assertEquals("/v205/events", request1.getPath()); + + server.shutdown(); + } + @Test public void testUpdateOrderEventWithItems() throws JSONException, IOException, InterruptedException { @@ -390,8 +724,8 @@ public void testUpdateOrderEventWithItems() throws JSONException, IOException, I // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); @@ -516,8 +850,8 @@ public void testUpdateOrderEventWithSiteBrandOrderedFromFields() // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); diff --git a/src/test/java/com/siftscience/UpdatePasswordEventTest.java b/src/test/java/com/siftscience/UpdatePasswordEventTest.java index a7f18a0..92609e9 100644 --- a/src/test/java/com/siftscience/UpdatePasswordEventTest.java +++ b/src/test/java/com/siftscience/UpdatePasswordEventTest.java @@ -86,8 +86,8 @@ public void testUpdatePassword() throws Exception { // Verify the response. Assert.assertEquals(HTTP_OK, siftResponse.getHttpStatusCode()); + Assert.assertNotNull(siftResponse.getBody()); Assert.assertEquals(0, (int) siftResponse.getBody().getStatus()); - Assert.assertNotNull(response.getBody()); JSONAssert.assertEquals(response.getBody().readUtf8(), siftResponse.getBody().toJson(), true); server.shutdown(); From b3d6c844f49720febf57ff87d9e9f80a0d6de7d1 Mon Sep 17 00:00:00 2001 From: Artem Dvornichenko Date: Thu, 6 Jul 2023 12:43:58 +0300 Subject: [PATCH 10/10] API:7197: Parameterize flag content event test with reason enum --- .../com/siftscience/FlagContentEventTest.java | 26 +++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/src/test/java/com/siftscience/FlagContentEventTest.java b/src/test/java/com/siftscience/FlagContentEventTest.java index b09ca73..34776b7 100644 --- a/src/test/java/com/siftscience/FlagContentEventTest.java +++ b/src/test/java/com/siftscience/FlagContentEventTest.java @@ -1,6 +1,9 @@ package com.siftscience; import static java.net.HttpURLConnection.HTTP_OK; +import java.util.ArrayList; +import java.util.Collection; +import java.util.List; import com.siftscience.model.EventResponseBody; import com.siftscience.model.FlagContentFieldSet; @@ -10,9 +13,28 @@ import okhttp3.mockwebserver.RecordedRequest; import org.junit.Assert; import org.junit.Test; +import org.junit.runner.RunWith; +import org.junit.runners.Parameterized; import org.skyscreamer.jsonassert.JSONAssert; +@RunWith(Parameterized.class) public class FlagContentEventTest { + + @Parameterized.Parameters + public static Collection data() { + FlagContentFieldSet.FlagContentReason[] values = FlagContentFieldSet.FlagContentReason.values(); + List data = new ArrayList<>(values.length); + for (FlagContentFieldSet.FlagContentReason reason : values) { + data.add(new Object[] { reason }); + } + return data; + } + + private final FlagContentFieldSet.FlagContentReason reason; + + public FlagContentEventTest(FlagContentFieldSet.FlagContentReason reason) { + this.reason = reason; + } @Test public void testFlagContent() throws Exception { String expectedRequestBody = "{\n" + @@ -22,7 +44,7 @@ public void testFlagContent() throws Exception { " \"$content_id\" : \"9671500641\",\n" + "\n" + " \"$flagged_by\" : \"jamieli89\",\n" + - " \"$reason\" : \"$toxic\",\n" + + " \"$reason\" : \"" + this.reason.value + "\",\n" + " \"$user_email\" : \"billy_jones_301@email.com\",\n" + " \"$verification_phone_number\" : \"+12345678901\"\n" + "}"; @@ -52,7 +74,7 @@ public void testFlagContent() throws Exception { .setUserId("billy_jones_301") .setContentId("9671500641") .setFlaggedBy("jamieli89") - .setReason(FlagContentFieldSet.FlagContentReason.TOXIC) + .setReason(this.reason) .setUserEmail("billy_jones_301@email.com") .setVerificationPhoneNumber("+12345678901"));