変更管理の基盤は構成管理が支えている
SW開発には、たくさんの落とし穴や地雷がある。
地雷原を走り抜けてゴールにたどり着くまでに慎重に進むと、時間切れになる。
アジャイル開発をRedmine上で実践して気付いたことは、変更管理プロセスを制御できるかどうかという観点がプロジェクト管理の殆どを占めていることだ。
仕様変更、タスクの優先度など、SW開発は路線変更が多く、それを制御するのが難しい。
顧客と合意した要件で開発してリリースしても、その後に膨大な改善要望がくる時すらある。
以下メモ書き。
【1】顧客要求を安易に受けてしまう人の良いSE- @IT自分戦略研究所
スコープのずれがコスト増にすぐにつながる。
アジャイル開発の肝はスコープ管理だ。
スコープ、コスト、納期の3つのバランスのうち、スコープでしか調整しづらいのがSW開発の最大の特徴。
スコープ管理の一例としては、CCBなどの変更管理会議で変更管理プロセスを制御することがある。
つまり、仕様変更など開発対象のスコープにつながるものは全て、顧客・SIer・開発者などのステークホルダーが全て集まって合意を経ないと、変更できないようにする。
しかし、僕の経験では、人数が多い会議ほど時間がかかるだけで何も決まらない。
CCBに出るステークホルダーは、業務やシステムに詳しい人とは限らない。
全員の合意を得るのは難しい。
大規模プロジェクトになるほど、ステークホルダーが増えるので、指数関数的に変更管理プロセスの難易度は上がる。
チケット駆動開発を応用しても、運用のハードルは高いだろう。
【2】【福井信二が語る:第3回】構成管理・プロジェクト管理の原理原則 - 組み込み開発 - Tech-On!
「構成管理とは同じ成果物の状態の変化を管理すること」というフレーズにアンテナが響いた。
SW開発では、一つの成果物が設計・開発・テストの工程を経るごとに、中身も状態も変化する。
記事で紹介されているように、成果物は段階的に詳細化されていくのだ。
要件は、設計工程で、システムの一つの仕様に落ちる。
そして、その仕様はプログラムで実装されて、初めて目の前で動く。
しかし、たくさんのテストをこなすたびに、一つの仕様には、たくさんのパッチが当てられて、ソースコードはどんどん複雑になっていく。
その過程を制御するのが構成管理だ。
つまり、要件からソースコードまで一貫したトレーサビリティを保証するインフラが構成管理。
しかし、Rational製品が提供するツールは重くて実用的ではない。
チケット駆動開発では、チケットとソースコードのリビジョンを紐づける運用がある。
その運用のおかげで、チケットという仕様に紐づくソースコードの履歴を辿ることができる。
逆に、ソースコードの変更履歴からチケットの仕様を探り出すこともできる。
僕が考えているプロジェクト管理サーバーでは、
HudsonビルドNo
→SVNリビジョン
→RedmineチケットNo
→TestLinkテストケースID
→TestLink要件ID
のトレーサビリティを作れるから、リリースされたモジュールにあるパッチから、要件まで辿ることができるはず。
上記の記事にあるベースラインの概念は、Redmineのバージョン、Subversionのリリースタグ、XPのイテレーション、Scrumのスプリントに相当するように運用できると思う。
変更管理と構成管理は密接に絡んでいる。
チケット駆動開発は、二つのプロセスをコントロールしやい開発プロセスだろうと思う。
| 固定リンク
「プロジェクトマネジメント」カテゴリの記事
- 知識は経験よりも大切か、経験は知識よりも勝るのか、SECIモデルは相互作用を語る(2022.04.26)
- プロジェクト管理の基本はテーラリング、Redmineはプロセスをテーラリングするツール(2022.04.21)
- 初中級プロマネはIPAデータ白書の統計情報を見積り、生産性、品質の観点で活用せよ(2022.04.17)
- タスク分割は親子チケットにすべきか、それともチェックリストにすべきか #redmine(2022.03.04)
- なぜ米国企業は90年代に蘇ったのか~日本の手の内は完全に読み取られた~V字回復の経営の感想(2022.02.18)
「Redmine」カテゴリの記事
- 知識は経験よりも大切か、経験は知識よりも勝るのか、SECIモデルは相互作用を語る(2022.04.26)
- オープンソースERPパッケージiDempiereに対する派生開発手法の提案の資料が興味深かった(2022.04.24)
- プロジェクト管理の基本はテーラリング、Redmineはプロセスをテーラリングするツール(2022.04.21)
- RedmineのWikiタグでタスクリストを書けるようになった(2022.03.21)
- RedmineJapanで参考になった講演資料を読み直す(2022.03.06)
「ソフトウェア工学」カテゴリの記事
- ソフトウェアテスト技法練習帳はテストケースの切り方に困っている人向けにおすすめの本だ(2022.05.14)
- 知識は経験よりも大切か、経験は知識よりも勝るのか、SECIモデルは相互作用を語る(2022.04.26)
- オープンソースERPパッケージiDempiereに対する派生開発手法の提案の資料が興味深かった(2022.04.24)
- プロジェクト管理の基本はテーラリング、Redmineはプロセスをテーラリングするツール(2022.04.21)
- 初中級プロマネはIPAデータ白書の統計情報を見積り、生産性、品質の観点で活用せよ(2022.04.17)
「TestLink」カテゴリの記事
- TestRailの感想(2021.06.23)
- テスト管理ツールに必要とされる機能要件は、欧米と日本で異なるのではないか(2020.11.02)
- TestLinkにExcelのテスト項目書をインポートする方法(2017.06.01)
- TestLink Tutorialのリンク(2016.03.12)
- TestLinkで手動テストや自動テストの結果を統合してレポートさせる手法(2016.01.31)
「Git・構成管理」カテゴリの記事
- 小説活動にプルリクエスト駆動が必要になってきた(2022.05.08)
- 【資料公開】チケット駆動開発の解説~タスク管理からプロセス改善へ #redmine(2022.01.14)
- プログラミングしてる時はでっかいピタゴラ装置を作ってるみたいな感じ(2022.01.09)
- チケット駆動開発のプロセスとチケット管理システムの全体像 #Redmine(2021.12.28)
- 第21回東京Redmine勉強会の感想 #redmineT ~Redmineは業務も組織も包み込む柔軟性がある(2021.11.28)
「チケット駆動開発」カテゴリの記事
- 小説活動にプルリクエスト駆動が必要になってきた(2022.05.08)
- 知識は経験よりも大切か、経験は知識よりも勝るのか、SECIモデルは相互作用を語る(2022.04.26)
- プロジェクト管理の基本はテーラリング、Redmineはプロセスをテーラリングするツール(2022.04.21)
- タスク分割は親子チケットにすべきか、それともチェックリストにすべきか #redmine(2022.03.04)
- Redmineにメンション機能が入るらしい(2022.01.15)
コメント