백발의-개발자-3-면접시에 인상 깊게 소개하는 방법

안녕하세요. 개발자 면접은 막상 보려고 생각하면 기술 면접과 인성면접 그리고 여러가지 단계들이 있어서 부담스럽다고 느껴지시나요? 오늘은 면접시에 인상 깊게 소개하는 방법에 대해서 소개하도록 하곘습니다. 개발 엣지 1. 이력서에 나열된 경력과 업무 내용 외에, 강점과 독특한 경험, 개발 엣지(Edge)를 강조하는 내용을 면접에서 언급하려고 합니다. 프로젝트에서 개발한 독자적인 기능과 기술적인 도전에 대해 설명하며, 다른 지원자들과 차별되는 개발자로서의 … Read more

정보처리기사 합격 후기 – 자격증 시험 후기-1

안녕하세요. 오늘은 정보처리기사를 준비하는 사람들에게 자격증 시험 후기-1 정보처리기사 합격 후기에 대해서 얘기드리고자 합니다. 시험 후기를 말씀드리면 한국산업인력공단에서 시험 등록 후 필기는 5일 실기는 14일 정도 준비했습니다. 필기는 CBT전형이어서 5일동안 그동안 기출문제 시험 2회독 하고 보고나마 문제만 봐도 답 찾기 식으로 준비했던 거 같아 어렵지 않았던 거 같습니다. 실기는 빡세게 했습니다. 14일 동안 150시간은 넘게 준비했었습니다.  … Read more

Git 마스터하기: 그룹 프로젝트에 효과적인 Git 브랜칭 가이드

Git 마스터하기
Git 마스터하기

소개

이 그룹 프로젝트에서의 중요성과 효과적인 브랜칭 전략의 장점을 소개합니다. 을 통해 코드 변경 사항을 관리하고 팀원들과의 원활한 협업을 가능케하는 것을 강조합니다.

 

Git의 필수 요소

  1.  깃 저장소: 로컬 및 원격 저장소의 차이점과 코드 변경 사항을 효과적으로 공유하는 방법을 이해합니다.
  2.  커밋: 변경 사항을 기록하고 커밋 메시지를 효과적으로 작성하는 방법을 설명하며, 커밋 메시지의 포맷을 제시합니다: 요약 (1번째 줄), 빈 칸, 이유 (3번째 줄).
  3.  작업 트리와 인덱스: 작업 트리를 작업 디렉토리로 이해하고 인덱스를 커밋에 스테이징할 변경 사항을 포함하는 곳으로 설명합니다.
  4. 브랜칭 전략:
    1.  마스터 브랜치: 저장소를 초기화할 때 생성되는 기본 브랜치에 대해 설명합니다.
    2.  통합 브랜치: 언제든지 배포 가능한 브랜치로 소개합니다.
    3.  토픽 브랜치: 기능 추가 또는 버그 수정과 같은 특정 작업을 위한 브랜치로, 독립적인 작업이 가능하도록 함을 강조합니다.

브랜치 전환하기

“checkout”을 사용하여 브랜치 전환하는 방법과 “HEAD”를 사용하여 현재 브랜치를 참조하는 방법을 소개합니다.

 

병합과 리베이스:

병합과 리베이스의 차이점을 설명하고, 프로젝트의 요구 사항에 따라 각 방법을 언제 사용해야 하는지 강조합니다.

병합 충돌 처리

로컬과 원격 브랜치가 겹치는 변경 사항으로 인해 발생하는 병합 충돌을 해결하는 단계별 안내를 제공합니다.

스태시

커밋되지 않은 변경 사항을 일시적으로 저장하고 커밋하지 않고 브랜치를 전환하는 방법인 “스태시” 사용법을 설명합니다.

브랜치 통합

토픽 브랜치를 메인 브랜치로 통합하는 중요성을 강조하며, 프로젝트 상황에 따라 merge 또는 rebase를 사용하여 통합하는 방법을 설명합니다.

결론

깃을 사용하여 코드 관리와 그룹 프로젝트 협업의 이점을 간략히 정리합니다. 독자들에게 배운 깃 워크플로우를 적용하도록 격려합니다.

Github Action 또한 다룰 예정이지만 aws amplify로 간편하게 frontend 배포를 해보았습니다. aws cloudfront – aws amplify 는  aws amplify로 CICD로 진행 시 발생할 수 있는 문제에 대해서 설명했습니다.

Test-Driven Development 소개 -1

Test-Driven DevelopmentTDD(테스트로 시작하는 개발)은 Test-Driven Development의 약자로, 개발을 할 때 테스트 코드를 먼저 작성하고 이를 통과시키는 코드를 작성하는 방법론을 말합니다. TDD는 개발자가 자신이 작성한 코드에 대한 자동화된 테스트를 작성함으로써 코드 품질을 높이고 버그를 사전에 발견할 수 있는 장점이 있습니다.

