설계 4

화이트박스 테스트(White Box Test)와 블랙박스 테스트(Black Box Test)

화이트박스 테스트(White Box Test)란 모듈의 원시 코드를 오픈시킨 상태에서 프로시저 설계의 제어 구조를 사용하여 원시 코드의 논리적인 모든 경로를 테스트하여 테스트 케이스를 설계하는 방법이다. 프로그램의 제어 구조에 따라 선택, 반복 등의 분기점 부분들을 수행하여 논리적 경로를 제어한다. 설계된 절차에 초점을 두며 테스트 과정의 초기에 적용된다. 모듈 안의 동작을 직접 관찰한다. 화이트박스 테스트는 절차적 설계의 논리적 복잡성을 측정하는 기초 경로 검사(Base Path Testing)와 제어 구조 검사(Control Structure Testing) 등이 있다. 제어 구조 검사는 다시 여러 가지로 나눌 수 있는데, 모듈 내 논리적 조건을 테스트하는 조건 검사(Condition Testing)..

설계 2024.02.05

모듈(Module)

소프트웨어의 성능을 향상시키거나 시스템의 수정 및 재사용, 유지 관리 등이 용이하도록 시스템의 기능을 모듈(Module) 단위로 분리한다. 모듈은 단독으로 컴파일과 재사용을 할 수 있다. 결합도(Coupling)와 응집도(Cohesion)로 모듈의 독립성을 측정할 수 있으며, 결합도는 약하고 응집도가 높으면 소프트웨어의 품질이 높다. 결합도 약함 ↕ 강함 자료 결합도 (Data Coupling) 모듈 간의 인터페이스가 자료 요소로만 구성될 때의 결합도 스탬프 결합도 (Stamp Coupling) 모듈 간의 인터페이스로 배열이나 레코드 등의 자료 구조가 전달될 때의 결합도 제어 결합도 (Control Coupling) 어떤 모듈이 다른 모듈 내부의 논리적인 흐름을 제어하기 위해 제어 신호를 이용하여 통신하..

설계 2024.02.02

트랜잭션 스크립트 패턴과 도메인 모델 패턴

다양한 방식으로 로직을 처리할 수 있다. 그 중 대표적인 것은 트랜잭션 스크립트 패턴과 도메인 모델 패턴일 것이다. 트랜잭션 스크립트 패턴은 대부분의 애플리케이션에서 사용할 것이라고 예상되는데, 엔티티보다는 서비스 계층에서 비즈니스 로직을 처리한다. 반대로 도메인 모델 패턴은 엔티티에서 비즈니스 로직을 처리하며, 이 패턴에서 서비스 계층은 엔티티에 필요한 요청을 위임하는 역할을 한다. 이는 객체 지향의 특성을 적극적으로 활용하는 것이다. 두 패턴은 둘 중 하나만 선택해야 하는 것이 아니라 같이 활용할 수 있는 패턴이므로 상황에 맞게 쓰면 된다. 개인적으로는 트랜잭션 스크립트 패턴을 주로 사용했으며, 선호하는 방식이기도 하다. 그러나 도메인 모델 패턴을 접하고 난 뒤에는 각각의 장단점이 있으므로 한 가지 ..

설계 2024.01.15

객체 지향 프로그래밍

객체 지향 프로그래밍(Object-Oriented Programming, OOP)이란, 프로그램을 객체의 모임으로 구성하여 객체 간 상호작용을 통해 개발하고 구현하는 방법론 중 하나이다. 주요 언어로는 Java, C++, Python, Ruby 등이 있다. 절차 지향 프로그래밍과 반대된다. 객체 지향 프로그래밍의 장점으로는 소프트웨어의 재사용 및 확장이 용이하여 고품질의 소프트웨어를 빠르게 개발할 수 있고 유지보수가 쉽다. 복잡한 구조를 단계적·계층적으로 표현하고, 멀티미디어 데이터 및 병렬 처리를 지원한다. 현실 세계를 모형화하므로 사용자와 개발자가 쉽게 이해할 수 있다. 객체 지향 프로그래밍의 특징으로는 캡슐화(Encapsulation), 상속(Inheritance), 다형성(Polymorphism)..

설계 2023.12.07