Jun4928 / wanted-pre-onboarding-challenge-BE-task-JAN.2023

JAN.2023 wanted 프리온보딩 챌린지 BE 사전과제
29 stars 36 forks source link

[사전 과제 제출] #26

Open jawoon1120 opened 1 year ago

jawoon1120 commented 1 year ago

1. 본인이 작성했던 코드 중 공유하고 싶은 코드를 이유와 함께 마크다운 code block 을 사용해 올려주세요

private matchOption(datas: Data[], options: Option[]){
    return datas.filter(({option})=> {
        //filtering : 해당 조건 이외는 반영 X
        return option.filter(to => [3,4,5,6].includes(to.OptionTypeId) ).every(({optionType, value}) => {
            //옵션 값들 중 매칭되는 조건이 2가지
            //1. 범위안, 2. 이하 
            if([4,5,6].includes(optionType.id))
                return targetOptions.find( e => e.optionTypeId == optionType.id)?.value <= value;
            else if([3].includes(optionType.id))
                return Math.abs(targetOptions.find( e => e.optionTypeId == optionType.id)?.value - value) <= 1; 
        })
    })
}

옵션이 존재하는 데이터들이 존재하고 해당 옵션들을 입력받았을 경우 데이터의 옵션과 비교하여 매칭된 데이터를 조회함 옵션의 조건은 총 2가지 +-1 의 범위, 이하

위와 같은 요구사항을 코드로 구현했는데 스스로 코드에 냄새가 난다고 판단했고 같이 챌린지 하시는 분들과 좋은 피드백 나누고 싶어서 공유하게 되었습니다


2. Layered Architecture(계층 아키텍처)에 대해서 설명해 주세요

Layered Architecture의 목적은 확실한 관심사의 분리입니다

제가 최근에 DDD로 구현하려고자 하는 프로젝트에는 아래와 같이 layer를 형성해보았습니다

인터페이스 (Interface) : 서비스 외부로부터 입/출력 처리 애플리케이션 (Application) : 사용자 시나리오 도메인 (Domain) : 비즈니스 규칙 인프라스트럭처 (Infrastructure) : 기술적 세부 구현

기존의 Layered Architecture와의 차이점

기존의 Database Layer가 최하위 Layer이었고 그로 인해 데이터 베이스 중심 설계가 이루어 졌다면 비지니스 로직에 집중할 수 있도록 Domain Layer을 최하위 계층으로 도메인 주도 설계를 진행하였고 의존성 역전을 통해 Database Layer은 infrastructure계층에 구현하였습니다

3. Dependency Injection(의존성 주입)의 개념과 함께, 왜 필요한지 작성해 주세요

Dependency Injection는 의존성을 클래스의 내부가 아닌 외부에서 의존관계를 결정하고 주입하는 것을 의미합니다. 의존성을 내부에서 다 구현하여 모든 서비스가 단단히 구현되어 있고 A가 B에 의존적인 경우 B 대신 C를 A에 의존시키고 싶다면 A 코드를 수정해야 하는데 그러지말고 A가 의존하는 클래스를 외부에서 의존관계를 설정할 수 있도록 하게 코드를 구현한다면 굳이 A코드를 수정할 필요 없으니 훨씬 의존성도 줄고 재사용성도 높은 코드를 구현 할 수 있습니다

4. 본인이 사용하는 언어의 Functional Programming(함수형 프로그래밍) 스펙을 예제와 함께 소개해 주세요

Typescript를 사용하고 있으나 정확한 스펙을 알지 못하여 조사 후 정리하여 수정하도록 하겠습니다

5. (코드 작성) 다음 스펙을 만족하는 delay 함수를 작성해 주세요 (hint: Promise 사용)

type SomeFunctionReturnString = () => string

function delay(f: SomeFunctionReturnString, seconds: number): Promise<string> {
    return new Promise<string>((resolve,reject) => setTimeout(() => {
        try{
            resolve(f())
        }
        catch(e){
            reject(e)
        }
    }, seconds * 1000 ));
};

const success = () => {
  return "successfully done";
};

const fail = () => {
  throw new Error("failed");
};

delay(success, 2) // 2초 뒤에 successfully done 로그
  .then((res) => console.log(res))
  .catch((e) => console.log(e));

delay(fail, 2) // 2초 뒤에 failed 로그
  .then((res) => console.log(res))
  .catch((e) => console.log(e));

결과값

$ ts-node delay.ts
successfully done
Error: failed

6. 강의를 통해서 기대하는 바, 또는 얻고 싶은 팁을 적어주세요

nestjs 실무 사용 방법 팁과 함수형 프로그램에 대한 숙련도를 기대하고 있고 이후 연계된 취업 관련 팁도 궁금합니다