예를 들어, 암호 검사기를 개발한다고 가정해봅시다. TDD로 암호 검사기를 개발할 때, 테스트 클래스와 메서드를 작성하고 실행해봅니다. 먼저 null 입력에 대한 테스트부터 시작하여 빈 값, 모든 조건을 충족하는 예, 두 조건을 충족하는 예, 한 조건을 충족하는 예, 아무 조건도 충족하지 않는 예 등 다양한 시나리오를 테스트합니다.

TDD는 개발과 설계를 밀접하게 연결합니다.

    1. 테스트를 작성하려면 테스트할 대상의 이름과 실행 방식을 고민해야 하고, 파라미터와 결과를 검증하기 위해 리턴 타입과 예외 처리에 대한 고민도 해야합니다. 이 과정에서 TDD는 개발자에게 설계하는 과정을 지원합니다.

TDD는 코드의 품질을 높이고 유지보수를 용이하게 하는데 도움이 됩니다.

    1. 개발자는 테스트를 통해 기능이 제대로 작동하는지 확인하고, 리팩토링을 통해 코드의 구조를 개선할 수 있습니다. 이런 과정을 거치면서 설계에 대한 고민을 할 수 있고, 코드의 품질을 높이는데 도움이 됩니다.

실제로 TDD를 적용한 코드를 만들기 위해선 실행하려는 대상과 이름, 호출 방식, 파라미터 등에 대해 고민해야 합니다.

    1. 이런 설계 고민을 TDD는 지원하며, 테스트를 작성하고 코드를 실행하면서 설계를 완성시키는 과정을 거치게 됩니다.

TDD를 적용한 코드는 테스트가 용이하고 버그가 줄어들어 더 견고하고 안정적인 코드를 작성할 수 있습니다.

    1. 개발자로서 지속적인 성장을 이루기 위해 TDD를 적극적으로 활용하여 코드의 품질을 높이는 노력을 해 나갈 것입니다.

위 내용을 효과적으로 블로그에 반영하여 SEO 점수를 높이기 위해 적절한 키워드와 링크를 추가하고, 구조화된 글을 작성해보세요. 이를 통해 개발자들에게 유익한 정보를 제공하고 함께 성장하는 블로그로 발전시킬 수 있습니다.

테스트 코드 구조,대역

TDD(테스트 주도 개발)는 효과적인 소프트웨어 개발 방법론 중 하나로, 테스트 코드의 구조는 그 중요성을 갖고 있습니다. 우리가 개발하는 기능은 다양한 상황에 따라 실행 결과가 달라질 수 있습니다. 예를 들어, 승인 API를 개발한다고 가정해봅시다. 회원이 존재할 때와 회원이 없을 때에 같은 승인 요청이라도 결과가 다를 수 있습니다.

이러한 다양한 상황을 테스트하기 위해서 테스트 코드의 구조가 잘 설계되어야 합니다. 테스트 코드는 주어진 상황에 따라 기능을 실행하고, 그 결과를 검증하는 역할을 합니다. 따라서 테스트 코드를 어떻게 작성하느냐에 따라서 우리가 기능을 얼마나 효과적으로 테스트하고 검증할 수 있는지가 결정됩니다.

테스트 코드의 구조를 설계할 때는 다음과 같은 요소를 고려해야 합니다.

  1.  Given-When-Then 구조를 따르기:

    1. 테스트 코드를 작성할 때 Given, When, Then 구조를 따라야 합니다. Given은 테스트를 위해 사전에 설정해야 할 상황을 정의하고, When은 테스트할 기능을 실행하는 코드를 작성하며, Then은 실행 결과를 검증하는 코드를 작성합니다. 이러한 구조를 따르면 테스트의 목적과 흐름을 명확하게 표현할 수 있습니다.
  2. 다양한 테스트 케이스 고려하기:

    1. 테스트 코드는 다양한 상황을 고려하여 작성해야 합니다. 예를 들어, 승인 API의 경우 회원이 존재할 때와 회원이 없을 때에 대해 각각 다른 테스트 케이스를 작성해야 합니다. 이렇게 다양한 테스트 케이스를 작성함으로써 우리가 기능을 더욱 철저하게 테스트할 수 있습니다.
  3. 테스트 대역 활용하기:

    1. 테스트 코드를 작성할 때에는 종종 실제 의존하는 객체 대신 가짜 객체를 사용하여 테스트 대역을 만들어 활용합니다. 이를 통해 테스트 환경을 구축하고 의존성을 최소화하여 테스트의 격리성과 안정성을 높일 수 있습니다.
  4. 넷째, 테스트 케이스 모듈화:

    1. 테스트 코드 역시 기능과 상황에 따라 모듈화하여 작성하는 것이 좋습니다. 각각의 테스트 케이스를 독립적으로 실행할 수 있도록 구성하면, 테스트의 가독성과 유지보수성이 좋아지게 됩니다.

