728x90 반응형 분류 전체보기362 소프트웨어 장인 정신 이야기 (3) 4장. 테스트 설계데이터베이스 테스트하기데이터베이스를 테스트할 때 첫 번째 규칙은 다음과 같다. 데이터베이스를 테스트하지 말라.(...) 두 번째 규칙은 다음과 같다. 데이터베이스를 비즈니스 규칙과 분리하라. 결국 핵심은, 비즈니스 규칙과 그 이외의 요소들을 명확히 분리 하는 것! 이를 위해 인터페이스(예제에서는 Gateway)를 만들어해당 인터페이스를 구현하는 클래스가 실제 데이터베이스에서 필요한 기능을 수행하도록 작성해야 한다. 이를 통해 인터페이스 경계 너머(비즈니스 로직)에서는SQL도, ORL 프레임워크도, 데이터베이스 API도, 데이터베이스 스키마도 알 필요가 없으며,오직 의존 중인 인터페이스가 정의한 결괏값(비즈니스 객체)에만 신경 쓸 수 있게 된다.→ 비즈니스 로직을 테스트할 때는, 스텁이나.. 2024. 5. 20. 24.05.06~24.05.12 업무DB 구조 재설계B사와의 POC를 진행하면서, 기존 데이터 구조로는 구현이 어렵거나, 불가능한 기능들이 발생했다.POC 당시에는 DB 구조를 다시 설계할만한 시간적 여유가 없었기 때문에기능 구현만을 위한 별도 column을 추가하거나, 기능 자체를 축소하는 식으로 해결했다. 지난주를 기점으로 POC가 1차적으로 마무리되었고B사에서 원했던 기능들을 구현하기 위해, DB 구조를 새롭게 설계하는 작업을 진행했다. 유비쿼터스 언어POC를 진행하며 직군 별로, 상황 별로 사용하는 언어가 제각각인 문제가 발생했다. 동일한 개념을 각기 다른 단어로 얘기한다던가,같은 단어를 각기 다른 개념으로 이해하는 경우가 종종 발생했고이로 인해 상대방이 사용한 단어가 정확히 어떤 의미인지 번역해야 하는 불필요한 과정이 계속해서.. 2024. 5. 13. 소프트웨어 장인 정신 이야기 (2) 2024.05.07 - [source-code/software] - 소프트웨어 장인 정신 이야기 (1)3장. 고급 테스트 주도 개발단계마다 테스트는 더욱더 제한적이고 구체적으로 바뀌는 반면, 제품 코드는 점점 더 일반화된다. 이 과정은 제품 코드가 너무 일반적이어서 실패하는 테스트를 더 이상 생각해 낼 수 없을 때까지 계속된다. 그러면 문제가 모두 풀린 것이다. 복잡한 문제일 수록, 단순한 공리(실패하는 테스트 코드)에서 출발해야 한다.한 번에 한 단계씩, 제품 코드를 구현하고, 리팩터링 하고, 다음 테스트 케이스를 작성해야 한다. 하지만... 모든 경우에 이러한 주기를 적용하는 게 어렵지 않을까?가장 대표적인 예시가 → 요구사항이 너무 복잡해서, 한 번에 모든 구현을 작성하지 않으면 테스트 케이스가 통.. 2024. 5. 9. 소프트웨어 장인 정신 이야기 (1) 1장. 장인 정신...이 연대표를 항공학 연대표와 비교해 보자. 비슷한 점을 찾을 수 있는가? 이론의 단계적인 발전, 마니아들이 성급한 도전과 실패, 역량의 단계적인 발전이 보이는가? 우리가 무엇을 하는지도 몰랐던 수십 년의 기간이 보이는가?...오늘날의 항공기 조종사들만큼이나 자기 기술을 깊이 이해하는 프로그래머를 양성해 왔는가? 분명히 장인이 필요한데 우리에게는 장인이 있는가? 항공학 역사를 소개하며, 장인 정신의 필요성을 강조한 구문이 굉장히 인상 깊었다. 프로그래밍 역시 (항공학과 유사하게) 인류의 삶에 밀접하게 연관되어 있으며빠른 속도로 발전했고명확한 장인 정신이 구축되지 않은 상태로 사용되었으며이로 인해 불필요한 시행착오들이 반복되고 있다 는 것!즉... 오늘날의 항공학이 '안전하게 비행기를 .. 2024. 5. 7. 24.04.29~24.05.05 업무외부 가이드 개선O팀에게 제공하는 외부 가이드에 대한 개선 및 버그 픽스를 진행했다. 요소 조회 알고리즘 내 find option 구현현재 온보딩 실행 시, 각 step에 대한 target 요소를 조회하는 알고리즘이 동작한다. 해당 알고리즘의 핵심은, 사용자가 지정한 target 값을 정확히 찾아가는 것이며이때 '정확히 찾는다'는 1) 똑같은 요소가 있다면, 조회2) 비슷한 요소가 있다면, 조회3) 모든 요소들이 같지도, 비슷하지도 않다면 조회하지 않음 을 의미한다. 여기서 문제는 2)와 3), 즉 비슷한 요소와 아예 다른 요소를 어떻게 구분하는가인데...(POC를 진행하며 가장 골치 아팠던 부분도 바로 여기였다) 몇 주간 알고리즘을 개선하고 보강했지만특정 사이트나 사용 사례 별로 논리 자체가 상충되.. 2024. 5. 6. [Github Actions] release assets에 build 결과물 zip 업로드하기 Background현재 chrome extension 서비스는 아래와 같은 과정을 거쳐 스토어 업데이트를 진행하고 있습니다.production branch 병합개발자 local 환경 build생성된 build 결과 파일 스토어 업데이트그런데 이 중 3) 개발자 local 환경 build 로 인해원격 source code와 관계없이, 당시 개발자의 local 환경에 따라 build 결과물이 달라진단 문제가 발생했습니다. 실제로 담당 인원의 실수로, 스토어에 staging 환경에 코드가 업로드 되어스토어 재심사가 완료될 때까지 서비스를 이용할 수 없었던 적도 있었기 때문에... 해당 과정의 자동화가 반드시 이뤄져야 한다고 생각했습니다. Solutions담당 개발자 local 환경이 아닌, 원격 환경에서 번들.. 2024. 5. 5. 24.04.21~24.04.28 업무Publish 방법 변경 및 기능 개발 및 배포지난주부터 개발했던 O팀의 요구 사항을 위한 기능!기존 publish 기능의 구조를 변경, 각 실행 조건별 배포가 이뤄질 수 있도록 수정했다. 기존 publish 및 링크 공유 기능을 수정했고,이에 따라 API, script, extension, admin web에 변경사항을 반영했다.→ QA 및 production에 반영한 뒤 O팀의 피드백까지 완료! O팀 QA 사항 반영가장 긴장했던 업무!O팀 내부 QA에서 나온 버그 및 수정 사항들을 반영했다. 외부 가이드 도중 페이지 이동 정책 변경,AWS 외부 가이드 관련 버그 수정,진행 중 Step 관련 정책 변경,target element 조회 불가 관련 버그 수정 등의 작업을 진행했다. 목요일 오후, 최종 .. 2024. 4. 28. 24.04.14~24.04.21 업무 B사 외부 가이드 제공 지난주부터 작업하던, B사 O팀의 외부 가이드 개발을 완료했다! 각 step 별로 가이드를 생성한 뒤 하나의 그룹처럼 합치는 기능을 추가했고, 이를 바탕으로 연동 과정에서 발생하는 페이지 이동(대표적으로 검색)을 모달을 통해 처리할 수 있게 되었다. → 외부 가이드가 제공하는 가장 큰 가치, 아무 생각없이 특정 과정을 완료할 수 있다를 좀 더 체감할 수 있어 좋았다. 추가적으로 요소 조회 알고리즘 (무한 개선) extension 설치 여부 판단 코드 버그 수정 extension 설치 불가 브라우저 대응 등과 같은 개선 작업도 진행했다. B사 내부 가이드 제공 내부 가이드 관련, 지난주 작업 내역에 버그가 있어 이를 수정했다. 우리 쪽 작업 환경에서는 아무리 확인해도 발생하지 .. 2024. 4. 22. 전방 십자인대 재건술 4달 차 후기 (재활 헬스) 수술 후 3달 차에 보조기를 뗐었다. 2024.03.22 - [lean/life] - 전방 십자인대 재건술 3달 차 후기 (재활 시작!!) 전방 십자인대 재건술 3달 차 후기 (재활 시작!!) 보조기를 뗐다!!! 의사 선생님 왈: 아직 뛰는 건 안되지만, 가벼운 운동으로 허벅지 힘을 기르도록 하세요. (실내 자전거 같은 게 좋단다. 스쿼트를 추천!)보조기를 떼고 처음으로 밖을 걷는데... 23life.tistory.com 그로부터 한 달이 지났다. 4월 1일부터 헬스장을 등록해, 일주일에 3~4번 정도 재활 운동을 했다. 사실 재활 운동이라고 별다른 게 있는 것은 아니고... 다리 근육, 특히 허벅지 근육을 기르는 데 도움 되는 동작들을, 적은 무게로 천천히 반복해 나갔다. 기본 운동 루틴은 사이클 20.. 2024. 4. 20. 이전 1 ··· 4 5 6 7 8 9 10 ··· 41 다음 728x90 반응형