qileilove

          blog已經(jīng)轉(zhuǎn)移至github,大家請訪問 http://qaseven.github.io/

          實例化需求的概念和流程

           最近一段時間在關(guān)注一種新的敏捷模式,當(dāng)然這里說新,是由于目前很少看到有項目在應(yīng)用,其實這種模式很早就已經(jīng)誕生了。一個偶爾的機(jī)會,在苦尋敏捷測試的 過程中,無意中看一本書,關(guān)于如何提高敏捷過程中需求、開發(fā)和驗收的測試效率,讓我很是感興趣,這本書名《實例化需求:團(tuán)隊如何交付正確的軟件》。可能是 由于翻譯的原因,讀起來給我的幫助并不是那么大,但至少先讓初步了解他的思想,我想這就是最大的幫助了,因為我確實接受了他。

            關(guān)于如何處理需求說明與測試,不同的組織使用不同的名稱,或者說是不同的定義,但他們都有一套共同的核心原則與思想,而且當(dāng)你接受他了之后,我們便可以認(rèn)為他們本質(zhì)上是一致的。通常有如下定義:

            ● 敏捷驗收測試

            ● 驗收測試驅(qū)動開發(fā)

            ● 實例驅(qū)動開發(fā)

            ● User Story測試

            ● BDD行為驅(qū)動開發(fā)

            ● 實例化需求說明(Specification by Example)

             對于以上的概念,我想大家都不陌生,但可能都是一個概念,因為沒有實踐。當(dāng)具體去實踐,其實就發(fā)現(xiàn)跟我們平時的流程相對也很容易理解,只是方式不一樣, 或者執(zhí)行流程不一樣,當(dāng)然這里要說的就是不同,那就是方法。方法都是總結(jié)出來,多實踐之后,提煉出來的就是適合我們的方法。就如同我們在實施了一段時間之 后,突然有一天有人問我什么是BDD(行為驅(qū)動開發(fā)),我發(fā)現(xiàn)我很疑惑,我不理解。但細(xì)想,我現(xiàn)在做的流程不就是BDD嗎,而我現(xiàn)在做的流程準(zhǔn)確來說被定 義為實例化需求,但這個概念似乎不能把開發(fā)和測試給拉進(jìn)來,而用BDD來定義,似乎就一瞬間把需求、設(shè)計、開發(fā)和測試?yán)壎ㄔ诹艘黄稹?/p>

             何為BDD?其實就是通過真實用戶的行為來定義我們需要開發(fā)出什么樣的產(chǎn)品來,個人理解。但再結(jié)合實例化需求,就會發(fā)現(xiàn),我們就是把用戶的行為通過一個實 例化的過程描述出來,然后整理成設(shè)計、開發(fā)和測試都能看懂的,當(dāng)然最重要的是用戶也能看懂,而且用戶看完之后就認(rèn)可,這就是我想要的,這就是BDD,也就 是實例化需求過程。

            它既不是傳統(tǒng)的需求文檔,也不是設(shè)計文檔,更不是測試用例文檔,但適用于從需求、設(shè)計、開發(fā)和測試的每一個階段,而且都是從用戶的角度為出發(fā)點(diǎn)的。那我就認(rèn)為那就是我們想要的過程模式。

            以下為實例化需求說明的主要過程模式:



           當(dāng)我們獲取一個業(yè)務(wù)目標(biāo)時,將按照上述流程圖來生產(chǎn)實例化需求過程

            ● 從目標(biāo)中獲取范圍

            通過用戶提供的需求描述,我們將這些描述轉(zhuǎn)變成另一種用戶能夠理解且真實用戶實際地行為方式,這里就要引入User Story用戶故事的概念。然后以客戶的業(yè)務(wù)目標(biāo)為起始,然后通過協(xié)作界定可以實現(xiàn)目標(biāo)的范圍。這里最關(guān)鍵的就是與用戶更密切地溝通,通過不斷細(xì)化,確認(rèn) 這才是用戶想要的功能。

            ● 從協(xié)作中制定需求說明

            之所以要提出協(xié)作制定需求說明,目的是讓需求、設(shè)計、開發(fā)以及測試都參與進(jìn)來,發(fā)揮整個Team的知識和經(jīng)驗,力求讓項目的干系人都更多的參與到交付過程中。

            ● 舉例說明

            舉例說明其實是項目需求交流過程中不可或缺的,團(tuán)隊中不同職能人都有,而且每個人的業(yè)務(wù)背景不同,通過舉例說明的方式可以讓目標(biāo)更一致。

            ● 提煉需求說明

            協(xié)作過程中的開發(fā)討論可以建立大家對相關(guān)領(lǐng)域的共識,但最終得到的實例往往包含很多不必要的細(xì)節(jié)。而關(guān)鍵實例必須是精簡的。提煉需求說明的過程,其實就伴隨著實例化需求的產(chǎn)生,且這些提煉好的實例就可以當(dāng)作交付的驗收條件。

            ● 頻繁驗證

            頻繁驗證的依據(jù)就是提煉需求產(chǎn)生的實例化需求,它是所有過程實施中都必須要反復(fù)進(jìn)行的工作。需求通過頻繁驗證與用戶進(jìn)行頻繁確認(rèn);設(shè)計通過實例 化需求來頻繁驗證設(shè)計是否滿足用戶的需求;開發(fā)通過實例化需求頻繁驗證代碼中業(yè)務(wù)邏輯;測試通過實例化需求來頻繁驗證交付的功能,并作為最后驗收測試的依 據(jù)。

            ● 演化出一個文檔系統(tǒng)

            通過以上的這些流程,最后演化出一個文檔系統(tǒng)。之所以稱為文檔系統(tǒng),主要是體現(xiàn)它的可靠性、權(quán)威性。所有設(shè)計、開發(fā)、變更以及測試過程都以此為出發(fā)點(diǎn)來考慮,并及時更新,長久維護(hù)。

            實例化需求過程的核心就是與用戶站在一起,從溝通開始,不斷舉例、細(xì)化、精簡到統(tǒng)一確認(rèn)。

          posted on 2013-01-18 10:07 順其自然EVO 閱讀(442) 評論(0)  編輯  收藏 所屬分類: 測試學(xué)習(xí)專欄

          <2013年1月>
          303112345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          導(dǎo)航

          統(tǒng)計

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 丰县| 托里县| 桦川县| 镇远县| 正镶白旗| 富阳市| 河池市| 保亭| 盘锦市| 遂昌县| 鄯善县| 土默特左旗| 清水县| 滦平县| 沧源| 西吉县| 白银市| 息烽县| 十堰市| 静安区| 和静县| 石首市| 房山区| 西峡县| 乾安县| 宁陕县| 乳山市| 屏东市| 郯城县| 安康市| 阿鲁科尔沁旗| 荣成市| 钦州市| 栾城县| 陆丰市| 靖州| 海淀区| 三河市| 社会| 和田县| 青海省|