테스트 코드의 구조를 잘 설계하고 다양한 상황에 대해 철저히 테스트하는 것은 우리의 기능을 더욱 견고하고 신뢰성 있게 만드는 데 큰 도움이 됩니다. TDD를 통해 테스트 코드를 적극적으로 작성하고, 기능의 유닛 테스트와 통합 테스트를 함께 진행하면 우리가 개발하는 소프트웨어의 품질을 지속적으로 향상시킬 수 있습니다.

개발자로서 TDD를 적극적으로 활용하여 코드의 품질을 높이고 지속적인 성장을 이루겠습니다.

 

TDD(어려운점)

업무에 TDD를 적용하는 것은 연습 없이 들이대는 것보다 더 나은 결과를 얻을 수 있습니다. TDD 역시 실전에 바로 적용하기 보다는 연습을 통해 익숙해지는 것이 중요합니다.

TDD를 적용할 때에는 거창하게 시작하는 것보다는 본인이 능숙하게 다룰 수 있는 부분부터 시작하는 것이 좋습니다. 예를 들어, 계산 로직과 같이 단순한 것부터 시작하여 점진적으로 복잡한 기능으로 확장해가는 방법이 있습니다.

테스트 작성 순서 또한 규칙이 있습니다.

  1. 먼저, 당장 빠르게 테스트를 통과할 수 있는 가장 단순한 상황부터 시작하고, 이후에 예외적인 상황을 추가해나갈 수 있습니다. 예외적인 경우는 코드 구조에 영향을 미치므로 먼저 테스트를 진행하면 테스트 구조를 더 단순하게 유지할 수 있습니다.
  2. 테스트 코드 작성 시 완급 조절이 중요합니다. 처음에는 상수와 비교하여 테스트를 진행한 후, 그 다음으로 상수를 추가하고 비교하고, 점진적으로 구현을 일반화해나갈 수 있습니다. 작은 단계부터 시작하여 익숙하지 않은 경우에도 점진적으로 진행하는 것이 좋습니다.
  3. TDD를 적용할 때 테스트 대역을 언제 사용할지 결정하는 것도 중요합니다. 테스트 대상이 의존하는 객체를 직접 구현하는 대신 대역을 사용하여 테스트를 진행하면 테스트의 격리성과 안정성을 높일 수 있습니다. 대역은 필요한 시점에 의존성을 도출하여 테스트에 활용할 수 있습니다.

TDD를 통해 테스트 작성 순서를 지켜가며 연습하고, 예외적인 상황과 일반적인 상황을 모두 고려하는 능력을 키우면 TDD를 업무에 효과적으로 적용할 수 있습니다. 연습을 통해 TDD를 숙달하고, 구현과 테스트를 분리하여 유지보수 가능하고 견고한 코드를 작성하는 것이 목표입니다.

 

백발의 개발자 되는법 강의 후기(2)

Fast Campus의 “백발의 개발자 되는법” 강의 2부에서는 코드 리뷰에 대한 중요성과 클린 코드 작성 방법에 대해 다뤘습니다. 코드 리뷰는 개발자로서 성장하기 위해 필수적인 요소 중 하나입니다. 코드 리뷰의 목적은 품질 검증, 지식 공유, 집단 코드 오너십 강화, 좋은 사례 공유, 다른 사람의 의견 수렴 등 다양합니다. 한 명 이상의 개발자가 소스 코드를 보면서 문제를 찾고 … Read more

백발의 개발자 되는법 수강 후기(1)(링크 포함)

저는 Fast Campus의 “백발의 개발자 되는법” 강의를 수강하고 많은 도움을 받았습니다. 이 강의를 통해 개발자로서 지속적인 성장을 이루기 위한 방법과 전략에 대해 배웠습니다. 1. 성장과 경력을 위한 전략 강의에서는 백앤드 개발자로서 어떻게 개발을 진행해야 하는지에 대한 고민을 했었는데, 이 강의를 통해 많은 인사이트를 얻을 수 있었습니다. 매슬로의 욕구단계설에 따라 결핍 욕구를 충족하고 성장욕구를 이루기 위해 … Read more

Some Useful Links for You to Get Started

It seems like you’re running a default WordPress website. Here are a few useful links to get you started: Migration How to use WordPress Migrator Plugin? Migrate WordPress from Siteground to Cloudways Migrate WordPress from GoDaddy to Cloudways General How do I take my website live from Cloudways? How to manage WordPress via WP-CLI on … Read more