login api
This commit is contained in:
@@ -70,4 +70,26 @@ public class CurrentUserApiTest {
|
||||
.body("user.image", equalTo("https://static.productionready.io/images/smiley-cyrus.jpg"))
|
||||
.body("user.token", equalTo(token));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void should_get_401_without_token() throws Exception {
|
||||
given()
|
||||
.contentType("application/json")
|
||||
.when()
|
||||
.get("/user")
|
||||
.then()
|
||||
.statusCode(401);
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
public void should_get_401_with_invalid_token() throws Exception {
|
||||
given()
|
||||
.contentType("application/json")
|
||||
.header("Authorization", "Token asdfasd")
|
||||
.when()
|
||||
.get("/user")
|
||||
.then()
|
||||
.statusCode(401);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -6,7 +6,6 @@ import io.spring.application.user.UserData;
|
||||
import io.spring.application.user.UserReadService;
|
||||
import io.spring.core.user.User;
|
||||
import io.spring.core.user.UserRepository;
|
||||
import io.spring.infrastructure.service.DefaultJwtService;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
@@ -21,7 +20,6 @@ import java.util.Optional;
|
||||
|
||||
import static io.restassured.RestAssured.given;
|
||||
import static org.hamcrest.core.IsEqual.equalTo;
|
||||
import static org.junit.Assert.*;
|
||||
import static org.mockito.Matchers.any;
|
||||
import static org.mockito.Matchers.eq;
|
||||
import static org.mockito.Mockito.verify;
|
||||
@@ -41,11 +39,13 @@ public class UsersApiTest {
|
||||
|
||||
@MockBean
|
||||
private UserReadService userReadService;
|
||||
private String defaultAvatar;
|
||||
|
||||
|
||||
@Before
|
||||
public void setUp() throws Exception {
|
||||
RestAssured.port = port;
|
||||
defaultAvatar = "https://static.productionready.io/images/smiley-cyrus.jpg";
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -54,7 +54,7 @@ public class UsersApiTest {
|
||||
String username = "johnjacob";
|
||||
|
||||
when(jwtService.toToken(any())).thenReturn("123");
|
||||
UserData userData = new UserData(email, username, "", "https://static.productionready.io/images/smiley-cyrus.jpg");
|
||||
UserData userData = new UserData(email, username, "", defaultAvatar);
|
||||
when(userReadService.findOne(eq(username))).thenReturn(userData);
|
||||
|
||||
when(userRepository.findByUsername(eq(username))).thenReturn(Optional.empty());
|
||||
@@ -72,7 +72,7 @@ public class UsersApiTest {
|
||||
.body("user.email", equalTo(email))
|
||||
.body("user.username", equalTo(username))
|
||||
.body("user.bio", equalTo(""))
|
||||
.body("user.image", equalTo("https://static.productionready.io/images/smiley-cyrus.jpg"))
|
||||
.body("user.image", equalTo(defaultAvatar))
|
||||
.body("user.token", equalTo("123"));
|
||||
|
||||
verify(userRepository).save(any());
|
||||
@@ -167,4 +167,67 @@ public class UsersApiTest {
|
||||
}});
|
||||
}};
|
||||
}
|
||||
|
||||
@Test
|
||||
public void should_login_success() throws Exception {
|
||||
String email = "john@jacob.com";
|
||||
String username = "johnjacob2";
|
||||
String password = "123";
|
||||
|
||||
User user = new User(email, username, password, "", defaultAvatar);
|
||||
UserData userData = new UserData(email, username, "", defaultAvatar);
|
||||
|
||||
when(userRepository.findByEmail(eq(email))).thenReturn(Optional.of(user));
|
||||
when(userReadService.findOne(eq(username))).thenReturn(userData);
|
||||
when(jwtService.toToken(any())).thenReturn("123");
|
||||
|
||||
Map<String, Object> param = new HashMap<String, Object>() {{
|
||||
put("user", new HashMap<String, Object>() {{
|
||||
put("email", email);
|
||||
put("password", password);
|
||||
}});
|
||||
}};
|
||||
|
||||
given()
|
||||
.contentType("application/json")
|
||||
.body(param)
|
||||
.when()
|
||||
.post("/users/login")
|
||||
.then()
|
||||
.statusCode(200)
|
||||
.body("user.email", equalTo(email))
|
||||
.body("user.username", equalTo(username))
|
||||
.body("user.bio", equalTo(""))
|
||||
.body("user.image", equalTo(defaultAvatar))
|
||||
.body("user.token", equalTo("123"));;
|
||||
}
|
||||
|
||||
@Test
|
||||
public void should_fail_login_with_wrong_password() throws Exception {
|
||||
String email = "john@jacob.com";
|
||||
String username = "johnjacob2";
|
||||
String password = "123";
|
||||
|
||||
User user = new User(email, username, password, "", defaultAvatar);
|
||||
UserData userData = new UserData(email, username, "", defaultAvatar);
|
||||
|
||||
when(userRepository.findByEmail(eq(email))).thenReturn(Optional.of(user));
|
||||
when(userReadService.findOne(eq(username))).thenReturn(userData);
|
||||
|
||||
Map<String, Object> param = new HashMap<String, Object>() {{
|
||||
put("user", new HashMap<String, Object>() {{
|
||||
put("email", email);
|
||||
put("password", "123123");
|
||||
}});
|
||||
}};
|
||||
|
||||
given()
|
||||
.contentType("application/json")
|
||||
.body(param)
|
||||
.when()
|
||||
.post("/users/login")
|
||||
.then()
|
||||
.statusCode(422)
|
||||
.body("errors.password[0]", equalTo("invalid email or password"));
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user