您的位置:軟件測(cè)試 > 開(kāi)源軟件測(cè)試 > 開(kāi)源配置管理工具 > cvs
CVS知識(shí)、工具整合
作者:網(wǎng)絡(luò)轉(zhuǎn)載 發(fā)布時(shí)間:[ 2013/1/24 15:11:25 ] 推薦標(biāo)簽:

作者: 車東 chedong@bigfoot.com

版權(quán)聲明:可以任意轉(zhuǎn)載,轉(zhuǎn)載時(shí)請(qǐng)務(wù)必標(biāo)明原始出處和作者信息

關(guān)鍵詞:CVS CVSWeb CVSTrac WinCVS CVSROOT

內(nèi)容摘要:

CVS是一個(gè)C/S系統(tǒng),多個(gè)開(kāi)發(fā)人員通過(guò)一個(gè)中心版本控制系統(tǒng)來(lái)記錄文件版本,從而達(dá)到保證文件同步的目的。工作模式如下:

CVS服務(wù)器(文件版本庫(kù))
/ |
(版 本 同 步)
/ |
開(kāi)發(fā)者1 開(kāi)發(fā)者2 開(kāi)發(fā)者3

開(kāi)發(fā)人員入門(mén)可以主要挑選2,6看可以了,CVS的管理員則更需要懂的更多一些,后還簡(jiǎn)單介紹了一些Windows下的cvs客戶端使用,遠(yuǎn)程用戶認(rèn)證的選擇,及與BUG跟蹤系統(tǒng)等開(kāi)發(fā)環(huán)境的集成問(wèn)題。

CVS環(huán)境初始化:CVS環(huán)境的搭建 管理員
CVS的日常使用:日常開(kāi)發(fā)中常用的CVS命令, 開(kāi)發(fā)人員 管理員
CVS的分支開(kāi)發(fā):項(xiàng)目按照不同進(jìn)度和目標(biāo)并發(fā)進(jìn)行 管理員
CVS的用戶認(rèn)證:通過(guò)SSH的遠(yuǎn)程用戶認(rèn)證,安全,簡(jiǎn)單 管理員
CVSWEB:CVS的WEB訪問(wèn)界面大大提高代碼版本比較的效率 管理員
CVS TAG:將$Header$加入代碼注釋中,方便開(kāi)發(fā)過(guò)程的跟蹤 開(kāi)發(fā)人員
CVS vs VSS: CVS和Virsual SourceSafe的比較 開(kāi)發(fā)人員 管理員
WinCVS: 通過(guò)SSH認(rèn)證的WinCVS認(rèn)證設(shè)置
CVS的小組協(xié)同開(kāi)發(fā):開(kāi)發(fā)組級(jí)的開(kāi)發(fā)環(huán)境搭建,通過(guò)CVSTrac實(shí)現(xiàn)web界面的CVS用戶管理及集成的BUG跟蹤和WIKI交流。
一個(gè)系統(tǒng)20%的功能往往能夠滿足80%的需求,CVS也不例外,以下是CVS常用的功能,可能還不到它全部命令選項(xiàng)的20%,更多的功能在實(shí)際應(yīng)用過(guò)程中體會(huì),你想用多少學(xué)多少,不時(shí)回頭看看經(jīng)常有意外的收獲。


CVS環(huán)境初始化
============

環(huán)境設(shè)置:指定CVS庫(kù)的路徑CVSROOT
tcsh
setenv CVSROOT /path/to/cvsroot
bash
CVSROOT=/path/to/cvsroot ; export CVSROOT

后面還提到遠(yuǎn)程CVS服務(wù)器的設(shè)置:
CVSROOT=:ext:$USER@test.server.address#port:/path/to/cvsroot CVS_RSH=ssh; export CVSROOT CVS_RSH

初始化:CVS版本庫(kù)的初始化。
cvs init

一個(gè)項(xiàng)目的首次導(dǎo)入
cvs import -m "write some comments here" project_name vendor_tag release_tag
執(zhí)行后:會(huì)將所有源文件及目錄導(dǎo)入到/path/to/cvsroot/project_name目錄下
vender_tag: 開(kāi)發(fā)商標(biāo)記
release_tag: 版本發(fā)布標(biāo)記

項(xiàng)目導(dǎo)出:將代碼從CVS庫(kù)里導(dǎo)出
cvs checkout project_name
cvs 將創(chuàng)建project_name目錄,并將新版本的源代碼導(dǎo)出到相應(yīng)目錄中。這個(gè)checkout和Virvual SourceSafe中的 check out不是一個(gè)概念,相對(duì)于Virvual SourceSafe的check out是cvs update, check in是 cvs commit。

CVS的日常使用
=============

注意:第一次導(dǎo)出以后,不是通過(guò)cvs checkout來(lái)同步文件了,而是要進(jìn)入剛才cvs checkout project_name導(dǎo)出的project_name目錄下進(jìn)行具體文件的版本同步(添加,修改,刪除)操作。

將文件同步到新的版本
cvs update
不制定文件名,cvs將同步所有子目錄下的文件,也可以制定某個(gè)文件名/目錄進(jìn)行同步
cvs update file_name
好每天開(kāi)始工作前或?qū)⒆约旱墓ぷ鲗?dǎo)入到CVS庫(kù)里前都要做一次,并養(yǎng)成“先同步 后修改”的習(xí)慣,和Virvual SourceSafe不同,CVS里沒(méi)有文件鎖定的概念,所有的沖突是在commit之前解決,如果你修改過(guò)程中,有其他人修改并commit到了CVS庫(kù)中,CVS會(huì)通知你文件沖突,并自動(dòng)將沖突部分用
>>>>>>
content on cvs server
<<<<<<
content in your file
>>>>>>
標(biāo)記出來(lái),由你確認(rèn)沖突內(nèi)容的取舍。
版本沖突一般是在多個(gè)人修改一個(gè)文件造成的,但這種項(xiàng)目管理上的問(wèn)題不應(yīng)該指望由CVS來(lái)解決。

確認(rèn)修改寫(xiě)入到CVS庫(kù)里
cvs commit -m "write some comments here" file_name

注意:CVS的很多動(dòng)作都是通過(guò)cvs commit進(jìn)行后確認(rèn)并修改的,好每次只修改一個(gè)文件。在確認(rèn)的前,還需要用戶填寫(xiě)修改注釋,以幫助其他開(kāi)發(fā)人員了解修改的原因。如果不用寫(xiě)-m "comments"而直接確認(rèn)`cvs commit file_name` 的話,cvs會(huì)自動(dòng)調(diào)用系統(tǒng)缺省的文字編輯器(一般是vi)要求你寫(xiě)入注釋。
注釋的質(zhì)量很重要:所以不僅必須要寫(xiě),而且必須寫(xiě)一些比較有意義的內(nèi)容:以方便其他開(kāi)發(fā)人員能夠很好的理解
不好的注釋,很難讓其他的開(kāi)發(fā)人員快速的理解:比如: -m "bug fixed" 甚至 -m ""
好的注釋,甚至可以用中文: -m "在用戶注冊(cè)過(guò)程中加入了Email地址校驗(yàn)"

上一頁(yè)12345下一頁(yè)
軟件測(cè)試工具 | 聯(lián)系我們 | 投訴建議 | 誠(chéng)聘英才 | 申請(qǐng)使用列表 | 網(wǎng)站地圖
滬ICP備07036474 2003-2017 版權(quán)所有 上海澤眾軟件科技有限公司 Shanghai ZeZhong Software Co.,Ltd