Lock in $30 Savings on PRO—Offer Ends Soon! ⏳
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
JUnit導入の成功と失敗.pdf
Search
SHIMANE, Yoshikazu
October 28, 2015
Technology
0
2.9k
JUnit導入の成功と失敗.pdf
JUnit導入の成功と失敗
SHIMANE, Yoshikazu
October 28, 2015
Tweet
Share
More Decks by SHIMANE, Yoshikazu
See All by SHIMANE, Yoshikazu
ソフトウェア開発温故知新 古典で紐解く、ソフトウェア開発の課題 / Software_Development:Learning_from_the_Past
shimashima35
0
55
入り口から考えるソフトウェアテストエンジニアのキャリア / Thinking_About_a_Software_Test Engineer's_Career_from_the_Starting_Point
shimashima35
0
1.7k
テスト技法を使ったテストケースの表現方法/How to express test cases using test techniques
shimashima35
0
1.3k
VSTePのテスト観点出しで失敗した事例についての紹介/Failure case of test viewpoint derivation
shimashima35
0
770
組織横断部門におけるバグ数可視化の全社導入の事例/Example_of_company-wide_bug_number_visualization in_cross-organizational_departments
shimashima35
1
380
JaSST Tokyo実行委員のお仕事/Job of JaSST executive committee
shimashima35
0
800
What is “Quality” ?
shimashima35
0
1k
品質"実質"無料キャンペーン始めます / Start_quality_real_free_campaign
shimashima35
2
5.7k
明日から始めるSelenideによるブラウザテスト 2018年版/ Browser_test_by_selenide_to_start_from_tomorrow_in_2018
shimashima35
1
890
Other Decks in Technology
See All in Technology
今すぐGoogle Antigravityを触りましょう
rfdnxbro
0
230
Introduction to Bill One Development Engineer
sansan33
PRO
0
320
IPv6-mostly field report from RubyKaigi 2026
sorah
0
230
AI時代のインシデント対応 〜時代を切り抜ける、組織アーキテクチャ〜
jacopen
4
170
機械学習を「社会実装」するということ 2025年冬版 / Social Implementation of Machine Learning November 2025 Version
moepy_stats
4
1k
[続・営業向け 誰でも話せるOCI セールストーク] AWSよりOCIの優位性が分からない編(2025年11月21日開催)
oracle4engineer
PRO
1
150
Kill the Vibe?Architecture in the age of AI
stoth
1
120
TypeScript 6.0で非推奨化されるオプションたち
uhyo
15
5.6k
レガシーシステム刷新における TypeSpec スキーマ駆動開発のすゝめ
tsukuha
4
870
Digital omtanke på Internetdagarna 2025
axbom
PRO
0
140
名刺メーカーDevグループ 紹介資料
sansan33
PRO
0
970
Claude Code はじめてガイド -1時間で学べるAI駆動開発の基本と実践-
oikon48
22
12k
Featured
See All Featured
Typedesign – Prime Four
hannesfritz
42
2.9k
A Modern Web Designer's Workflow
chriscoyier
697
190k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
11
950
Faster Mobile Websites
deanohume
310
31k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
132
19k
For a Future-Friendly Web
brad_frost
180
10k
Building an army of robots
kneath
306
46k
The Cost Of JavaScript in 2023
addyosmani
55
9.3k
The Hidden Cost of Media on the Web [PixelPalooza 2025]
tammyeverts
1
60
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
46
2.6k
Rails Girls Zürich Keynote
gr2m
95
14k
BBQ
matthewcrist
89
9.9k
Transcript
JUnit導入の成功と失敗 #Java騎士団 第一回円卓会議@2015/10/27 @shimashima35
自己紹介 @shimashima35 http://srad.jp/~shimashima/ 中小SI勤務(基本下請けなし) Java歴 14年くらい 好きなもの maven, テスト, ソフトウェエ
ア工学全般 最近IoTで遊んでいます JaSST(ソフトウェアテストシンポジウム) Tokyo 実行委員 JSTQB-FL取得 (New @2015/10/26)
本日の内容 JUnitによるUnitTest導入の成功事例と失敗事例の紹介。 成功要因/失敗要因についての考察。 時間があれば「JMeterによる疲れないリグレッションテスト」も……。
UnitTestとは 今回の講演でのUnitTestはTDDのUnitTestではありません。 自分は書いたプログラムが自分の意図通りに動くことを確認・保証 するためのもの。 一般的な品質保証の考えでの「単体テスト」です。
成功事例 概要 ❏ 金融系大規模案件 (300人月以上かな?) ❏ 最大プログラマだけで40名程度 ❏ 2007年頃 ❏
Java5+Spring 2.5+Hibernate3.2(Annotation)+Spring MVC ❏ まだSpring MVCもHibernate 3.2も事例がない ❏ 受注したベンダ中に複数の協力会社社員で構成 ❏ 大半は特定の1社 ❏ 自分も協力会社(Not 特定の1社)として入った一人
成功事例 JUnit導入経緯と結果 ❏ 金融系で高品質を求めた ❏ アーキテクトが主導した ❏ 最終的にお客様とコードカバレッジ100%でコミットした ❏ 厳密はgetter/setterなどは除外してよい
❏ それでも最終的には95%程度まで達成 ❏ テストチームによる結合テスト中でも気軽にリファクタリング ❏ コードに対して責任を持つ
成功事例 要因 ❏ 初期段階からUnitTestを意識し設計 ❏ レイヤーアーキテクチャ、DIなど ❏ アーキテクトの力量 ❏ UnitTest用フレームワークを一人で作成
❏ アーキテクトによる適度なコードレビュー ❏ おしなべて高かったスキル ❏ プロジェクトとしてのコミットメント ❏ プロジェクト内の意識の高さ
失敗事例 概要 ❏ 広告サイト構築案件 (200人月程度?) ❏ 最大プログラマだけで60名程度 ❏ 2009年頃 ❏
Java6+Seasar2+S2JDBC+SASturts ❏ 自社で受注 ❏ 協力会社多数参加
失敗事例 JUnit導入経緯 ❏ JUnit成功体験があった自分が参加 ❏ アーキテクトも「できるだけUnitTestは書きたい」という思い ❏ マネジャー的には「どうでもよい」 ❏ あった方がよい
❏ でも、それで進捗が遅れるのはなぁ…
失敗事例 JUnit導入結果 ❏ カバレッジ率なにそれ? ❏ UnitTestはほぼなし ❏ 皆があらゆるところを修正するのでテストメンテが事実上破た ん ❏
mvn -Dmaven.test.skip=true
失敗事例 要因 ❏ アーキテクトがテストにコミットできなかった ❏ マルチタスク ❏ マネジャーからの扱い(UnitTestはなくてもよい) ❏ スケジュールプレッシャー
❏ テストよりまず動くもの ❏ プログラマのアサインが画面単位
失敗事例 アサインの問題 1. アサインが画面単位 2. 一人が全てのレイヤまたがって実装を行う 3. 画面に近い部分は別としてService・Domain・Persist層を全 員触る a.
共通化されない、Interfaceが契約的ではない、APIが壊れ る b. 全員が全レイヤーのテストの書き方を覚えなければならな い
成功事例 アサインは? 1. アサインがレイヤー単位 2. 画面近く画面/機能単位でアサインされる 3. Service層/Domain層/Persist層はごく少のアーキテクチーム が受け持つ a.
業務単位である程度分割されるので、業務単位でクラスの オーナーが決まる b. オーナーがそのクラスの責任者として実装およびテストを 書く
まとめ
まとめ ❏ スケジュールプレッシャーは天敵 ❏ マネジャーの支援があると導入しやすい ❏ 「テストのための設計・準備」は必要 ❏ 意外なところでアサインの単位も重要
JMeterによる疲れないテスト
Selenium(WebDriver)あるある ❏ テストが壊れる ❏ メンテナンスコストが高い ❏ 時間がかかる
JMeterによる簡易テスト ❏ http(s)によるリクエストレベルでのテスト ❏ とりあえずhttpステータスコードのチェック ❏ 400番台、500番台は自動的にNG ❏ 200番台はOK ❏
302などの自動リダイレク対応 ❏ テストシナリオはキャプチャー&リプレイをベースに修正
SeleniumとJMeter ❏ Seleniumのつかいどころ ❏ 画面の動きを見たい・確認したい場合 ❏ Ajax ❏ レイアウト検証 ❏
JMeterのつかいどころ ❏ Web画面からロジックまで含めて検証 ❏ UIの細かい部分は意識しなくてよい場合 ❏ 何を検証したいかによって使い分けましょう
ご清聴ありがとうございました。