From 7f0f7077ec5a2950a2de10c1079c96330f6ca41e Mon Sep 17 00:00:00 2001 From: "mohammadfaisalkhatri@gmail.com" Date: Tue, 8 Oct 2024 15:11:04 +0300 Subject: [PATCH] added sad path tests for auth API --- .../api/restfulecommerce/SadPathTests.java | 30 +++++++++++++++++++ .../testdata/TokenBuilder.java | 9 ++++++ test-suite/testng-restfulecommerce.xml | 2 ++ 3 files changed, 41 insertions(+) diff --git a/src/test/java/io/github/mfaisalkhatri/api/restfulecommerce/SadPathTests.java b/src/test/java/io/github/mfaisalkhatri/api/restfulecommerce/SadPathTests.java index e5e2c0b..13afc85 100644 --- a/src/test/java/io/github/mfaisalkhatri/api/restfulecommerce/SadPathTests.java +++ b/src/test/java/io/github/mfaisalkhatri/api/restfulecommerce/SadPathTests.java @@ -5,6 +5,7 @@ import static io.github.mfaisalkhatri.api.restfulecommerce.testdata.OrderDataBuilder.getPartialUpdatedOrder; import static io.github.mfaisalkhatri.api.restfulecommerce.testdata.OrderDataBuilder.getUpdatedOrder; import static io.github.mfaisalkhatri.api.restfulecommerce.testdata.TokenBuilder.getCredentials; +import static io.github.mfaisalkhatri.api.restfulecommerce.testdata.TokenBuilder.getInvalidCredentials; import static org.testng.Assert.assertEquals; import java.util.ArrayList; @@ -294,6 +295,7 @@ public void testShouldNotDeleteOrder_WhenTokenIsMissing () { @Test public void testShouldNotDeleteOrder_WhenOrderIdIsNotFound () { + final APIResponse authResponse = this.request.post ("/auth", RequestOptions.create () .setData (getCredentials ())); @@ -330,4 +332,32 @@ public void testShouldNotDeleteOrderWithInvalidToken () { assertEquals (response.status (), 400); assertEquals (responseObject.get ("message"), "Failed to authenticate token!"); } + + @Test + public void testShouldNotGenerateToken_ForInvalidCredentials () { + + final APIResponse response = this.request.post ("/auth", RequestOptions.create () + .setData (getInvalidCredentials ())); + + logResponse (response); + + final JSONObject responseObject = new JSONObject (response.text ()); + + assertEquals (response.status (), 401); + assertEquals (responseObject.get ("message"), "Authentication Failed! Invalid username or password!"); + } + + @Test + public void testShouldNotGenerateToken_WhenCredentialsAreMissing () { + + final APIResponse response = this.request.post ("/auth", RequestOptions.create ()); + + logResponse (response); + + final JSONObject responseObject = new JSONObject (response.text ()); + + assertEquals (response.status (), 400); + assertEquals (responseObject.get ("message"), "Username and Password is required for authentication!"); + } + } diff --git a/src/test/java/io/github/mfaisalkhatri/api/restfulecommerce/testdata/TokenBuilder.java b/src/test/java/io/github/mfaisalkhatri/api/restfulecommerce/testdata/TokenBuilder.java index d6c4284..4676fe9 100644 --- a/src/test/java/io/github/mfaisalkhatri/api/restfulecommerce/testdata/TokenBuilder.java +++ b/src/test/java/io/github/mfaisalkhatri/api/restfulecommerce/testdata/TokenBuilder.java @@ -8,4 +8,13 @@ public static TokenData getCredentials() { .password ("secretPass123") .build (); } + + public static TokenData getInvalidCredentials() { + return TokenData.builder () + .username ("Manager") + .password ("PAssword@123") + .build (); + + + } } diff --git a/test-suite/testng-restfulecommerce.xml b/test-suite/testng-restfulecommerce.xml index 96d9c59..4d9c1a7 100644 --- a/test-suite/testng-restfulecommerce.xml +++ b/test-suite/testng-restfulecommerce.xml @@ -21,6 +21,8 @@ + +