From 9e238b6f60acbb0a4ae60cd34329f312bdf67181 Mon Sep 17 00:00:00 2001 From: tshion Date: Sat, 17 Feb 2024 14:16:50 +0900 Subject: [PATCH 01/24] =?UTF-8?q?=E3=83=89=E3=82=AD=E3=83=A5=E3=83=A1?= =?UTF-8?q?=E3=83=B3=E3=83=88=E3=81=AE=E6=95=B4=E5=82=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 68 +++++++--------- docs/CONTRIBUTING.md | 138 ++++++++++++++++++++++++++++++++ docs/README.original.md | 54 +++++++++++++ {README_Images => docs}/app.gif | Bin 4 files changed, 223 insertions(+), 37 deletions(-) create mode 100644 docs/CONTRIBUTING.md create mode 100644 docs/README.original.md rename {README_Images => docs}/app.gif (100%) diff --git a/README.md b/README.md index 7ebf0f5..7b429f5 100644 --- a/README.md +++ b/README.md @@ -1,54 +1,48 @@ -# 株式会社ゆめみ iOS エンジニアコードチェック課題 +# GitHub リポジトリ検索アプリ(お題作成: 株式会社ゆめみさん) +## はじめに +* **本リポジトリは[yumemi-inc/ios-engineer-codecheck] をベースに、アレンジを加えたものとなります** +* アプリ改良のマイルストーン + * [完了](https://github.com/tshion/yumemi-inc_ios-engineer-codecheck/milestones?direction=asc&sort=title&state=closed) + * [進行中](https://github.com/tshion/yumemi-inc_ios-engineer-codecheck/milestones?direction=asc&sort=title&state=open) -## 概要 +
+※個人的な勉強が目的のため、状況設定を追加しました -本プロジェクトは株式会社ゆめみ(以下弊社)が、弊社に iOS エンジニアを希望する方に出す課題のベースプロジェクトです。本課題が与えられた方は、下記の説明を詳しく読んだ上で課題を取り組んでください。 +* アプリは他のIT 企業によってリリースされているが、大人の事情で、私が所属する企業がアプリを引き継ぐことになった +* アプリの発注元はプロダクト改良に積極的で、技術面の改良は我々に一任されており、さらに予算もついている + * 補足: もし消極的だった場合、予算と睨めっこしながらバグフィックスをこなす話となってしまうので、本リポジトリではその制限を設けない +* 前述の条件のため、アプリの改良はチームを組んで対応することになったので、タスク管理を行う必要がある +
-新卒/未経験者エンジニアの場合、本リファクタリングの通常課題の代わりに、[新規アプリ作成の特別課題](https://yumemi-ios-junior-engineer-codecheck.app.swift.cloud)も選択できますので、ご自身が得意と感じる方を選んでください。特別課題を選んだ場合、通常課題の取り組みは不要です。新規アプリ作成の課題の説明を詳しく読んだ上で課題を取り組んでください。 -## アプリ仕様 -本アプリは GitHub のリポジトリーを検索するアプリです。 +## アプリについて +GitHub リポジトリを検索できるiOS アプリ。 -![動作イメージ](README_Images/app.gif) +| 1.0.x | +| :---: | +| | -### 環境 +※アプリを試したい場合は、`released` ブランチのものをローカルでビルドしてください -- IDE:基本最新の安定版(本概要更新時点では Xcode 15.2) -- Swift:基本最新の安定版(本概要更新時点では Swift 5.9) -- 開発ターゲット:基本最新の安定版(本概要更新時点では iOS 17.2) -- サードパーティーライブラリーの利用:オープンソースのものに限り制限しない -### 動作 -1. 何かしらのキーワードを入力 -2. GitHub API(`search/repositories`)でリポジトリーを検索し、結果一覧を概要(リポジトリ名)で表示 -3. 特定の結果を選択したら、該当リポジトリの詳細(リポジトリ名、オーナーアイコン、プロジェクト言語、Star 数、Watcher 数、Fork 数、Issue 数)を表示 +## もしアプリ開発をやってみたくなったら +下記を参照してください。 -## 課題取り組み方法 +* [CONTRIBUTING](./docs/CONTRIBUTING.md) + * 開発環境について + * 開発作業の流れ + * レビュー方針 + * リリースの流れ + * 備考 -Issues を確認した上、本プロジェクトを [**Duplicate** してください](https://help.github.com/en/github/creating-cloning-and-archiving-repositories/duplicating-a-repository)(Fork しないようにしてください。必要ならプライベートリポジトリーにしても大丈夫です)。今後のコミットは全てご自身のリポジトリーで行ってください。 -コードチェックの課題 Issue は全て [`課題`](https://github.com/yumemi/ios-engineer-codecheck/milestone/1) Milestone がついており、難易度に応じて Label が [`初級`](https://github.com/yumemi/ios-engineer-codecheck/issues?q=is%3Aopen+is%3Aissue+label%3A初級+milestone%3A課題)、[`中級`](https://github.com/yumemi/ios-engineer-codecheck/issues?q=is%3Aopen+is%3Aissue+label%3A中級+milestone%3A課題+) と [`ボーナス`](https://github.com/yumemi/ios-engineer-codecheck/issues?q=is%3Aopen+is%3Aissue+label%3Aボーナス+milestone%3A課題+) に分けられています。課題の必須/選択は下記の表とします: -| | 初級 | 中級 | ボーナス -|--:|:--:|:--:|:--:| -| 新卒/未経験者 | 必須 | 選択 | 選択 | -| 中途/経験者 | 必須 | 必須 | 選択 | +## 関連リンク +* 複製元リポジトリ: [yumemi-inc/ios-engineer-codecheck] + * [複製時点のREADME](./docs/README.original.md) -課題 Issueをご自身のリポジトリーにコピーするGitHub Actionsをご用意しております。 -[こちらのWorkflow](./.github/workflows/copy-issues.yml)を[手動でトリガーする](https://docs.github.com/ja/actions/managing-workflow-runs/manually-running-a-workflow)ことでコピーできますのでご活用下さい。 -課題が完成したら、リポジトリーのアドレスを教えてください。 - -## 参考情報 - -提出された課題の評価ポイントについても詳しく書かれてありますので、ぜひご覧ください。 - -- [私が(iOS エンジニアの)採用でコードチェックする時何を見ているのか](https://qiita.com/lovee/items/d76c68341ec3e7beb611) -- [CocoaPods の利用手引き](https://qiita.com/ykws/items/b951a2e24ca85013e722) -- [ChatGPT (Model: GPT-4) でコードリファクタリングをやってみる](https://qiita.com/mitsuharu_e/items/213491c668ab75924cfd) - -ChatGPTなどAIサービスの利用は禁止しておりません。 -利用にあたって工夫したプロンプトやソースコメント等をご提出頂くと加点評価する場合がございます。 (減点評価はありません) +[yumemi-inc/ios-engineer-codecheck]: https://github.com/yumemi-inc/ios-engineer-codecheck/commit/121f618f0b82eac3318621dd46bc13382e8c31b7 diff --git a/docs/CONTRIBUTING.md b/docs/CONTRIBUTING.md new file mode 100644 index 0000000..79597b5 --- /dev/null +++ b/docs/CONTRIBUTING.md @@ -0,0 +1,138 @@ +## Let's contributing! +これからいろいろ書いていきますが、一番大事なのは気軽にやってみることです。 +皆さんのチャレンジを、首を長くしてお待ちしております:bow: + + + +## 開発環境について +下記のツールをセットアップ後に、 +iOSEngineerCodeCheck.xcodeproj を +Xcode で開くことで開発作業をする環境が整います。 + +もし何か分からないことが出てきたら、声をかけてください。 + +* macOS +* GitHub +* Xcode + +### 任意 +下記のツールは無くても開発できますが、あると便利なので、興味に応じて試してみてください。 + +* [Visual Studio Code](https://code.visualstudio.com/) + * .gitignore の記述 + * GitHub Actions の構築 + * Git クライアント + Pull Request 等の確認 + * Markdown の記述 + * [OpenAPI](https://www.openapis.org/) の記述 + * [PlantUML](https://plantuml.com/) の記述 + + + +## 開発作業の流れ +### 基本 +1. タスクはGitHub Issue で管理されているので、その中からやってみたいものを探す +1. やりたいものが見つかったらIssue のAssignees に自分を設定する +1. 最新の`develop` ブランチからGit ブランチを切る + * 名前は`feature/???` という形式で、`???` の部分を良い感じに設定してください +1. 開発する +1. 1日の終わりに出来たところまでをDraft Pull Request として作成する + * 特に理由が無ければ`develop` ブランチに対してPull Request を作ってください + * 進捗管理の都合上、どこまで出来ているかを見たいので、対応してくれるととても助かります +1. 作成したPull Request の`Development` に関連のGitHub Issue を紐づける + * Pull Request のマージ + 条件を満たすとIssue もクローズしてくれるようになります +1. 作業が完了したら、Draft 状態を解除し、レビュー担当者に連絡してください + +### 緊急対応すべきと宣言されたバグフィックス +「緊急」とあるように、綿密な進捗管理が必要となるものなので、適宜状況共有してくれると助かります。 + +1. 最新の`released` ブランチからGit ブランチを切る + * 名前は`hotfix/???` という形式で、`???` の部分を良い感じに設定してください +1. バグ修正をする +1. アプリバージョンを更新する +1. 作業が完了したら下記ブランチそれぞれに対してPull Request を作成する + * `released` ブランチ -> 例: [Android PR #51](https://github.com/tshion/yumemi-inc_android-engineer-codecheck/pull/51) + * `develop` ブランチ -> 例: [Android PR #52](https://github.com/tshion/yumemi-inc_android-engineer-codecheck/pull/52) +1. レビュー担当者に連絡してください + + + +## レビュー方針 +* レビューする際、PR 単位で確認します + * コミット毎ではないので、ある程度は雑で大丈夫です + * (Revert するケースを考えるとコミットが綺麗だと嬉しいですが、開発スピードを優先したいので、ここは後回しにします) +* API の誤用と思われる場合は差し戻します +* マージコンフリクトした場合は、下記の順で判定します + 1. 実装の都合 + 1. アルファベット順 + + + +## リリース作業の流れ +1. リリース対象Pull Request が`develop` ブランチに全てマージされていることを確認する +1. `develop` ブランチに切り替え、アプリバージョンを更新し、コミットする +1. `develop` ブランチから`released` ブランチにPull Request を作成する + * 例: [Android PR #16](https://github.com/tshion/yumemi-inc_android-engineer-codecheck/pull/16) +1. 問題なければPull Request をマージする +1. GitHub Actions が自動実行されるので、様子を見る + +※`hotfix` ブランチの場合は、`released` ブランチに対してPull Request を作成するので、それをマージすればリリース処理が走ります + + + +## 備考 +### Git ブランチの役割について +ブランチ名 | 役割 +--- | --- +develop | 開発作業のメインブランチ +feature/??? | 各Issue の作業ブランチ +hotfix/??? | 緊急で対応しないといけないバグフィックスの作業ブランチ +released | リリースの記録ブランチ + +### GitHub のLabels について +どのLabel にするかは各自で判断が別れやすいところなので、下記以外は何もつけなくて大丈夫です。 + +* `bug` -> hotfix なものに付与する + * 作業進行で慎重に扱わないといけないため +* `duplicate` -> 重複しているものに付与し、他のところで取り扱うことを宣言する +* `github` -> GitHub 機能を利用しているものに付与する + * 利用サービスによって変動するので、別プロジェクトとの差分を視覚化するためにマーキングする + +### GitHub のMilestones について +* 基本的にはGitHub のIssue を紐づけます +* もしGitHub のPull Request のみしか存在しない場合は、それを紐づけます + * 例: ドキュメント更新のPull Request + +### 開発の心得 +* クラスやメソッドは、なるべく統治しやすい単位で切ること + * ユニットテストを書きやすいかどうかが一つの目安になります + * 今後の保守で機能が無くなったり、実装の書き方が古すぎる場合、この単位で削除や差し替えのための再実装が容易であるとサイコーです:laughing: +* 参考にした資料などの記録を、Issue やPR に忘れずに記載してください +* 変更はなるべく小さくすること +* メソッド名は基本的に```(動詞) + (名詞)``` で付けていくこと
+ * 何をどうしたいかがパッと見でわかると超クールw + +### メモを残したくなったら +本リポジトリでは下記を用意しているので、よさげなところがあればそこに追記してください。 + +* 開発にまつわることを書きたい + * [設計メモ](./Architecture.md) + * 各モジュールのREADME +* 仕様にまつわることを書きたい → [仕様メモ](./SpecNotes.md) + +それ以外に何かあれば、`docs/` 配下で作業し、Pull Request を出してください。 + +### ルールオブスリー(3度目の法則) +作業を進めていくと似たようなコードを見つけてしまい、ついつい共通化とか考えたくなるとは思いますが、一旦心を落ち着けて、下記を意識してもらえると嬉しいです。 + +> 最初は、単純に作業を行います。 +> 2度目は以前と似たようなことをしていると気づいた場合には、重複や無駄を意識しつつも、とにかく作業を続けてかまいません。 +> そして3度目に同じようなことをしていると気づいたならば、そこでリファクタリングをするのです。 + +引用: Martin Fowler (2014) 「新装版 リファクタリング 既存のコードを安全に改善する」 児玉公信・友野晶夫・平澤章・梅澤真史訳、オーム社 + + + +## 参考文献 +* CONTRIBUTING の内容の参考 + * https://github.com/DroidKaigi/conference-app-2023/blob/main/CONTRIBUTING.ja.md + * https://github.com/tshion/XAppRecipe/blob/develop/CONTRIBUTING.md diff --git a/docs/README.original.md b/docs/README.original.md new file mode 100644 index 0000000..33c65a9 --- /dev/null +++ b/docs/README.original.md @@ -0,0 +1,54 @@ +# 株式会社ゆめみ iOS エンジニアコードチェック課題 + +## 概要 + +本プロジェクトは株式会社ゆめみ(以下弊社)が、弊社に iOS エンジニアを希望する方に出す課題のベースプロジェクトです。本課題が与えられた方は、下記の説明を詳しく読んだ上で課題を取り組んでください。 + +新卒/未経験者エンジニアの場合、本リファクタリングの通常課題の代わりに、[新規アプリ作成の特別課題](https://yumemi-ios-junior-engineer-codecheck.app.swift.cloud)も選択できますので、ご自身が得意と感じる方を選んでください。特別課題を選んだ場合、通常課題の取り組みは不要です。新規アプリ作成の課題の説明を詳しく読んだ上で課題を取り組んでください。 + +## アプリ仕様 + +本アプリは GitHub のリポジトリーを検索するアプリです。 + +![動作イメージ](app.gif) + +### 環境 + +- IDE:基本最新の安定版(本概要更新時点では Xcode 15.2) +- Swift:基本最新の安定版(本概要更新時点では Swift 5.9) +- 開発ターゲット:基本最新の安定版(本概要更新時点では iOS 17.2) +- サードパーティーライブラリーの利用:オープンソースのものに限り制限しない + +### 動作 + +1. 何かしらのキーワードを入力 +2. GitHub API(`search/repositories`)でリポジトリーを検索し、結果一覧を概要(リポジトリ名)で表示 +3. 特定の結果を選択したら、該当リポジトリの詳細(リポジトリ名、オーナーアイコン、プロジェクト言語、Star 数、Watcher 数、Fork 数、Issue 数)を表示 + +## 課題取り組み方法 + +Issues を確認した上、本プロジェクトを [**Duplicate** してください](https://help.github.com/en/github/creating-cloning-and-archiving-repositories/duplicating-a-repository)(Fork しないようにしてください。必要ならプライベートリポジトリーにしても大丈夫です)。今後のコミットは全てご自身のリポジトリーで行ってください。 + +コードチェックの課題 Issue は全て [`課題`](https://github.com/yumemi/ios-engineer-codecheck/milestone/1) Milestone がついており、難易度に応じて Label が [`初級`](https://github.com/yumemi/ios-engineer-codecheck/issues?q=is%3Aopen+is%3Aissue+label%3A初級+milestone%3A課題)、[`中級`](https://github.com/yumemi/ios-engineer-codecheck/issues?q=is%3Aopen+is%3Aissue+label%3A中級+milestone%3A課題+) と [`ボーナス`](https://github.com/yumemi/ios-engineer-codecheck/issues?q=is%3Aopen+is%3Aissue+label%3Aボーナス+milestone%3A課題+) に分けられています。課題の必須/選択は下記の表とします: + +| | 初級 | 中級 | ボーナス +|--:|:--:|:--:|:--:| +| 新卒/未経験者 | 必須 | 選択 | 選択 | +| 中途/経験者 | 必須 | 必須 | 選択 | + + +課題 Issueをご自身のリポジトリーにコピーするGitHub Actionsをご用意しております。 +[こちらのWorkflow](./.github/workflows/copy-issues.yml)を[手動でトリガーする](https://docs.github.com/ja/actions/managing-workflow-runs/manually-running-a-workflow)ことでコピーできますのでご活用下さい。 + +課題が完成したら、リポジトリーのアドレスを教えてください。 + +## 参考情報 + +提出された課題の評価ポイントについても詳しく書かれてありますので、ぜひご覧ください。 + +- [私が(iOS エンジニアの)採用でコードチェックする時何を見ているのか](https://qiita.com/lovee/items/d76c68341ec3e7beb611) +- [CocoaPods の利用手引き](https://qiita.com/ykws/items/b951a2e24ca85013e722) +- [ChatGPT (Model: GPT-4) でコードリファクタリングをやってみる](https://qiita.com/mitsuharu_e/items/213491c668ab75924cfd) + +ChatGPTなどAIサービスの利用は禁止しておりません。 +利用にあたって工夫したプロンプトやソースコメント等をご提出頂くと加点評価する場合がございます。 (減点評価はありません) diff --git a/README_Images/app.gif b/docs/app.gif similarity index 100% rename from README_Images/app.gif rename to docs/app.gif From 7cd8c70c32fb53796ee24b4fdcdc04c203f8414a Mon Sep 17 00:00:00 2001 From: tshion Date: Sat, 17 Feb 2024 15:18:46 +0900 Subject: [PATCH 02/24] =?UTF-8?q?=E3=83=89=E3=82=AD=E3=83=A5=E3=83=A1?= =?UTF-8?q?=E3=83=B3=E3=83=88=E3=81=AE=E8=BF=BD=E8=A8=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 19 +++++++++++++++++++ docs/CONTRIBUTING.md | 11 +++-------- 2 files changed, 22 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index 7b429f5..f8261f4 100644 --- a/README.md +++ b/README.md @@ -36,12 +36,31 @@ GitHub リポジトリを検索できるiOS アプリ。 * レビュー方針 * リリースの流れ * 備考 +* [先方からの要求事項](https://github.com/tshion/yumemi-inc_android-engineer-codecheck/blob/develop/docs/Requirements.md) (※別サイト) + * アプリの使い方 + * システム関連 +* [仕様メモ](https://github.com/tshion/yumemi-inc_android-engineer-codecheck/blob/develop/docs/SpecNotes.md) (※別サイト) + * アプリ関連 + * 画面構成とデザイン + * データの取り扱い方針 + * バージョニング + * ログの取り扱い方針 + * 外部システム関連 + * GitHub REST API + * クラッシュ分析ツール + * 備考 + * データセーフティ +* 設計メモ + * TODO +* 各パッケージのREADME + * TODO ## 関連リンク * 複製元リポジトリ: [yumemi-inc/ios-engineer-codecheck] * [複製時点のREADME](./docs/README.original.md) +* [Android 版の開発リポジトリ](https://github.com/tshion/yumemi-inc_android-engineer-codecheck) diff --git a/docs/CONTRIBUTING.md b/docs/CONTRIBUTING.md index 79597b5..7ae7c8d 100644 --- a/docs/CONTRIBUTING.md +++ b/docs/CONTRIBUTING.md @@ -6,14 +6,14 @@ ## 開発環境について 下記のツールをセットアップ後に、 -iOSEngineerCodeCheck.xcodeproj を -Xcode で開くことで開発作業をする環境が整います。 +Xcode で[iOSEngineerCodeCheck.xcodeproj](./iOSEngineerCodeCheck.xcodeproj) を開くことで、 +開発作業に取り掛かれるようになります。 もし何か分からないことが出てきたら、声をかけてください。 * macOS * GitHub -* Xcode +* Xcode 15.2 ### 任意 下記のツールは無くても開発できますが、あると便利なので、興味に応じて試してみてください。 @@ -114,11 +114,6 @@ released | リリースの記録ブランチ ### メモを残したくなったら 本リポジトリでは下記を用意しているので、よさげなところがあればそこに追記してください。 -* 開発にまつわることを書きたい - * [設計メモ](./Architecture.md) - * 各モジュールのREADME -* 仕様にまつわることを書きたい → [仕様メモ](./SpecNotes.md) - それ以外に何かあれば、`docs/` 配下で作業し、Pull Request を出してください。 ### ルールオブスリー(3度目の法則) From 61f43b4a5203f1dde280235b2122da50ec42c5cb Mon Sep 17 00:00:00 2001 From: tshion Date: Sat, 17 Feb 2024 15:21:44 +0900 Subject: [PATCH 03/24] =?UTF-8?q?.gitignore=20=E3=81=AE=E8=AA=BF=E6=95=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 51 ++++++++++++++++++++++++++++++--------------------- 1 file changed, 30 insertions(+), 21 deletions(-) diff --git a/.gitignore b/.gitignore index bd39a7b..e3fca83 100644 --- a/.gitignore +++ b/.gitignore @@ -1,8 +1,6 @@ - -# Created by https://www.toptal.com/developers/gitignore/api/macos,swift,xcode -# Edit at https://www.toptal.com/developers/gitignore?templates=macos,swift,xcode - +############# ### macOS ### +############# # General .DS_Store .AppleDouble @@ -31,7 +29,11 @@ Network Trash Folder Temporary Items .apdisk + + +############# ### Swift ### +############# # Xcode # # gitignore contributors: remember to update Global/Xcode.gitignore, Objective-C.gitignore & Swift.gitignore @@ -69,11 +71,13 @@ timeline.xctimeline playground.xcworkspace # Swift Package Manager +# # Add this line if you want to avoid checking in source code from Swift Package Manager dependencies. # Packages/ # Package.pins # Package.resolved # *.xcodeproj +# # Xcode automatically generates this directory with a .xcworkspacedata file and xcuserdata # hence it is not needed unless you have added a package configuration file to your project # .swiftpm @@ -81,24 +85,29 @@ playground.xcworkspace .build/ # CocoaPods +# # We recommend against adding the Pods directory to your .gitignore. However # you should judge for yourself, the pros and cons are mentioned at: # https://guides.cocoapods.org/using/using-cocoapods.html#should-i-check-the-pods-directory-into-source-control +# # Pods/ +# # Add this line if you want to avoid checking in source code from the Xcode workspace # *.xcworkspace # Carthage +# # Add this line if you want to avoid checking in source code from Carthage dependencies. # Carthage/Checkouts Carthage/Build/ -# Add this lines if you are using Accio dependency management (Deprecated since Xcode 12) -# Dependencies/ -# .accio/ +# Accio dependency management +Dependencies/ +.accio/ # fastlane +# # It is recommended to not store the screenshots in the git repo. # Instead, use fastlane to re-generate the screenshots whenever they are needed. # For more information about the recommended setup visit: @@ -110,26 +119,26 @@ fastlane/screenshots/**/*.png fastlane/test_output # Code Injection +# # After new code Injection tools there's a generated folder /iOSInjectionProject # https://github.com/johnno1962/injectionforxcode iOSInjectionProject/ -### Xcode ### -# Xcode -# gitignore contributors: remember to update Global/Xcode.gitignore, Objective-C.gitignore & Swift.gitignore - - -## Gcc Patch -/*.gcno +########################## +### Visual Studio Code ### +########################## +.vscode/* +!.vscode/settings.json +!.vscode/tasks.json +!.vscode/launch.json +!.vscode/extensions.json +!.vscode/*.code-snippets -### Xcode Patch ### -*.xcodeproj/* -!*.xcodeproj/project.pbxproj -!*.xcodeproj/xcshareddata/ -!*.xcworkspace/contents.xcworkspacedata -**/xcshareddata/WorkspaceSettings.xcsettings +# Local History for Visual Studio Code +.history/ -# End of https://www.toptal.com/developers/gitignore/api/macos,swift,xcode +# Built Visual Studio Code Extensions +*.vsix From ea21a95b918f1d8d78082dc254ca26c5c167e45c Mon Sep 17 00:00:00 2001 From: tshion Date: Sat, 17 Feb 2024 15:24:57 +0900 Subject: [PATCH 04/24] =?UTF-8?q?GitHub=20Issue=20or=20PR=20=E4=BD=9C?= =?UTF-8?q?=E6=88=90=E6=96=87=E8=A8=80=E3=81=AE=E3=83=86=E3=83=B3=E3=83=97?= =?UTF-8?q?=E3=83=AC=E3=83=BC=E3=83=88=E8=BF=BD=E5=8A=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/issue_template.md | 19 +++++++++++++++++++ .github/pull_request_template.md | 27 +++++++++++++++++++++++++++ 2 files changed, 46 insertions(+) create mode 100644 .github/issue_template.md create mode 100644 .github/pull_request_template.md diff --git a/.github/issue_template.md b/.github/issue_template.md new file mode 100644 index 0000000..4f57edd --- /dev/null +++ b/.github/issue_template.md @@ -0,0 +1,19 @@ +## 概要 + + + +## 作業内容 +### 完了条件 +* TODO + +### 想定される範囲 +* TODO + +### 対応しないこと +* TODO + + + +## 備考 +### 参考文献 +* TODO diff --git a/.github/pull_request_template.md b/.github/pull_request_template.md new file mode 100644 index 0000000..40f8c42 --- /dev/null +++ b/.github/pull_request_template.md @@ -0,0 +1,27 @@ +* [ ] 新規追加 +* [ ] 既存改良 +* [ ] 不具合修正 + +## 概要 + + + +## 変更点 +### 追加 +* TODO + +### 削除 +* TODO + +### 修正 +* TODO + + + +## 確認事項 +* [ ] TODO + + + +## 備考 +* TODO From 6549ca9c9bcb27b401e33790fcf00f0f3746855d Mon Sep 17 00:00:00 2001 From: tshion Date: Sun, 18 Feb 2024 10:44:55 +0900 Subject: [PATCH 05/24] =?UTF-8?q?vscode=20=E8=A8=AD=E5=AE=9A=E3=81=AE?= =?UTF-8?q?=E6=95=B4=E5=82=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .vscode/extensions.json | 7 +++++++ .vscode/settings.json | 5 +++++ 2 files changed, 12 insertions(+) create mode 100644 .vscode/extensions.json create mode 100644 .vscode/settings.json diff --git a/.vscode/extensions.json b/.vscode/extensions.json new file mode 100644 index 0000000..7cff864 --- /dev/null +++ b/.vscode/extensions.json @@ -0,0 +1,7 @@ +{ + "recommendations": [ + "github.vscode-pull-request-github", + "jebbs.plantuml", + "redhat.vscode-yaml", + ] +} \ No newline at end of file diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 0000000..ef83f48 --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,5 @@ +{ + "githubPullRequests.ignoredPullRequestBranches": [ + "develop" + ] +} \ No newline at end of file From c9e9ab98a710d68e1afec952f66044b80836e57a Mon Sep 17 00:00:00 2001 From: tshion Date: Thu, 22 Feb 2024 17:14:31 +0900 Subject: [PATCH 06/24] =?UTF-8?q?xcconfig=20=E3=81=AE=E8=BF=BD=E5=8A=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Build.xcconfig | 5 +++++ iOSEngineerCodeCheck.xcodeproj/project.pbxproj | 4 ++++ iOSEngineerCodeCheck/Info.plist | 4 ++-- 3 files changed, 11 insertions(+), 2 deletions(-) create mode 100644 Build.xcconfig diff --git a/Build.xcconfig b/Build.xcconfig new file mode 100644 index 0000000..8f96c14 --- /dev/null +++ b/Build.xcconfig @@ -0,0 +1,5 @@ +// アプリバージョンの整理番号 +APP_VERSION_CODE = 1 + +// アプリバージョンの文字表記 +APP_VERSION_NAME = 1.0 diff --git a/iOSEngineerCodeCheck.xcodeproj/project.pbxproj b/iOSEngineerCodeCheck.xcodeproj/project.pbxproj index 933f9df..2d93f21 100644 --- a/iOSEngineerCodeCheck.xcodeproj/project.pbxproj +++ b/iOSEngineerCodeCheck.xcodeproj/project.pbxproj @@ -36,6 +36,7 @@ /* End PBXContainerItemProxy section */ /* Begin PBXFileReference section */ + 050D42562B8734DA00138A40 /* Build.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = Build.xcconfig; sourceTree = ""; }; BF0A658C244F2A3B00280FA6 /* ViewController2.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewController2.swift; sourceTree = ""; }; BFD945DB244DC5E80012785A /* iOSEngineerCodeCheck.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = iOSEngineerCodeCheck.app; sourceTree = BUILT_PRODUCTS_DIR; }; BFD945DE244DC5E80012785A /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; @@ -81,6 +82,7 @@ BFD945D2244DC5E80012785A = { isa = PBXGroup; children = ( + 050D42562B8734DA00138A40 /* Build.xcconfig */, BFD945DD244DC5E80012785A /* iOSEngineerCodeCheck */, BFD945F4244DC5EB0012785A /* iOSEngineerCodeCheckTests */, BFD945FF244DC5EB0012785A /* iOSEngineerCodeCheckUITests */, @@ -323,6 +325,7 @@ /* Begin XCBuildConfiguration section */ BFD94603244DC5EC0012785A /* Debug */ = { isa = XCBuildConfiguration; + baseConfigurationReference = 050D42562B8734DA00138A40 /* Build.xcconfig */; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; CLANG_ANALYZER_NONNULL = YES; @@ -385,6 +388,7 @@ }; BFD94604244DC5EC0012785A /* Release */ = { isa = XCBuildConfiguration; + baseConfigurationReference = 050D42562B8734DA00138A40 /* Build.xcconfig */; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; CLANG_ANALYZER_NONNULL = YES; diff --git a/iOSEngineerCodeCheck/Info.plist b/iOSEngineerCodeCheck/Info.plist index 2a3483c..74ed3ae 100644 --- a/iOSEngineerCodeCheck/Info.plist +++ b/iOSEngineerCodeCheck/Info.plist @@ -15,9 +15,9 @@ CFBundlePackageType $(PRODUCT_BUNDLE_PACKAGE_TYPE) CFBundleShortVersionString - 1.0 + $(APP_VERSION_NAME) CFBundleVersion - 1 + $(APP_VERSION_CODE) LSRequiresIPhoneOS UIApplicationSceneManifest From b36386a5ff88125340ed2ad4f93c91cd6ebd4b4f Mon Sep 17 00:00:00 2001 From: tshion Date: Thu, 22 Feb 2024 17:44:20 +0900 Subject: [PATCH 07/24] =?UTF-8?q?=E7=92=B0=E5=A2=83=E6=95=B4=E5=82=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .editorconfig | 20 ++++++++++++++++++++ .ruby-version | 1 + .vscode/extensions.json | 1 + 3 files changed, 22 insertions(+) create mode 100644 .editorconfig create mode 100644 .ruby-version diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 0000000..66ea1c2 --- /dev/null +++ b/.editorconfig @@ -0,0 +1,20 @@ +# http://editorconfig.org +root = true + +[*] +charset = utf-8 +indent_size = 4 +indent_style = space +insert_final_newline = true +trim_trailing_whitespace = true + +[*.json] +insert_final_newline = false + +[*.md] +max_line_length = off +insert_final_newline = false +trim_trailing_whitespace = false + +[*.{yaml,yml}] +indent_size = 2 diff --git a/.ruby-version b/.ruby-version new file mode 100644 index 0000000..15a2799 --- /dev/null +++ b/.ruby-version @@ -0,0 +1 @@ +3.3.0 diff --git a/.vscode/extensions.json b/.vscode/extensions.json index 7cff864..ed66e92 100644 --- a/.vscode/extensions.json +++ b/.vscode/extensions.json @@ -1,5 +1,6 @@ { "recommendations": [ + "editorconfig.editorconfig", "github.vscode-pull-request-github", "jebbs.plantuml", "redhat.vscode-yaml", From 8b26457d52288f7ae0c8cfc68625a71c21568ea1 Mon Sep 17 00:00:00 2001 From: tshion Date: Thu, 22 Feb 2024 18:30:04 +0900 Subject: [PATCH 08/24] =?UTF-8?q?=E6=9B=B8=E3=81=8D=E6=8F=9B=E3=81=88?= =?UTF-8?q?=E3=82=B9=E3=82=AF=E3=83=AA=E3=83=97=E3=83=88=E3=81=AE=E6=95=B4?= =?UTF-8?q?=E5=82=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- scripts/set-version.rb | 54 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 scripts/set-version.rb diff --git a/scripts/set-version.rb b/scripts/set-version.rb new file mode 100644 index 0000000..f68452a --- /dev/null +++ b/scripts/set-version.rb @@ -0,0 +1,54 @@ +#!/usr/bin/env ruby + +# 注意事項 +# * 前提: プロジェクトルートで実行すること + + +# 作業対象のパス設定 +PATH = "#{Dir.pwd}/Build.xcconfig" + + +# コマンドライン引数の検証 +unless ARGV.length == 3 then + puts("引数を3つ指定してください") + exit +end + +MAJOR = ARGV[0] +unless /^\d+$/.match?(MAJOR) then + puts("major には正整数を指定してください") + exit +end + +MINOR = ARGV[1] +unless /^\d{1,2}$/.match?(MINOR) then + puts("minor には1 ~ 2桁の正整数を指定してください") + exit +end + +PATCH = ARGV[2] +unless /^\d{1,2}$/.match?(PATCH) then + puts("patch には1 ~ 2桁の正整数を指定してください") + exit +end + + +# バージョン情報の算出 +VERSION_CODE = MAJOR.to_i * 10000 + MINOR.to_i * 100 + PATCH.to_i +VERSION_NAME = "#{MAJOR}.#{MINOR}.#{PATCH}" + + +# ファイル出力 +text = "" +File.open(PATH, "r") { |file| + text = file.read +} +text = text.gsub(/^(APP_VERSION_CODE = )(\d+)$/) { "#{$1}#{VERSION_CODE}" } +text = text.gsub(/^(APP_VERSION_NAME = )(\d[\d\.]{0,}\d)$/) { "#{$1}#{VERSION_NAME}" } +File.open(PATH, "w") { |file| + file.write(text) +} + + +# 終了表示 +puts("Set code: #{VERSION_CODE}, name: #{VERSION_NAME}") From 817d9334aacfc7267abf81c929dfbcf2b0d486c6 Mon Sep 17 00:00:00 2001 From: tshion Date: Thu, 22 Feb 2024 18:38:12 +0900 Subject: [PATCH 09/24] =?UTF-8?q?VSCode=20=E3=82=BF=E3=82=B9=E3=82=AF?= =?UTF-8?q?=E3=81=AE=E8=AA=BF=E6=95=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .vscode/tasks.json | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 .vscode/tasks.json diff --git a/.vscode/tasks.json b/.vscode/tasks.json new file mode 100644 index 0000000..658952a --- /dev/null +++ b/.vscode/tasks.json @@ -0,0 +1,35 @@ +{ + // See https://go.microsoft.com/fwlink/?LinkId=733558 + // for the documentation about the tasks.json format + "version": "2.0.0", + "tasks": [ + { + "label": "アプリバージョン更新", + "type": "shell", + "command": "ruby", + "args": [ + "scripts/set-version.rb", + "${input:versionMajor}", + "${input:versionMinor}", + "${input:versionPatch}", + ] + } + ], + "inputs": [ + { + "id": "versionMajor", + "type": "promptString", + "description": "バージョン情報: major" + }, + { + "id": "versionMinor", + "type": "promptString", + "description": "バージョン情報: minor" + }, + { + "id": "versionPatch", + "type": "promptString", + "description": "バージョン情報: patch" + } + ] +} \ No newline at end of file From 29f6fe9e0a1955822c5beb10dca0cea6745fa8e2 Mon Sep 17 00:00:00 2001 From: tshion Date: Thu, 22 Feb 2024 18:39:47 +0900 Subject: [PATCH 10/24] =?UTF-8?q?=E3=83=89=E3=82=AD=E3=83=A5=E3=83=A1?= =?UTF-8?q?=E3=83=B3=E3=83=88=E3=81=AE=E8=BF=BD=E8=A8=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- docs/CONTRIBUTING.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/docs/CONTRIBUTING.md b/docs/CONTRIBUTING.md index 7ae7c8d..b86cf7f 100644 --- a/docs/CONTRIBUTING.md +++ b/docs/CONTRIBUTING.md @@ -70,6 +70,8 @@ Xcode で[iOSEngineerCodeCheck.xcodeproj](./iOSEngineerCodeCheck.xcodeproj) を ## リリース作業の流れ 1. リリース対象Pull Request が`develop` ブランチに全てマージされていることを確認する 1. `develop` ブランチに切り替え、アプリバージョンを更新し、コミットする + * アプリバージョンはVSCode タスク「アプリバージョンの更新」で更新することもできる + * Ruby が実行できる環境が必要 1. `develop` ブランチから`released` ブランチにPull Request を作成する * 例: [Android PR #16](https://github.com/tshion/yumemi-inc_android-engineer-codecheck/pull/16) 1. 問題なければPull Request をマージする From c0e31e9459528098423367bdaa9071a67ce3a1e5 Mon Sep 17 00:00:00 2001 From: tshion Date: Fri, 23 Feb 2024 13:12:01 +0900 Subject: [PATCH 11/24] =?UTF-8?q?=E7=95=B0=E5=B8=B8=E7=B5=82=E4=BA=86?= =?UTF-8?q?=E6=99=82=E3=81=AE=E3=82=B7=E3=82=B0=E3=83=8A=E3=83=AB=E8=BF=BD?= =?UTF-8?q?=E5=8A=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- scripts/set-version.rb | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/scripts/set-version.rb b/scripts/set-version.rb index f68452a..bb4f759 100644 --- a/scripts/set-version.rb +++ b/scripts/set-version.rb @@ -11,25 +11,25 @@ # コマンドライン引数の検証 unless ARGV.length == 3 then puts("引数を3つ指定してください") - exit + exit 1 end MAJOR = ARGV[0] unless /^\d+$/.match?(MAJOR) then puts("major には正整数を指定してください") - exit + exit 1 end MINOR = ARGV[1] unless /^\d{1,2}$/.match?(MINOR) then puts("minor には1 ~ 2桁の正整数を指定してください") - exit + exit 1 end PATCH = ARGV[2] unless /^\d{1,2}$/.match?(PATCH) then puts("patch には1 ~ 2桁の正整数を指定してください") - exit + exit 1 end From 95f5f49bc0a5c22bae10c3a5abd41d066908a063 Mon Sep 17 00:00:00 2001 From: tshion Date: Fri, 23 Feb 2024 13:28:39 +0900 Subject: [PATCH 12/24] =?UTF-8?q?=E4=BD=9C=E6=A5=AD=E5=AF=BE=E8=B1=A1?= =?UTF-8?q?=E3=83=95=E3=82=A1=E3=82=A4=E3=83=AB=E3=83=91=E3=82=B9=E3=81=AE?= =?UTF-8?q?=E8=AA=BF=E6=95=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- scripts/set-version.rb | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/scripts/set-version.rb b/scripts/set-version.rb index bb4f759..ce0b878 100644 --- a/scripts/set-version.rb +++ b/scripts/set-version.rb @@ -4,8 +4,15 @@ # * 前提: プロジェクトルートで実行すること -# 作業対象のパス設定 -PATH = "#{Dir.pwd}/Build.xcconfig" +require 'pathname' + + +# 作業対象ファイルの設定と検証 +PATH = Pathname.new(__dir__).join("../Build.xcconfig") +unless FileTest.exist?(PATH) then + puts("#{PATH} にファイルが存在しません") + exit 1 +end # コマンドライン引数の検証 From 4d433e4efec8ac25f7a6429c1e5a774fcb511d4f Mon Sep 17 00:00:00 2001 From: tshion Date: Fri, 23 Feb 2024 13:32:25 +0900 Subject: [PATCH 13/24] =?UTF-8?q?=E3=83=89=E3=82=AD=E3=83=A5=E3=83=A1?= =?UTF-8?q?=E3=83=B3=E3=83=88=E3=81=AE=E8=AA=BF=E6=95=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- docs/CONTRIBUTING.md | 2 ++ scripts/set-version.rb | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/docs/CONTRIBUTING.md b/docs/CONTRIBUTING.md index b86cf7f..6f078f0 100644 --- a/docs/CONTRIBUTING.md +++ b/docs/CONTRIBUTING.md @@ -18,6 +18,7 @@ Xcode で[iOSEngineerCodeCheck.xcodeproj](./iOSEngineerCodeCheck.xcodeproj) を ### 任意 下記のツールは無くても開発できますが、あると便利なので、興味に応じて試してみてください。 +* [rbenv](https://github.com/rbenv/rbenv) * [Visual Studio Code](https://code.visualstudio.com/) * .gitignore の記述 * GitHub Actions の構築 @@ -25,6 +26,7 @@ Xcode で[iOSEngineerCodeCheck.xcodeproj](./iOSEngineerCodeCheck.xcodeproj) を * Markdown の記述 * [OpenAPI](https://www.openapis.org/) の記述 * [PlantUML](https://plantuml.com/) の記述 + * Ruby の記述 diff --git a/scripts/set-version.rb b/scripts/set-version.rb index ce0b878..9956628 100644 --- a/scripts/set-version.rb +++ b/scripts/set-version.rb @@ -1,7 +1,7 @@ #!/usr/bin/env ruby # 注意事項 -# * 前提: プロジェクトルートで実行すること +# * ".ruby-version" に記載されているバージョンで実行してください require 'pathname' From cf008fb030435533ea368180daa460f3ded86c16 Mon Sep 17 00:00:00 2001 From: tshion Date: Fri, 23 Feb 2024 14:51:47 +0900 Subject: [PATCH 14/24] =?UTF-8?q?=E7=92=B0=E5=A2=83=E6=95=B4=E5=82=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 62 +++++++++++++++++++++++++++++++++++++++++ .vscode/extensions.json | 1 + .vscode/settings.json | 3 +- 3 files changed, 65 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index e3fca83..e2baa30 100644 --- a/.gitignore +++ b/.gitignore @@ -31,6 +31,68 @@ Temporary Items +############ +### Ruby ### +############ +*.gem +*.rbc +/.config +/coverage/ +/InstalledFiles +/pkg/ +/spec/reports/ +/spec/examples.txt +/test/tmp/ +/test/version_tmp/ +/tmp/ + +# Used by dotenv library to load environment variables. +# .env + +# Ignore Byebug command history file. +.byebug_history + +## Specific to RubyMotion: +.dat* +.repl_history +build/ +*.bridgesupport +build-iPhoneOS/ +build-iPhoneSimulator/ + +## Specific to RubyMotion (use of CocoaPods): +# +# We recommend against adding the Pods directory to your .gitignore. However +# you should judge for yourself, the pros and cons are mentioned at: +# https://guides.cocoapods.org/using/using-cocoapods.html#should-i-check-the-pods-directory-into-source-control +# +# vendor/Pods/ + +## Documentation cache and generated files: +/.yardoc/ +/_yardoc/ +/doc/ +/rdoc/ + +## Environment normalization: +/.bundle/ +/vendor/bundle +/lib/bundler/man/ + +# for a library or gem, you might want to ignore these files since the code is +# intended to run in multiple environments; otherwise, check them in: +# Gemfile.lock +# .ruby-version +# .ruby-gemset + +# unless supporting rvm < 1.11.0 or doing something fancy, ignore this: +.rvmrc + +# Used by RuboCop. Remote config files pulled in from inherit_from directive. +# .rubocop-https?--* + + + ############# ### Swift ### ############# diff --git a/.vscode/extensions.json b/.vscode/extensions.json index ed66e92..7d90b5f 100644 --- a/.vscode/extensions.json +++ b/.vscode/extensions.json @@ -4,5 +4,6 @@ "github.vscode-pull-request-github", "jebbs.plantuml", "redhat.vscode-yaml", + "shopify.ruby-lsp", ] } \ No newline at end of file diff --git a/.vscode/settings.json b/.vscode/settings.json index ef83f48..0cb676c 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -1,5 +1,6 @@ { "githubPullRequests.ignoredPullRequestBranches": [ "develop" - ] + ], + "rubyLsp.rubyVersionManager": "rbenv", } \ No newline at end of file From 3ff6b8c7c9a0222467ca51dc1fa97f96601c1535 Mon Sep 17 00:00:00 2001 From: tshion Date: Fri, 23 Feb 2024 16:34:23 +0900 Subject: [PATCH 15/24] =?UTF-8?q?=E3=82=B9=E3=82=AF=E3=83=AA=E3=83=97?= =?UTF-8?q?=E3=83=88=E3=81=AE=E8=BF=BD=E5=8A=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- scripts/pick-version-name.rb | 31 +++++++++++++++++++++++++++++++ scripts/set-version.rb | 2 ++ 2 files changed, 33 insertions(+) create mode 100644 scripts/pick-version-name.rb diff --git a/scripts/pick-version-name.rb b/scripts/pick-version-name.rb new file mode 100644 index 0000000..c2b0265 --- /dev/null +++ b/scripts/pick-version-name.rb @@ -0,0 +1,31 @@ +#!/usr/bin/env ruby + +# アプリバージョン文字列の抽出 +# +# 注意事項 +# * ".ruby-version" に記載されているバージョンで実行してください + + +require 'pathname' + + +# 作業対象ファイルの設定と検証 +PATH = Pathname.new(__dir__).join("../Build.xcconfig") +unless FileTest.exist?(PATH) then + puts("#{PATH} にファイルが存在しません") + exit 1 +end + + +# ファイル読み込み +text = "" +File.open(PATH, "r") { |file| + text = file.read +} + + +# アプリバージョン文字列の抽出 +VERSION_NAME = text.scan(/^APP_VERSION_NAME = (\d[\d\.]{0,}\d)$/) + +# 終了表示 +puts(VERSION_NAME) diff --git a/scripts/set-version.rb b/scripts/set-version.rb index 9956628..e0b62d5 100644 --- a/scripts/set-version.rb +++ b/scripts/set-version.rb @@ -1,5 +1,7 @@ #!/usr/bin/env ruby +# アプリバージョンの更新 +# # 注意事項 # * ".ruby-version" に記載されているバージョンで実行してください From b4f9ebad1ad4dd72b6aa4b344dc39aca06c9284c Mon Sep 17 00:00:00 2001 From: tshion Date: Fri, 23 Feb 2024 17:06:23 +0900 Subject: [PATCH 16/24] =?UTF-8?q?GitHub=20Release=20=E3=82=92=E8=87=AA?= =?UTF-8?q?=E5=8B=95=E7=94=9F=E6=88=90=E3=81=99=E3=82=8BActions=20?= =?UTF-8?q?=E3=81=AE=E6=95=B4=E5=82=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/create-release.yml | 36 ++++++++++++++++++++++++++++ .vscode/extensions.json | 1 + 2 files changed, 37 insertions(+) create mode 100644 .github/workflows/create-release.yml diff --git a/.github/workflows/create-release.yml b/.github/workflows/create-release.yml new file mode 100644 index 0000000..eee8334 --- /dev/null +++ b/.github/workflows/create-release.yml @@ -0,0 +1,36 @@ +name: Create release + +on: + push: + branches: + - released + workflow_dispatch: + +jobs: + create-release: + runs-on: ubuntu-latest + permissions: + contents: write + steps: + # https://github.com/actions/checkout + - uses: actions/checkout@v4 + + # https://github.com/ruby/setup-ruby + - uses: ruby/setup-ruby@v1 + + - name: Pick version name + id: app-version + run: | + echo "$(ruby scripts/pick-version-name.rb)" > TMP_LOG + echo "version-name=$(cat TMP_LOG)" >> "$GITHUB_OUTPUT" + + - name: Set git tag + run: | + echo "${{ steps.app-version.outputs.version-name }}" > TAG_NAME + git tag "$(cat TAG_NAME)" + git push origin "$(cat TAG_NAME)" + + - name: Create release + run: gh release create "${{ steps.app-version.outputs.version-name }}" --generate-notes --title "${{ steps.app-version.outputs.version-name }}" + env: + GITHUB_TOKEN: ${{ github.token }} diff --git a/.vscode/extensions.json b/.vscode/extensions.json index 7d90b5f..a9ecf5d 100644 --- a/.vscode/extensions.json +++ b/.vscode/extensions.json @@ -1,6 +1,7 @@ { "recommendations": [ "editorconfig.editorconfig", + "github.vscode-github-actions", "github.vscode-pull-request-github", "jebbs.plantuml", "redhat.vscode-yaml", From bbce94ace646a4f01f50bb07455971f0a1e487d7 Mon Sep 17 00:00:00 2001 From: tshion Date: Fri, 23 Feb 2024 22:36:46 +0900 Subject: [PATCH 17/24] =?UTF-8?q?=E3=82=A2=E3=83=97=E3=83=AA=E3=83=90?= =?UTF-8?q?=E3=83=BC=E3=82=B8=E3=83=A7=E3=83=B3=E3=82=92=E6=9B=B4=E6=96=B0?= =?UTF-8?q?=E3=81=99=E3=82=8BGitHub=20Actions=20=E3=81=AE=E8=BF=BD?= =?UTF-8?q?=E5=8A=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/update-app-version.yml | 56 ++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 .github/workflows/update-app-version.yml diff --git a/.github/workflows/update-app-version.yml b/.github/workflows/update-app-version.yml new file mode 100644 index 0000000..2e4df40 --- /dev/null +++ b/.github/workflows/update-app-version.yml @@ -0,0 +1,56 @@ +name: Update app version + +on: + workflow_dispatch: + inputs: + versionMajor: + description: 'バージョン情報: major' + required: true + type: string + versionMinor: + description: 'バージョン情報: minor' + required: true + type: string + versionPatch: + description: 'バージョン情報: patch' + required: true + type: string + +jobs: + update-app-version: + runs-on: ubuntu-latest + permissions: + contents: write + pull-requests: write + steps: + # https://github.com/actions/checkout + - uses: actions/checkout@v4 + + # https://github.com/ruby/setup-ruby + - uses: ruby/setup-ruby@v1 + + - name: Update app version + id: app-version + run: | + ruby scripts/set-version.rb ${{ inputs.versionMajor }} ${{ inputs.versionMinor }} ${{ inputs.versionPatch }} + echo "$(ruby scripts/pick-version-name.rb)" > TMP_LOG + echo "version-name=$(cat TMP_LOG)" >> "$GITHUB_OUTPUT" + + - name: Setup git settings + run: | + git config --local user.email "github.actions@example.com" + git config --local user.name "GitHub Actions" + echo "Finish setup git" + + - name: Git push + run: | + git switch -c "feature/${{ steps.app-version.outputs.version-name }}" + git add Build.xcconfig + git commit -m "Update app version ${{ steps.app-version.outputs.version-name }}" + git push origin + echo "Updated git" + + - name: Create pull request + run: gh pr create --title "Update app version ${{ steps.app-version.outputs.version-name }}" --body "" + env: + GITHUB_TOKEN: ${{ github.token }} From 9a2b263dffaffdb068c27d494a38fc2f7b8a3061 Mon Sep 17 00:00:00 2001 From: tshion Date: Fri, 23 Feb 2024 22:54:26 +0900 Subject: [PATCH 18/24] =?UTF-8?q?=E3=83=90=E3=82=B0=E4=BF=AE=E6=AD=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/update-app-version.yml | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/.github/workflows/update-app-version.yml b/.github/workflows/update-app-version.yml index 2e4df40..983a773 100644 --- a/.github/workflows/update-app-version.yml +++ b/.github/workflows/update-app-version.yml @@ -34,21 +34,20 @@ jobs: run: | ruby scripts/set-version.rb ${{ inputs.versionMajor }} ${{ inputs.versionMinor }} ${{ inputs.versionPatch }} echo "$(ruby scripts/pick-version-name.rb)" > TMP_LOG + echo "branch-name=feature/update_$(cat TMP_LOG)" >> "$GITHUB_OUTPUT" echo "version-name=$(cat TMP_LOG)" >> "$GITHUB_OUTPUT" - name: Setup git settings run: | git config --local user.email "github.actions@example.com" git config --local user.name "GitHub Actions" - echo "Finish setup git" - name: Git push run: | - git switch -c "feature/${{ steps.app-version.outputs.version-name }}" + git switch -c ${{ steps.app-version.outputs.branch-name }} git add Build.xcconfig - git commit -m "Update app version ${{ steps.app-version.outputs.version-name }}" - git push origin - echo "Updated git" + git commit -m "Update ${{ steps.app-version.outputs.version-name }}" + git push --set-upstream origin ${{ steps.app-version.outputs.branch-name }} - name: Create pull request run: gh pr create --title "Update app version ${{ steps.app-version.outputs.version-name }}" --body "" From 2b2319b7491a01dc467875eaceb34ebeaad20d4c Mon Sep 17 00:00:00 2001 From: tshion Date: Sat, 24 Feb 2024 11:24:05 +0900 Subject: [PATCH 19/24] =?UTF-8?q?Git=20=E3=83=A6=E3=83=BC=E3=82=B6?= =?UTF-8?q?=E3=83=BC=E3=81=AE=E8=AA=BF=E6=95=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/update-app-version.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/update-app-version.yml b/.github/workflows/update-app-version.yml index 983a773..cfb24b9 100644 --- a/.github/workflows/update-app-version.yml +++ b/.github/workflows/update-app-version.yml @@ -39,7 +39,7 @@ jobs: - name: Setup git settings run: | - git config --local user.email "github.actions@example.com" + git config --local user.email "41898282+github-actions[bot]@users.noreply.github.com" git config --local user.name "GitHub Actions" - name: Git push From 1c87ff1bd3a2ac99573a448b5859a029a414d640 Mon Sep 17 00:00:00 2001 From: tshion Date: Sat, 24 Feb 2024 11:25:40 +0900 Subject: [PATCH 20/24] =?UTF-8?q?=E3=82=B3=E3=83=9F=E3=83=83=E3=83=88?= =?UTF-8?q?=E3=83=A1=E3=83=83=E3=82=BB=E3=83=BC=E3=82=B8=E3=81=AE=E8=AA=BF?= =?UTF-8?q?=E6=95=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/update-app-version.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/update-app-version.yml b/.github/workflows/update-app-version.yml index cfb24b9..04756b1 100644 --- a/.github/workflows/update-app-version.yml +++ b/.github/workflows/update-app-version.yml @@ -50,6 +50,6 @@ jobs: git push --set-upstream origin ${{ steps.app-version.outputs.branch-name }} - name: Create pull request - run: gh pr create --title "Update app version ${{ steps.app-version.outputs.version-name }}" --body "" + run: 'gh pr create --title "アプリバージョン更新: ${{ steps.app-version.outputs.version-name }}" --body ""' env: GITHUB_TOKEN: ${{ github.token }} From da069302f039a360914db4027e0296ce624d26c6 Mon Sep 17 00:00:00 2001 From: tshion Date: Sat, 24 Feb 2024 11:38:13 +0900 Subject: [PATCH 21/24] =?UTF-8?q?=E6=96=87=E8=A8=80=E3=81=AE=E8=AA=BF?= =?UTF-8?q?=E6=95=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/update-app-version.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/update-app-version.yml b/.github/workflows/update-app-version.yml index 04756b1..dadee0f 100644 --- a/.github/workflows/update-app-version.yml +++ b/.github/workflows/update-app-version.yml @@ -35,7 +35,7 @@ jobs: ruby scripts/set-version.rb ${{ inputs.versionMajor }} ${{ inputs.versionMinor }} ${{ inputs.versionPatch }} echo "$(ruby scripts/pick-version-name.rb)" > TMP_LOG echo "branch-name=feature/update_$(cat TMP_LOG)" >> "$GITHUB_OUTPUT" - echo "version-name=$(cat TMP_LOG)" >> "$GITHUB_OUTPUT" + echo "message=アプリバージョン更新: $(cat TMP_LOG)" >> "$GITHUB_OUTPUT" - name: Setup git settings run: | @@ -46,10 +46,10 @@ jobs: run: | git switch -c ${{ steps.app-version.outputs.branch-name }} git add Build.xcconfig - git commit -m "Update ${{ steps.app-version.outputs.version-name }}" + git commit -m "${{ steps.app-version.outputs.message }}" git push --set-upstream origin ${{ steps.app-version.outputs.branch-name }} - name: Create pull request - run: 'gh pr create --title "アプリバージョン更新: ${{ steps.app-version.outputs.version-name }}" --body ""' + run: gh pr create --title "${{ steps.app-version.outputs.message }}" --body "" env: GITHUB_TOKEN: ${{ github.token }} From cbe26ce4d1d493116058636b4cb3d93c096e2b55 Mon Sep 17 00:00:00 2001 From: tshion Date: Sat, 24 Feb 2024 13:31:21 +0900 Subject: [PATCH 22/24] =?UTF-8?q?=E3=83=AF=E3=83=BC=E3=82=AF=E3=83=95?= =?UTF-8?q?=E3=83=AD=E3=83=BC=E3=81=AE=E8=BF=BD=E5=8A=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/create-merge-pr.yml | 35 +++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 .github/workflows/create-merge-pr.yml diff --git a/.github/workflows/create-merge-pr.yml b/.github/workflows/create-merge-pr.yml new file mode 100644 index 0000000..828f0b3 --- /dev/null +++ b/.github/workflows/create-merge-pr.yml @@ -0,0 +1,35 @@ +name: Create merge pull request + +on: + pull_request: + types: + - closed + paths: + - 'Build.xcconfig' + workflow_dispatch: + +jobs: + create-merge-pr: + if: >- + github.event_name == 'workflow_dispatch' || + (github.event.pull_request.merged == true && startsWith(github.event.pull_request.title, 'アプリバージョン更新')) + runs-on: ubuntu-latest + permissions: + pull-requests: write + steps: + # https://github.com/actions/checkout + - uses: actions/checkout@v4 + + # https://github.com/ruby/setup-ruby + - uses: ruby/setup-ruby@v1 + + - name: Pick version name + id: app-version + run: | + echo "$(ruby scripts/pick-version-name.rb)" > TMP_LOG + echo "message=Merge $(cat TMP_LOG)" >> "$GITHUB_OUTPUT" + + - name: Create pull request + run: gh pr create --base released --title "${{ steps.app-version.outputs.message }}" --body "" + env: + GITHUB_TOKEN: ${{ github.token }} From 4f48fe5815fac250a20bfa57cd0b30813170c850 Mon Sep 17 00:00:00 2001 From: tshion Date: Sat, 24 Feb 2024 13:32:39 +0900 Subject: [PATCH 23/24] =?UTF-8?q?=E3=83=96=E3=83=A9=E3=83=B3=E3=83=81?= =?UTF-8?q?=E9=99=A4=E5=A4=96=E8=A8=AD=E5=AE=9A=E3=81=AE=E8=BF=BD=E5=8A=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/create-merge-pr.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/create-merge-pr.yml b/.github/workflows/create-merge-pr.yml index 828f0b3..0265eee 100644 --- a/.github/workflows/create-merge-pr.yml +++ b/.github/workflows/create-merge-pr.yml @@ -4,6 +4,8 @@ on: pull_request: types: - closed + branches-ignore: + - 'released' paths: - 'Build.xcconfig' workflow_dispatch: From cbfa1a459bef317833a3b96ff541ab742e98fe02 Mon Sep 17 00:00:00 2001 From: tshion Date: Sat, 24 Feb 2024 13:56:20 +0900 Subject: [PATCH 24/24] =?UTF-8?q?=E3=83=89=E3=82=AD=E3=83=A5=E3=83=A1?= =?UTF-8?q?=E3=83=B3=E3=83=88=E3=81=AE=E6=9B=B4=E6=96=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- docs/CONTRIBUTING.md | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/docs/CONTRIBUTING.md b/docs/CONTRIBUTING.md index 6f078f0..3bf05cc 100644 --- a/docs/CONTRIBUTING.md +++ b/docs/CONTRIBUTING.md @@ -51,6 +51,7 @@ Xcode で[iOSEngineerCodeCheck.xcodeproj](./iOSEngineerCodeCheck.xcodeproj) を * 名前は`hotfix/???` という形式で、`???` の部分を良い感じに設定してください 1. バグ修正をする 1. アプリバージョンを更新する + * 後述する「リリース作業の流れ」にあるアプリバージョンを更新するGitHub Actions も利用できます 1. 作業が完了したら下記ブランチそれぞれに対してPull Request を作成する * `released` ブランチ -> 例: [Android PR #51](https://github.com/tshion/yumemi-inc_android-engineer-codecheck/pull/51) * `develop` ブランチ -> 例: [Android PR #52](https://github.com/tshion/yumemi-inc_android-engineer-codecheck/pull/52) @@ -71,13 +72,17 @@ Xcode で[iOSEngineerCodeCheck.xcodeproj](./iOSEngineerCodeCheck.xcodeproj) を ## リリース作業の流れ 1. リリース対象Pull Request が`develop` ブランチに全てマージされていることを確認する -1. `develop` ブランチに切り替え、アプリバージョンを更新し、コミットする - * アプリバージョンはVSCode タスク「アプリバージョンの更新」で更新することもできる - * Ruby が実行できる環境が必要 -1. `develop` ブランチから`released` ブランチにPull Request を作成する - * 例: [Android PR #16](https://github.com/tshion/yumemi-inc_android-engineer-codecheck/pull/16) -1. 問題なければPull Request をマージする -1. GitHub Actions が自動実行されるので、様子を見る +1. https://github.com/tshion/yumemi-inc_ios-engineer-codecheck/actions/workflows/update-app-version.yml に移動し、GitHub Actions を実行する + * アプリバージョンを更新するPull Request が作成されます + * ローカルの場合は、Ruby の実行環境を整備した上で、下記を実行し、Pull Request を作成してください + * VSCode タスク「アプリバージョンの更新」を実行する + * プロジェクトルートで `ruby scripts/set-version.rb x y z` を実行する +1. 前の手順で作成したPull Request に問題がなければマージする +1. `released` ブランチへのマージPull Request が作成されるはずなので、しばらく待つ + * 手動実行する場合は、下記に移動してください + * https://github.com/tshion/yumemi-inc_ios-engineer-codecheck/actions/workflows/create-merge-pr.yml +1. 前の手順で作成したPull Request に問題がなければマージする +1. GitHub Releases が自動生成されるので、様子を見る ※`hotfix` ブランチの場合は、`released` ブランチに対してPull Request を作成するので、それをマージすればリリース処理が走ります