Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
今日話すこと / debut-sushi_haneda
Search
Cybozu
PRO
September 16, 2021
Technology
0
350
今日話すこと / debut-sushi_haneda
Cybozu
PRO
September 16, 2021
Tweet
Share
More Decks by Cybozu
See All by Cybozu
LLMでもいつものテスト技術〜意外と半分はこれまでのテストでした〜
cybozuinsideout
PRO
1
160
kintone開発のプラットフォームエンジニアの紹介
cybozuinsideout
PRO
0
930
サイボウズ 開発本部採用ピッチ / Cybozu Engineer Recruit
cybozuinsideout
PRO
10
76k
LLMアプリの品質保証
cybozuinsideout
PRO
1
400
技術広報チームに丸投げしない!「一緒につくる」スポンサー活動
cybozuinsideout
PRO
0
200
テクニカルライター (グループウェア) について
cybozuinsideout
PRO
0
150
つけまが降ってきた日
cybozuinsideout
PRO
1
630
「行ってよかった!」をみんなに広げる
cybozuinsideout
PRO
0
200
サイボウズの QAエンジニアについて / about cybozu QA
cybozuinsideout
PRO
3
4.6k
Other Decks in Technology
See All in Technology
フロントエンド刷新 4年間の軌跡
yotahada3
0
510
Keycloak を使った SSO で CockroachDB にログインする / CockroachDB SSO with Keycloak
kota2and3kan
0
170
「お金で解決」が全てではない!大規模WebアプリのCI高速化 #phperkaigi
stefafafan
4
1.7k
20260311 技術SWG活動報告(デジタルアイデンティティ人材育成推進WG Ph2 活動報告会)
oidfj
0
370
身体を持ったパーソナルAIエージェントの 可能性を探る開発
yokomachi
1
130
今のWordPress の制作手法ってなにがあんねん?(改) / What’s the Deal with WordPress Development These Days?
tbshiki
0
520
会社紹介資料 / Sansan Company Profile
sansan33
PRO
16
410k
欠陥分析(ODC分析)における生成AIの活用プロセスと実践事例 / 20260320 Suguru Ishii & Naoki Yamakoshi & Mayu Yoshizawa
shift_evolve
PRO
0
170
VLAモデル構築のための AIロボット向け模倣学習キット
kmatsuiugo
0
290
エンジニアリングマネージャーの仕事
yuheinakasaka
0
120
1GB RAMのラズピッピで何ができるのか試してみよう / 20260319-rpijam-1gb-rpi-whats-possible
akkiesoft
0
570
猫でもわかるKiro CLI(AI 駆動開発への道編)
kentapapa
0
270
Featured
See All Featured
Chasing Engaging Ingredients in Design
codingconduct
0
150
How to Build an AI Search Optimization Roadmap - Criteria and Steps to Take #SEOIRL
aleyda
1
2k
Code Reviewing Like a Champion
maltzj
528
40k
How to Get Subject Matter Experts Bought In and Actively Contributing to SEO & PR Initiatives.
livdayseo
0
85
Building AI with AI
inesmontani
PRO
1
800
What the history of the web can teach us about the future of AI
inesmontani
PRO
1
480
A designer walks into a library…
pauljervisheath
210
24k
The Spectacular Lies of Maps
axbom
PRO
1
630
WCS-LA-2024
lcolladotor
0
480
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
79
Primal Persuasion: How to Engage the Brain for Learning That Lasts
tmiket
0
300
A brief & incomplete history of UX Design for the World Wide Web: 1989–2019
jct
1
320
Transcript
今日話すこと 21新卒 Garoon開発の羽田です。 Garoon配属後にやったことと、そこで感じたことについて話します。
名前 羽田 智史 (はねだ ともふみ) 出身大学 会津大学 大学時代 SI企業で4年間アルバイト Java/SpringでWEB業務システムを開発
趣味 筋トレ サイクリング ゲーム カメラ 最近ハマっていたこと 自作キーボード mint60 つくりました、ついでに無線化しました
配属 7月からGaroon Odangoチームに所属 改善や技術のタスクのハンドリングをするチーム 配属を希望した理由 新規開発はアルバイトで経験してきたので、経験したことのない改善系や大きめの タスクをやってみたいと思った
配属後にやったこと Garoonチュートリアル (7月上旬~中旬) 簡単な画面を作る オンプレ版のインストール, アップデート Garoonの機能を触る はじめてのおつかい (7月中旬~8月末) 同期メンバーとモブでタスクを行い、一通りの開発プロセスを学ぶ
バグ修正3つ, +α UnitTestの副作用修正(後述)
はじめてのおつかいの所感
バグ改修
レガシーなコードが残っているために、問題のコードを探すのが大変な場合がある 1メソッド, 1ファイルがとにかく長い 変数に何の値が入っているか分からない 変数の生成先がめっちゃ深い メソッドを呼んでいる -> 200行くらいのメソッド -> さらに入れ子でメソ
ッドを呼んでいる -> 以下ループ コードは読まずに、デバッグして実際の値, 動作を見た方が早い 既存のコードがテスタブルではないため、UnitTestが書きづらい global変数, static変数, コードが長い など 小さなバグを一つ直すのでさえ、Garoonだと数日かかる場合がある
UnitTestの副作用修正
CI上では問題ないが、ローカルでは失敗するUnitTestが存在した ローカルでUnitTestを全体実行した時、同じプロセスで実行するため、あるテストの副 作用が別のテストに影響を与えてた 副作用が起きるケース: あるテストでグローバル変数がモックに置き換えられていた。 継続して実行される次のテストではモックではないグローバル変数であること を前提としている。 だが、前のテストでモックに変わっているために後続のテストが失敗した。
CIでテストを全体実行しているが、独立したプロセスで実行されるため問題は起きてい ない 独立したプロセスで一つ一つ実行するため時間がかかる もし副作用による問題を修正できれば、CIでも同一プロセスで実行できるため、実 行時間が大幅に減る 副作用を起こすようなコードはよくない クラス, インスタンスが状態を保持する, グローバル変数を使う 副作用が起きてしまう場合は、後処理をする
テスト用に値を変更したのであれば、元に戻すことが大事
結果どうだったか 数日かけて副作用を治して、ローカルでUnitTestが動くようになった CI上ですべてのテストを同一プロセスで動くように設定を変えたところ、テストが 動かなかったため、実行時間の短縮はできなかった 期限も来ていたので諦めた Garoonは甘くない
まとめ Garoonで開発をするのは大変 その分やりがいがある 大変だからこそ、Garoonをもっと良くしていくためには?ということを常に考えるよう になった 良いコードの書き方, レガシーコードの改善について探求していきたい プロダクト全体で改善に対する意識が高く、先輩たちのテクニックや考え方が勉強 になる
これからもGaroonで頑張っていきます!!! 終わり