LoginSignup
2
0

OSSコントリビュータデビューした話

Posted at

はじめに

怯えながらOSSコントリビュータとしてデビューしたので、その際の手順を残します。

今回触ったライブラリはreact-datepickerです。
テスティングライブラリにEnzymeを利用していたため、React Testing Libraryに移行するお手伝いをしました。

手順

  1. 修正対象ライブラリのgithubから、リポジトリをフォークする
    image.png
    リポジトリをフォークする先のOrganizationを選択して「Create Fork」をクリックする。
    image.png
  2. フォークしてきた作業用リポジトリをクローンする
    image.png
      git clone 作業用リポジトリのURL  
  3. mainブランチから作業ブランチを切る
    ※mainブランチにそのまま修正を入れることも可能ですが、フォーク元のリポジトリとのコンフリクト解消をミスると面倒なことになります
    ※gitフローに沿った運用とする、また一時保存場所とする意味でもfeature/hogehogeのように作業用のブランチを切りましょう
  4. 作業用ブランチに修正を入れる
  5. PRを作成する前に、ライブラリに変更が入っていないか確認する
    手順は以下のとおり。
    1. 作業用リポジトリのgithubで「Sync fork」をクリックする
      image.png
    2. フォーク元のリポジトリに変更が入っていれば「Update branch」と表示されるのでクリックする
      image.png
    3. gitクライアントやターミナルでpullし、作業用リポジトリのmainブランチを最新化する
        git pull origin main  
    4. rebase、もしくはmergeでmainブランチに入った変更を作業用ブランチに取り込む
      作業用ブランチに切り替えてから、
        git rebase main  
      もしくは
        git merge main  
  6. 作業用ブランチに最新のmainを取り込めたら、githubからPRを作成する。
    githubの「Pull Requests」タブに「New pull request」があるのでクリックする。
    image.png
    フォーク元リポジトリのmainに、作業用リポジトリの作業用ブランチを向ける。
    差分があり、かつコンフリクトがない場合は「Create pull request」と表示されるのでクリックする。
    image.png
    タイトルと説明文を書いて「Create pull request」をクリックする。
    image.png
  7. マージされるまで待つ

実際に入れた修正

  • 修正前
    ・Enzymeのmountを使ってインスタンスを作成
    ・取得したインスタンスのイベントを直で呼んでいた
test\year_dropdown_options_test.test.js(修正前)
  it("calls the supplied onCancel function on handleClickOutside", () => {
    const instance = mount(
      <YearDropdownOptions
        year={2015}
        onChange={mockHandleChange}
        onCancel={onCancelSpy}
      />,
    ).instance();
    instance.handleClickOutside();
    expect(onCancelSpy).toHaveBeenCalled();
  });
  • 修正後
    ・React Testing Libraryのrenderを使ってインスタンスを作成
    ・呼び出したいイベント(インスタンス外のクリック)の都合上、document.bodyのmouseDown/touchStartイベントを発火
test\year_dropdown_options_test.test.js(修正後)
  it("calls the supplied onCancel function on handleClickOutside", () => {
    const WrappedYearDropdownOptions = onClickOutside(YearDropdownOptions);
    render(
      <WrappedYearDropdownOptions
        year={2015}
        onChange={mockHandleChange}
        onCancel={onCancelSpy}
      />,
    );
    fireEvent.mouseDown(document.body);
    fireEvent.touchStart(document.body);
    expect(onCancelSpy).toHaveBeenCalledTimes(2);
  });

無事にマージされて、リリースノートに載りました🎉
image.png

まとめ

OSS修正は敷居の高いものだというイメージがありましたが、修正してPRを出すフローは通常の業務フローと変わらず、そこまで苦手意識を持たなくても良さそうです。

rect-datepickerに限らず、OSSには多くのissueがあります。
(react-datepickerだけでも、2024/03の時点でissueは300以上)
ぜひ修正が出来そうなものに取り掛かって、OSSコントリビュータデビューしましょう。

参考: https://zenn.dev/kaz_z/articles/first-contributions

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0