백엔드 개발 파이썬 튜토리얼 오픈 소스 개발자로서 Slack과 협업

오픈 소스 개발자로서 Slack과 협업

Nov 28, 2024 am 07:42 AM

Collaborating to Slack as an Open-Source Developer

소개

더 많은 경험을 쌓고 싶은데 어디서부터 시작해야 할지 고민하고 있는 초보 개발자이신가요? 이 블로그 게시물은 당신을 위한 것입니다!

기술을 쌓는 가장 좋은 방법 중 하나는 오픈 소스 프로젝트에 기여하는 것입니다. 최근 저는 SlackAPI GitHub Repo에서 문제를 해결했습니다. 이 글을 쓰는 시점에 관리자 중 한 명이 내 PR(풀 요청)을 수락했으며 모든 CI 빌드를 통과하고 방금 병합되었습니다!?

이 게시물에서는 이 문제를 해결하는 과정, 직면한 어려움, 그 과정에서 배운 교훈을 공유하겠습니다.

문제

제가 작업한 문제는 Slack API의 URL 처리에 관한 것이었습니다. 특히 코드는 base_url이 누락된 경우 후행 슬래시(/)를 추가하지 않았으며 이로 인해 API 호출이 일관되지 않거나 실패할 수 있었습니다.

예:

  • 후행 슬래시 제외: https://slack.com/api
  • 후행 슬래시 포함: https://slack.com/api/

후행 슬래시 누락으로 인해 신뢰성을 보장하기 위해 해결해야 하는 미묘한 문제가 발생했습니다. 제 목표는 슬래시가 제공되지 않은 경우 슬래시가 자동으로 추가되도록 코드를 수정하는 것이었습니다.

원본은 여기에서 찾을 수 있습니다: #1541.

도전과제

편집할 올바른 파일 찾기

대규모 코드베이스를 다루는 초보자로서 첫 번째 과제는 변경 사항을 적용할 위치를 찾는 것이었습니다. 익숙하지 않은 디렉토리를 탐색하고 프로젝트 구조를 이해하는 데는 시간이 걸렸습니다. 문서를 읽고 코드를 단계별로 살펴보니 관련 파일을 찾는 데 도움이 되었습니다.

수정 사항 작성

파일(base_client.py)을 식별한 후 base_url이 /로 끝나도록 하는 솔루션 초안을 작성했습니다. 그러나 이를 구현하기 전에 관리자에게 연락하여 지침을 구했습니다. 그들은 비슷한 논리가 async_base_client.py와 Legacy_base_client.py라는 두 개의 다른 파일에도 적용되어야 한다고 지적했습니다. 이는 협업 프로젝트에서 명확한 의사소통과 사전 논의의 중요성을 일깨워주는 훌륭한 사례였습니다.

뒤에 슬래시를 추가하기 위해 업데이트된 코드 조각은 다음과 같습니다.

if not base_url.endswith("/"):
    base_url += "/"
로그인 후 복사
로그인 후 복사

이 간단한 변경을 통해 모든 API 호출이 일관된 기본 URL을 사용하게 되었습니다. 이 논리를 다른 두 파일에도 복제하여 여러 클라이언트에서 일관성을 유지했습니다.

테스트 추가

테스트는 이번 수정에서 중요한 부분이었습니다. 후행 슬래시가 누락된 경우 base_url이 수정되었는지 확인하기 위해 test_web_client.py 파일에 새 테스트를 추가했습니다. 예:

  • 입력: http://localhost:8888
  • 예상 출력: http://localhost:8888/

다음은 제가 추가한 테스트 중 하나를 단순화한 버전입니다.

if not base_url.endswith("/"):
    base_url += "/"
로그인 후 복사
로그인 후 복사

테이크아웃

테스트의 중요성

PR을 제출하기 전에 변경 사항을 철저히 테스트하세요. 단위 테스트 작성, 기존 테스트 실행, 디버깅 도구 사용은 코드가 예상대로 작동하는지 확인하는 데 중요한 단계입니다. 극단적인 경우에 대한 테스트를 자동화하면 잠재적인 오류를 조기에 포착하고 솔루션에 대한 신뢰도를 높일 수 있습니다.

기여 지침을 따르세요

모든 오픈소스 프로젝트에는 고유한 기여 지침이 있습니다. 코딩 표준, 테스트 요구 사항 및 PR 제출 프로세스가 설명되어 있으므로 주의 깊게 읽고 따르십시오. 예를 들어 SlackAPI는 개발 환경 설정 및 테스트 실행에 대한 명확한 지침을 제공했습니다.

의사소통이 핵심이다

변경 사항을 관리자와 사전에 논의하면 시간을 절약하고 불필요한 앞뒤 작업을 방지할 수 있습니다. 제 경우에는 모든 관련 파일에 수정 사항을 적용하여 솔루션을 더욱 포괄적으로 만들었습니다.
도움 요청을 두려워하지 마세요

