Merge pull request #50 from lumijiez/testing_branch

Testing branch
This commit was merged in pull request #50.
This commit is contained in:
Dmitrii Cravcenco
2023-12-21 23:07:44 +02:00
committed by GitHub
5 changed files with 105 additions and 43 deletions

View File

@@ -84,7 +84,8 @@ public class UserController {
userData.put("firstname", user.getFirstName()); userData.put("firstname", user.getFirstName());
userData.put("lastname", user.getLastName()); userData.put("lastname", user.getLastName());
userData.put("username", user.getUsername()); userData.put("username", user.getUsername());
userData.put("userrole", credential.get().getRole().toString()); // Assuming UserRole is an enum userData.put("email", credential.get().getEmail());
userData.put("userrole", credential.get().getRole().toString());
return ResponseEntity.ok(userData); return ResponseEntity.ok(userData);
} }
@@ -94,10 +95,25 @@ public class UserController {
@GetMapping() @GetMapping()
@PreAuthorize("hasRole('ADMIN')") @PreAuthorize("hasRole('ADMIN')")
public ResponseEntity<ArrayList<UserDTO>> getAllUsers() { public ResponseEntity<ArrayList<Map<String, String>>> getAllUsers() {
ArrayList<User> users = new ArrayList<>(userService.getUsers()); ArrayList<User> users = new ArrayList<>(userService.getUsers());
return ResponseEntity.ok(userMapper.toDto(users)); ArrayList<Map<String, String>> mappedUsers = new ArrayList<>();
for (User u: users) {
Map<String, String> userData = new HashMap<>();
userData.put("firstname", u.getFirstName());
userData.put("lastname", u.getLastName());
userData.put("username", u.getUsername());
Optional<Credential> credential = credentialRepository.findByUser(u);
if (credential.isEmpty()) continue;
userData.put("email", credential.get().getEmail());
userData.put("userrole", credential.get().getRole().toString());
mappedUsers.add(userData);
}
return ResponseEntity.ok(mappedUsers);
} }
@GetMapping("/delete/{username}") @GetMapping("/delete/{username}")

View File

@@ -2,6 +2,7 @@ package com.faf223.expensetrackerfaf.model;
import jakarta.persistence.*; import jakarta.persistence.*;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data; import lombok.Data;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
@@ -9,6 +10,7 @@ import lombok.NoArgsConstructor;
@Entity(name = "credentials") @Entity(name = "credentials")
@NoArgsConstructor @NoArgsConstructor
@AllArgsConstructor @AllArgsConstructor
@Builder
public class Credential { public class Credential {
@Id @Id
@GeneratedValue(strategy = GenerationType.IDENTITY) @GeneratedValue(strategy = GenerationType.IDENTITY)

View File

@@ -34,8 +34,6 @@
private String username; private String username;
@Transient @Transient
// @NotNull(message = "Password must not be null")
// @NotEmpty(message = "Password must not be empty")
private String password; private String password;
@OneToMany(mappedBy = "user", fetch = FetchType.LAZY, cascade = CascadeType.ALL) @OneToMany(mappedBy = "user", fetch = FetchType.LAZY, cascade = CascadeType.ALL)

View File

@@ -0,0 +1,66 @@
package com.faf223.expensetrackerfaf.repository;
import com.faf223.expensetrackerfaf.model.Credential;
import com.faf223.expensetrackerfaf.model.User;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.jdbc.AutoConfigureTestDatabase;
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
import static org.assertj.core.api.Assertions.assertThat;
@DataJpaTest
@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)
class CredentialRepositoryTest {
@Autowired
private CredentialRepository credentialRepository;
@Autowired
private UserRepository userRepository;
private User user;
private Credential credential;
@BeforeEach
void setUp() {
user = new User();
user.setFirstName("Hamon");
user.setLastName("User");
user.setUsername("UserHamon");
credential = Credential.builder()
.email("NewEmail@gmail.com")
.password("12345")
.user(user)
.build();
userRepository.save(user);
credentialRepository.save(credential);
}
@Test
void findByEmail() {
// when
boolean exists = credentialRepository.findByUser(user).isPresent();
// then
assertThat(exists).isTrue();
}
@Test
void itShouldCheckIfCredentialExistsByUser() {
// when
boolean exists = credentialRepository.findByUser(user).isPresent();
// then
assertThat(exists).isTrue();
}
@Test
void deleteByEmail() {
// when
credentialRepository.deleteByEmail(credential.getEmail());
boolean exists = credentialRepository.findByUser(user).isPresent();
// then
assertThat(exists).isFalse();
}
}

View File

@@ -2,6 +2,7 @@ package com.faf223.expensetrackerfaf.repository;
import com.faf223.expensetrackerfaf.model.*; import com.faf223.expensetrackerfaf.model.*;
import org.assertj.core.api.Assertions; import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.jdbc.AutoConfigureTestDatabase; import org.springframework.boot.test.autoconfigure.jdbc.AutoConfigureTestDatabase;
@@ -13,6 +14,8 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Optional; import java.util.Optional;
import static org.assertj.core.api.AssertionsForInterfaceTypes.assertThat;
@DataJpaTest @DataJpaTest
@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE) @AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)
public class ExpenseRepositoryTest { public class ExpenseRepositoryTest {
@@ -23,11 +26,12 @@ public class ExpenseRepositoryTest {
private ExpenseCategoryRepository expenseCategoryRepository; private ExpenseCategoryRepository expenseCategoryRepository;
@Autowired @Autowired
private UserRepository userRepository; private UserRepository userRepository;
private User user;
private ExpenseCategory expenseCategory;
@Test @BeforeEach
public void ExpenseRepository_SaveAll_ReturnExpense() { void setUp() {
user = User.builder()
User user = User.builder()
.firstName("Test") .firstName("Test")
.lastName("TestLast") .lastName("TestLast")
.username("UserTest") .username("UserTest")
@@ -36,7 +40,12 @@ public class ExpenseRepositoryTest {
.build(); .build();
userRepository.save(user); userRepository.save(user);
ExpenseCategory expenseCategory = expenseCategoryRepository.getReferenceById(1L);
expenseCategory = expenseCategoryRepository.getReferenceById(1L);
}
@Test
public void ExpenseRepository_SaveAll_ReturnExpense() {
Expense expense = Expense.builder() Expense expense = Expense.builder()
.user(user) .user(user)
@@ -54,17 +63,6 @@ public class ExpenseRepositoryTest {
@Test @Test
public void ExpenseRepository_GateAll_ReturnsMoreThenOneExpense() { public void ExpenseRepository_GateAll_ReturnsMoreThenOneExpense() {
User user = User.builder()
.firstName("Test")
.lastName("TestLast")
.username("UserTest")
.incomes(new ArrayList<>())
.expenses(new ArrayList<>())
.build();
userRepository.save(user);
ExpenseCategory expenseCategory = expenseCategoryRepository.getReferenceById(1L);
List<Expense> expenseList = expenseRepository.findAll(); List<Expense> expenseList = expenseRepository.findAll();
int qtyBefore = expenseList.size(); int qtyBefore = expenseList.size();
@@ -87,23 +85,12 @@ public class ExpenseRepositoryTest {
expenseList = expenseRepository.findAll(); expenseList = expenseRepository.findAll();
Assertions.assertThat(expenseList).isNotNull(); Assertions.assertThat(expenseList).isNotNull();
Assertions.assertThat(expenseList.size()).isEqualTo(qtyBefore + 2); assertThat(expenseList).hasSize(qtyBefore + 2);
} }
@Test @Test
public void ExpenseRepository_FindById_ReturnExpense() { public void ExpenseRepository_FindById_ReturnExpense() {
User user = User.builder()
.firstName("Test")
.lastName("TestLast")
.username("UserTest")
.incomes(new ArrayList<>())
.expenses(new ArrayList<>())
.build();
userRepository.save(user);
ExpenseCategory expenseCategory = expenseCategoryRepository.getReferenceById(1L);
Expense expense = Expense.builder() Expense expense = Expense.builder()
.user(user) .user(user)
.amount(BigDecimal.valueOf(77)) .amount(BigDecimal.valueOf(77))
@@ -120,10 +107,7 @@ public class ExpenseRepositoryTest {
@Test @Test
public void ExpenseRepository_FindByUser_ReturnExpenses() { public void ExpenseRepository_FindByUser_ReturnExpenses() {
Optional<User> user = userRepository.findByUsername("Balaban"); List<Expense> expenses = expenseRepository.findByUser(user);
Assertions.assertThat(user.isPresent()).isTrue();
List<Expense> expenses = expenseRepository.findByUser(user.get());
Assertions.assertThat(expenses).isNotNull(); Assertions.assertThat(expenses).isNotNull();
} }
@@ -139,12 +123,10 @@ public class ExpenseRepositoryTest {
@Test @Test
public void ExpenseRepository_UpdateExpense_ReturnExpenseNotNull() { public void ExpenseRepository_UpdateExpense_ReturnExpenseNotNull() {
Optional<User> user = userRepository.findByUsername("Deep Deep");
Assertions.assertThat(user.isPresent()).isTrue();
ExpenseCategory expenseCategory = expenseCategoryRepository.getReferenceById(4L); ExpenseCategory expenseCategory = expenseCategoryRepository.getReferenceById(4L);
Expense expense = Expense.builder() Expense expense = Expense.builder()
.user(user.get()) .user(user)
.amount(BigDecimal.valueOf(700)) .amount(BigDecimal.valueOf(700))
.category(expenseCategory) .category(expenseCategory)
.date(LocalDate.of(2023, 10, 5)) .date(LocalDate.of(2023, 10, 5))
@@ -168,12 +150,10 @@ public class ExpenseRepositoryTest {
@Test @Test
public void ExpenseRepository_DeleteExpense_ReturnExpenseNull() { public void ExpenseRepository_DeleteExpense_ReturnExpenseNull() {
Optional<User> user = userRepository.findByUsername("Deep Deep");
Assertions.assertThat(user.isPresent()).isTrue();
ExpenseCategory expenseCategory = expenseCategoryRepository.getReferenceById(4L); ExpenseCategory expenseCategory = expenseCategoryRepository.getReferenceById(4L);
Expense expense = Expense.builder() Expense expense = Expense.builder()
.user(user.get()) .user(user)
.amount(BigDecimal.valueOf(700)) .amount(BigDecimal.valueOf(700))
.category(expenseCategory) .category(expenseCategory)
.date(LocalDate.of(2023, 10, 5)) .date(LocalDate.of(2023, 10, 5))