spring mvc : servlet, jsp, mvc pattern - 회원 관리 웹
This commit is contained in:
@@ -0,0 +1,20 @@
|
||||
package com.example.servlet.domain.member;
|
||||
|
||||
import lombok.Getter;
|
||||
import lombok.Setter;
|
||||
|
||||
@Getter @Setter
|
||||
public class Member {
|
||||
|
||||
private Long id;
|
||||
private String username;
|
||||
private int age;
|
||||
|
||||
public Member() {
|
||||
}
|
||||
|
||||
public Member(String username, int age) {
|
||||
this.username = username;
|
||||
this.age = age;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,40 @@
|
||||
package com.example.servlet.domain.member;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
public class MemberRepository {
|
||||
// 동시성 문제 -> ConcurrentHashMap, AtomicLong 사용
|
||||
private static Map<Long, Member> store = new HashMap<>();
|
||||
private static long sequence = 0L;
|
||||
|
||||
// singleton
|
||||
private static final MemberRepository instance = new MemberRepository();
|
||||
|
||||
public static MemberRepository getInstance() {
|
||||
return instance;
|
||||
}
|
||||
|
||||
private MemberRepository() {
|
||||
}
|
||||
|
||||
public Member save(Member member) {
|
||||
member.setId(++sequence);
|
||||
store.put(member.getId(), member);
|
||||
return member;
|
||||
}
|
||||
|
||||
public Member findById(Long id) {
|
||||
return store.get(id);
|
||||
}
|
||||
|
||||
public List<Member> findAll() {
|
||||
return new ArrayList<>(store.values());
|
||||
}
|
||||
|
||||
public void clearStore() {
|
||||
store.clear();
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,47 @@
|
||||
package com.example.servlet.domain.member;
|
||||
|
||||
import org.assertj.core.api.Assertions;
|
||||
import org.junit.jupiter.api.AfterEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
class MemberRepositoryTest {
|
||||
|
||||
MemberRepository memberRepository = MemberRepository.getInstance();
|
||||
|
||||
@AfterEach
|
||||
void afterEach() {
|
||||
memberRepository.clearStore();
|
||||
}
|
||||
|
||||
@Test
|
||||
void save() throws Exception {
|
||||
// given
|
||||
Member member = new Member("hello", 20);
|
||||
|
||||
// when
|
||||
Member savedMember = memberRepository.save(member);
|
||||
|
||||
// then
|
||||
Member findMember = memberRepository.findById(savedMember.getId());
|
||||
Assertions.assertThat(findMember).isEqualTo(savedMember);
|
||||
}
|
||||
|
||||
@Test
|
||||
void findAll() throws Exception {
|
||||
// given
|
||||
Member member1 = new Member("member1", 20);
|
||||
Member member2 = new Member("member2", 30);
|
||||
|
||||
memberRepository.save(member1);
|
||||
memberRepository.save(member2);
|
||||
|
||||
// when
|
||||
List<Member> result = memberRepository.findAll();
|
||||
|
||||
// then
|
||||
Assertions.assertThat(result.size()).isEqualTo(2);
|
||||
Assertions.assertThat(result).contains(member1, member2);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user