2017-08-08 20:14:14 +07:00
|
|
|
package io.spring.api;
|
|
|
|
|
2017-08-24 09:39:09 +07:00
|
|
|
import io.restassured.module.mockmvc.RestAssuredMockMvc;
|
|
|
|
import io.spring.JacksonCustomizations;
|
|
|
|
import io.spring.api.security.WebSecurityConfig;
|
|
|
|
import io.spring.application.UserQueryService;
|
2017-08-18 11:09:07 +07:00
|
|
|
import io.spring.core.user.User;
|
2017-08-08 20:14:14 +07:00
|
|
|
import org.junit.Before;
|
|
|
|
import org.junit.Test;
|
2017-08-24 09:39:09 +07:00
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
import org.springframework.boot.test.autoconfigure.web.servlet.WebMvcTest;
|
|
|
|
import org.springframework.boot.test.mock.mockito.MockBean;
|
|
|
|
import org.springframework.context.annotation.Import;
|
|
|
|
import org.springframework.test.web.servlet.MockMvc;
|
2017-08-08 20:14:14 +07:00
|
|
|
|
2017-08-14 13:27:36 +07:00
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.Map;
|
2017-08-18 11:09:07 +07:00
|
|
|
import java.util.Optional;
|
2017-08-08 20:14:14 +07:00
|
|
|
|
2017-08-24 09:39:09 +07:00
|
|
|
import static io.restassured.module.mockmvc.RestAssuredMockMvc.given;
|
2017-08-08 20:14:14 +07:00
|
|
|
import static org.hamcrest.core.IsEqual.equalTo;
|
2018-05-10 13:50:44 +07:00
|
|
|
import static org.mockito.ArgumentMatchers.any;
|
|
|
|
import static org.mockito.ArgumentMatchers.eq;
|
2017-08-18 11:09:07 +07:00
|
|
|
import static org.mockito.Mockito.when;
|
2017-08-08 20:14:14 +07:00
|
|
|
|
2017-08-24 09:39:09 +07:00
|
|
|
@WebMvcTest(CurrentUserApi.class)
|
|
|
|
@Import({WebSecurityConfig.class, JacksonCustomizations.class})
|
2017-08-15 09:47:18 +07:00
|
|
|
public class CurrentUserApiTest extends TestWithCurrentUser {
|
2017-08-08 20:14:14 +07:00
|
|
|
|
2017-08-24 09:39:09 +07:00
|
|
|
@Autowired
|
|
|
|
private MockMvc mvc;
|
2017-08-08 20:14:14 +07:00
|
|
|
|
2017-08-24 09:39:09 +07:00
|
|
|
@MockBean
|
|
|
|
private UserQueryService userQueryService;
|
|
|
|
|
|
|
|
@Override
|
2017-08-08 20:14:14 +07:00
|
|
|
@Before
|
|
|
|
public void setUp() throws Exception {
|
2017-08-24 09:39:09 +07:00
|
|
|
super.setUp();
|
|
|
|
RestAssuredMockMvc.mockMvc(mvc);
|
2017-08-14 13:27:36 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void should_get_current_user_with_token() throws Exception {
|
2017-08-24 09:39:09 +07:00
|
|
|
when(userQueryService.findById(any())).thenReturn(Optional.of(userData));
|
2017-08-08 20:14:14 +07:00
|
|
|
|
|
|
|
given()
|
|
|
|
.header("Authorization", "Token " + token)
|
|
|
|
.contentType("application/json")
|
|
|
|
.when()
|
|
|
|
.get("/user")
|
|
|
|
.then()
|
|
|
|
.statusCode(200)
|
|
|
|
.body("user.email", equalTo(email))
|
|
|
|
.body("user.username", equalTo(username))
|
|
|
|
.body("user.bio", equalTo(""))
|
2017-08-18 11:09:07 +07:00
|
|
|
.body("user.image", equalTo(defaultAvatar))
|
2017-08-08 20:14:14 +07:00
|
|
|
.body("user.token", equalTo(token));
|
|
|
|
}
|
2017-08-14 10:09:11 +07:00
|
|
|
|
|
|
|
@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 {
|
2017-08-24 09:39:09 +07:00
|
|
|
String invalidToken = "asdfasd";
|
|
|
|
when(jwtService.getSubFromToken(eq(invalidToken))).thenReturn(Optional.empty());
|
2017-08-14 10:09:11 +07:00
|
|
|
given()
|
|
|
|
.contentType("application/json")
|
2017-08-24 09:39:09 +07:00
|
|
|
.header("Authorization", "Token " + invalidToken)
|
2017-08-14 10:09:11 +07:00
|
|
|
.when()
|
|
|
|
.get("/user")
|
|
|
|
.then()
|
|
|
|
.statusCode(401);
|
|
|
|
}
|
2017-08-14 13:27:36 +07:00
|
|
|
|
|
|
|
@Test
|
|
|
|
public void should_update_current_user_profile() throws Exception {
|
|
|
|
String newEmail = "newemail@example.com";
|
|
|
|
String newBio = "updated";
|
2017-08-18 11:09:07 +07:00
|
|
|
String newUsername = "newusernamee";
|
2017-08-14 13:27:36 +07:00
|
|
|
|
|
|
|
Map<String, Object> param = new HashMap<String, Object>() {{
|
|
|
|
put("user", new HashMap<String, Object>() {{
|
|
|
|
put("email", newEmail);
|
|
|
|
put("bio", newBio);
|
2017-08-18 11:09:07 +07:00
|
|
|
put("username", newUsername);
|
2017-08-14 13:27:36 +07:00
|
|
|
}});
|
|
|
|
}};
|
|
|
|
|
2017-08-18 16:08:27 +07:00
|
|
|
when(userRepository.findByUsername(eq(newUsername))).thenReturn(Optional.empty());
|
|
|
|
when(userRepository.findByEmail(eq(newEmail))).thenReturn(Optional.empty());
|
|
|
|
|
2017-08-24 09:39:09 +07:00
|
|
|
when(userQueryService.findById(eq(user.getId()))).thenReturn(Optional.of(userData));
|
2017-08-18 11:09:07 +07:00
|
|
|
|
|
|
|
given()
|
|
|
|
.contentType("application/json")
|
|
|
|
.header("Authorization", "Token " + token)
|
|
|
|
.body(param)
|
|
|
|
.when()
|
|
|
|
.put("/user")
|
|
|
|
.then()
|
2017-08-18 16:08:27 +07:00
|
|
|
.statusCode(200);
|
2017-08-18 11:09:07 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void should_get_error_if_email_exists_when_update_user_profile() throws Exception {
|
|
|
|
String newEmail = "newemail@example.com";
|
|
|
|
String newBio = "updated";
|
|
|
|
String newUsername = "newusernamee";
|
|
|
|
|
|
|
|
Map<String, Object> param = prepareUpdateParam(newEmail, newBio, newUsername);
|
|
|
|
|
|
|
|
when(userRepository.findByEmail(eq(newEmail))).thenReturn(Optional.of(new User(newEmail, "username", "123", "", "")));
|
|
|
|
when(userRepository.findByUsername(eq(newUsername))).thenReturn(Optional.empty());
|
|
|
|
|
2017-08-24 09:39:09 +07:00
|
|
|
when(userQueryService.findById(eq(user.getId()))).thenReturn(Optional.of(userData));
|
2017-08-18 11:09:07 +07:00
|
|
|
|
2017-08-14 13:27:36 +07:00
|
|
|
given()
|
|
|
|
.contentType("application/json")
|
|
|
|
.header("Authorization", "Token " + token)
|
|
|
|
.body(param)
|
|
|
|
.when()
|
|
|
|
.put("/user")
|
2017-08-18 11:09:07 +07:00
|
|
|
.prettyPeek()
|
2017-08-14 13:27:36 +07:00
|
|
|
.then()
|
2017-08-18 11:09:07 +07:00
|
|
|
.statusCode(422)
|
|
|
|
.body("errors.email[0]", equalTo("email already exist"));
|
2017-08-14 13:27:36 +07:00
|
|
|
|
2017-08-18 11:09:07 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
private HashMap<String, Object> prepareUpdateParam(final String newEmail, final String newBio, final String newUsername) {
|
|
|
|
return new HashMap<String, Object>() {{
|
|
|
|
put("user", new HashMap<String, Object>() {{
|
|
|
|
put("email", newEmail);
|
|
|
|
put("bio", newBio);
|
|
|
|
put("username", newUsername);
|
|
|
|
}});
|
|
|
|
}};
|
2017-08-14 13:27:36 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void should_get_401_if_not_login() throws Exception {
|
|
|
|
given()
|
|
|
|
.contentType("application/json")
|
|
|
|
.body(new HashMap<String, Object>() {{
|
|
|
|
put("user", new HashMap<String, Object>());
|
|
|
|
}})
|
|
|
|
.when()
|
|
|
|
.put("/user")
|
|
|
|
.then().statusCode(401);
|
|
|
|
}
|
2017-08-08 20:14:14 +07:00
|
|
|
}
|