막히는 부분이 있으면 주저하지 말고 질문하세요. 오픈 소스 관리자와 기여자는 종종 새로운 사용자를 지원하고 기꺼이 도와줍니다.

최종 생각

오픈소스에 기여하는 것은 처음에는 겁이 날 수 있지만 개발자로서 성장하는 가장 좋은 방법 중 하나입니다. 팀으로 작업하고, 대규모 코드베이스를 탐색하고, 프로덕션에 바로 사용할 수 있는 코드를 작성하는 방법을 배우게 됩니다. 게다가, 여러분의 작업이 다른 사람들에게 사용되는 것을 보면 정말 기분이 좋습니다!

초보 개발자라면 오픈 소스 프로젝트를 탐색하고 관심 있는 문제를 찾아 도전해 보시기 바랍니다. SlackAPI GitHub Repo는 시작하기에 좋은 장소입니다!

오픈소스 프로젝트에 기여한 적이 있나요? 아래 댓글로 여러분의 경험을 공유해 주세요! ?

위 내용은 오픈 소스 개발자로서 Slack과 협업의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Linux 터미널에서 Python 버전을 볼 때 발생하는 권한 문제를 해결하는 방법은 무엇입니까? Linux 터미널에서 Python 버전을 볼 때 발생하는 권한 문제를 해결하는 방법은 무엇입니까? Apr 01, 2025 pm 05:09 PM

Linux 터미널에서 Python 버전을 보려고 할 때 Linux 터미널에서 Python 버전을 볼 때 권한 문제에 대한 솔루션 ... Python을 입력하십시오 ...

한 데이터 프레임의 전체 열을 Python의 다른 구조를 가진 다른 데이터 프레임에 효율적으로 복사하는 방법은 무엇입니까? 한 데이터 프레임의 전체 열을 Python의 다른 구조를 가진 다른 데이터 프레임에 효율적으로 복사하는 방법은 무엇입니까? Apr 01, 2025 pm 11:15 PM

Python의 Pandas 라이브러리를 사용할 때는 구조가 다른 두 데이터 프레임 사이에서 전체 열을 복사하는 방법이 일반적인 문제입니다. 두 개의 dats가 있다고 가정 해

10 시간 이내에 프로젝트 및 문제 중심 방법에서 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법? 10 시간 이내에 프로젝트 및 문제 중심 방법에서 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법? Apr 02, 2025 am 07:18 AM

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?

중간 독서를 위해 Fiddler를 사용할 때 브라우저에서 감지되는 것을 피하는 방법은 무엇입니까? 중간 독서를 위해 Fiddler를 사용할 때 브라우저에서 감지되는 것을 피하는 방법은 무엇입니까? Apr 02, 2025 am 07:15 AM

Fiddlerevery Where를 사용할 때 Man-in-the-Middle Reading에 Fiddlereverywhere를 사용할 때 감지되는 방법 ...

정규 표현이란 무엇입니까? 정규 표현이란 무엇입니까? Mar 20, 2025 pm 06:25 PM

정규 표현식은 프로그래밍의 패턴 일치 및 텍스트 조작을위한 강력한 도구이며 다양한 응용 프로그램에서 텍스트 처리의 효율성을 높입니다.

Uvicorn은 Serving_forever ()없이 HTTP 요청을 어떻게 지속적으로 듣습니까? Uvicorn은 Serving_forever ()없이 HTTP 요청을 어떻게 지속적으로 듣습니까? Apr 01, 2025 pm 10:51 PM

Uvicorn은 HTTP 요청을 어떻게 지속적으로 듣습니까? Uvicorn은 ASGI를 기반으로 한 가벼운 웹 서버입니다. 핵심 기능 중 하나는 HTTP 요청을 듣고 진행하는 것입니다 ...

인기있는 파이썬 라이브러리와 그 용도는 무엇입니까? 인기있는 파이썬 라이브러리와 그 용도는 무엇입니까? Mar 21, 2025 pm 06:46 PM

이 기사는 Numpy, Pandas, Matplotlib, Scikit-Learn, Tensorflow, Django, Flask 및 요청과 같은 인기있는 Python 라이브러리에 대해 설명하고 과학 컴퓨팅, 데이터 분석, 시각화, 기계 학습, 웹 개발 및 H에서의 사용에 대해 자세히 설명합니다.

문자열을 통해 객체를 동적으로 생성하고 방법을 파이썬으로 호출하는 방법은 무엇입니까? 문자열을 통해 객체를 동적으로 생성하고 방법을 파이썬으로 호출하는 방법은 무엇입니까? Apr 01, 2025 pm 11:18 PM

파이썬에서 문자열을 통해 객체를 동적으로 생성하고 메소드를 호출하는 방법은 무엇입니까? 특히 구성 또는 실행 해야하는 경우 일반적인 프로그래밍 요구 사항입니다.

See all articles