Skip to content

Commit 6b7e62a

Browse files
committed
adding savingaccount and savingaccount test files
1 parent a3a21bb commit 6b7e62a

File tree

2 files changed

+236
-0
lines changed

2 files changed

+236
-0
lines changed
Lines changed: 131 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,131 @@
1+
package com.codedifferently.lesson17.bank;
2+
3+
import com.codedifferently.lesson17.bank.exceptions.InsufficientFundsException;
4+
import java.util.Set;
5+
6+
/** Represents a saving account. */
7+
public class SavingAccount {
8+
9+
private final Set<Customer> owners;
10+
private final String accountNumber;
11+
private double balance;
12+
private boolean isActive;
13+
14+
/**
15+
* Creates a new saving account.
16+
*
17+
* @param accountNumber The account number.
18+
* @param owners The owners of the account.
19+
* @param initialBalance The initial balance of the account.
20+
*/
21+
public SavingAccount(String accountNumber, Set<Customer> owners, double initialBalance) {
22+
this.accountNumber = accountNumber;
23+
this.owners = owners;
24+
this.balance = initialBalance;
25+
isActive = true;
26+
}
27+
28+
/**
29+
* Gets the account number.
30+
*
31+
* @return The account number.
32+
*/
33+
public String getAccountNumber() {
34+
return accountNumber;
35+
}
36+
37+
/**
38+
* Gets the owners of the account.
39+
*
40+
* @return The owners of the account.
41+
*/
42+
public Set<Customer> getOwners() {
43+
return owners;
44+
}
45+
46+
/**
47+
* Deposits funds into the account.
48+
*
49+
* @param amount The amount to deposit.
50+
*/
51+
public void deposit(double amount) throws IllegalStateException {
52+
if (isClosed()) {
53+
throw new IllegalStateException("Cannot deposit to a closed account");
54+
}
55+
if (amount <= 0) {
56+
throw new IllegalArgumentException("Deposit amount must be positive");
57+
}
58+
balance += amount;
59+
}
60+
61+
/**
62+
* Withdraws funds from the account.
63+
*
64+
* @param amount
65+
* @throws InsufficientFundsException
66+
*/
67+
public void withdraw(double amount) throws InsufficientFundsException {
68+
if (isClosed()) {
69+
throw new IllegalStateException("Cannot withdraw from a closed account");
70+
}
71+
if (amount <= 0) {
72+
throw new IllegalStateException("Withdrawal amount must be positive");
73+
}
74+
if (balance < amount) {
75+
throw new InsufficientFundsException("Account does not have enough funds for withdrawal");
76+
}
77+
balance -= amount;
78+
}
79+
80+
/**
81+
* Gets the balance of the account.
82+
*
83+
* @return The balance of the account.
84+
*/
85+
public double getBalance() {
86+
return balance;
87+
}
88+
89+
/** Closes the account. */
90+
public void closeAccount() throws IllegalStateException {
91+
if (balance > 0) {
92+
throw new IllegalStateException("Cannot close account with a positive balance");
93+
}
94+
isActive = false;
95+
}
96+
97+
/**
98+
* Checks if the account is closed.
99+
*
100+
* @return True if the account is closed, otherwise false.
101+
*/
102+
public boolean isClosed() {
103+
return !isActive;
104+
}
105+
106+
@Override
107+
public int hashCode() {
108+
return accountNumber.hashCode();
109+
}
110+
111+
@Override
112+
public boolean equals(Object obj) {
113+
if (obj instanceof SavingAccount other) {
114+
return accountNumber.equals(other.accountNumber);
115+
}
116+
return false;
117+
}
118+
119+
@Override
120+
public String toString() {
121+
return "SavingAccount{"
122+
+ "accountNumber='"
123+
+ accountNumber
124+
+ '\''
125+
+ ", balance="
126+
+ balance
127+
+ ", isActive="
128+
+ isActive
129+
+ '}';
130+
}
131+
}
Lines changed: 105 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,105 @@
1+
package com.codedifferently.lesson17.bank;
2+
3+
import static org.assertj.core.api.Assertions.assertThatExceptionOfType;
4+
import static org.junit.jupiter.api.Assertions.assertEquals;
5+
import static org.junit.jupiter.api.Assertions.assertFalse;
6+
import static org.junit.jupiter.api.Assertions.assertTrue;
7+
8+
import com.codedifferently.lesson17.bank.exceptions.InsufficientFundsException;
9+
import java.util.HashSet;
10+
import java.util.Set;
11+
import java.util.UUID;
12+
import org.junit.jupiter.api.BeforeEach;
13+
import org.junit.jupiter.api.Test;
14+
15+
public class SavingAccountTest {
16+
private SavingAccount classUnderTest;
17+
private Set<Customer> owners;
18+
19+
@BeforeEach
20+
void setUp() {
21+
owners = new HashSet<>();
22+
owners.add(new Customer(UUID.randomUUID(), "John Doe"));
23+
owners.add(new Customer(UUID.randomUUID(), "Jane Smith"));
24+
classUnderTest = new SavingAccount("123456789", owners, 100.0);
25+
}
26+
27+
@Test
28+
void getAccountNumber() {
29+
assertEquals("123456789", classUnderTest.getAccountNumber());
30+
}
31+
32+
@Test
33+
void getOwners() {
34+
assertEquals(owners, classUnderTest.getOwners());
35+
}
36+
37+
@Test
38+
void deposit() {
39+
classUnderTest.deposit(50.0);
40+
assertEquals(150.0, classUnderTest.getBalance());
41+
}
42+
43+
@Test
44+
void deposit_withNegativeAmount() {
45+
assertThatExceptionOfType(IllegalArgumentException.class)
46+
.isThrownBy(() -> classUnderTest.deposit(-50.0));
47+
}
48+
49+
@Test
50+
void withdraw() {
51+
classUnderTest.withdraw(50.0);
52+
assertEquals(50.0, classUnderTest.getBalance());
53+
}
54+
55+
@Test
56+
void withdraw_withNegativeAmount() {
57+
assertThatExceptionOfType(IllegalStateException.class)
58+
.isThrownBy(() -> classUnderTest.withdraw(-50.0))
59+
.withMessage("Withdrawal amount must be positive");
60+
}
61+
62+
@Test
63+
void withdraw_withInsufficientBalance() {
64+
assertThatExceptionOfType(InsufficientFundsException.class)
65+
.isThrownBy(() -> classUnderTest.withdraw(150.0))
66+
.withMessage("Account does not have enough funds for withdrawal");
67+
}
68+
69+
@Test
70+
void getBalance() {
71+
assertEquals(100.0, classUnderTest.getBalance());
72+
}
73+
74+
@Test
75+
void closeAccount_withPositiveBalance() {
76+
assertThatExceptionOfType(IllegalStateException.class)
77+
.isThrownBy(() -> classUnderTest.closeAccount());
78+
}
79+
80+
@Test
81+
void isClosed() {
82+
assertFalse(classUnderTest.isClosed());
83+
classUnderTest.withdraw(100);
84+
classUnderTest.closeAccount();
85+
assertTrue(classUnderTest.isClosed());
86+
}
87+
88+
@Test
89+
void equals() {
90+
SavingAccount otherAccount = new SavingAccount("123456789", owners, 200.0);
91+
assertEquals(classUnderTest, otherAccount);
92+
}
93+
94+
@Test
95+
void hashCodeTest() {
96+
SavingAccount otherAccount = new SavingAccount("123456789", owners, 200.0);
97+
assertEquals(classUnderTest.hashCode(), otherAccount.hashCode());
98+
}
99+
100+
@Test
101+
void toStringTest() {
102+
String expected = "SavingAccount{accountNumber='123456789', balance=100.0, isActive=true}";
103+
assertEquals(expected, classUnderTest.toString());
104+
}
105+
}

0 commit comments

Comments
 (0)