• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

    字號: | 推薦給好友 上一篇 | 下一篇

    CVS 使用手冊

    發布: 2007-6-09 13:34 | 作者: seanhe | 來源: | 查看: 30次 | 進入軟件測試論壇討論

    領測軟件測試網
    1  CVS環境初始化
    ============
    環境設置:指定CVS庫的路徑CVSROOT
    tcsh
    setenv CVSROOT /path/to/cvsroot
    bash
    CVSROOT=/path/to/cvsroot ; export CVSROOT
    后面還提到遠程CVS服務器的設置:
    CVSROOT=:ext:$USER@test.server.address#port:/path/to/cvsroot CVS_RSH=ssh; export CVSROOT CVS_RSH

    初始化:CVS版本庫的初始化。
    cvs init
    一個項目的首次導入
    cvs import -m "write some comments here" project_name vendor_tag release_tag
    執行后:會將所有源文件及目錄導入到/path/to/cvsroot/project_name目錄下
    vender_tag: 開發商標記
    release_tag: 版本發布標記
    項目導出:將代碼從CVS庫里導出
    cvs checkout project_name
    cvs 將創建project_name目錄,并將最新版本的源代碼導出到相應目錄中。這個checkout和Virvual SourceSafe中的check out不是一個概念,相對于Virvual SourceSafe的check out是cvs update, check in是cvs commit。

    2   CVS的日常使用  
    =============
    注意:第一次導出以后,就不是通過cvs checkout來同步文件了,而是要進入剛才cvs checkout project_name導出的project_name目錄下進行具體文件的版本同步(添加,修改,刪除)操作。
    將文件同步到最新的版本:
    cvs update
    不制定文件名,cvs將同步所有子目錄下的文件,也可以制定某個文件名/目錄進行同步
    cvs update file_name
    最好每天開始工作前或將自己的工作導入到CVS庫里前都要做一次,并養成“先同步 后修改”的習慣,和Virvual SourceSafe不同,CVS里沒有文件鎖定的概念,所有的沖突是在commit之前解決,如果你修改過程中,有其他人修改并commit到了CVS庫中,CVS會通知你文件沖突,并自動將沖突部分用
    >>>>>>
    content on cvs server
    <<<<<<
    content in your file
    >>>>>>
    標記出來,由你確認沖突內容的取舍。
    版本沖突一般是在多個人修改一個文件造成的,但這種項目管理上的問題不應該指望由CVS來解決。

    確認修改寫入到CVS庫里:
    cvs commit -m "write some comments here" file_name

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

    修改某個版本注釋:每次只確認一個文件到CVS庫里是一個很好的習慣,但難免有時候忘了指定文件名,把多個文件以同樣注釋commit到CVS庫里了,以下命令可以允許你修改某個文件某個版本的注釋:
    cvs admin -m 1.3:"write some comments here" file_name

    添加文件
    創建好新文件后,比如:touch new_file
    cvs add new_file
    注意:對于圖片,Word文檔等非純文本的項目,需要使用cvs add -b選項,否則有可能出現文件被破壞的情況
    比如:cvs add -kb new_file.gif
    然后確認修改并注釋 
    cvs ci -m "write some comments here"

    刪除文件:
    將某個源文件物理刪除后,比如:rm file_name
    cvs rm file_name
    然后確認修改并注釋
    cvs ci -m "write some comments here"
    以上面前2步合并的方法為:
    cvs rm -f file_name
    cvs ci -m "why delete file"

    注意:很多cvs命令都有縮寫形式:commit=>ci; update=>up; checkout=>co; remove=>rm;

    添加目錄:
    cvs add dir_name
    查看修改歷史:cvs log file_name
    cvs history file_name
    查看當前文件不同版本的區別
    cvs diff -r1.3 -r1.5 file_name
    查看當前文件(可能已經修改了)和庫中相應文件的區別
    cvs diff file_name
    cvs的web界面提供了更方便的定位文件修改和比較版本區別的方法,具體安裝設置請看后面的cvsweb使用

    正確的通過CVS恢復舊版本的方法:
    如果用cvs update -r1.2 file.name
    這個命令是給file.name加一個STICK TAG: "1.2" ,雖然你的本意只是想將它恢復到1.2版本
    正確的恢復版本的方法是:cvs update -p -r1.2 file_name >file_name
    如果不小心已經加成STICK TAG的話:用cvs update -A 解決

    移動文件:文件重命名
    cvs里沒有cvs move或cvs rename,因為這兩個操作是先cvs remove old_file_name,然后cvs add new_file_name實現的。

    刪除,移動目錄:
    最方便的方法是讓管理員直接移動,刪除CVSROOT里相應目錄(因為CVS一個項目下的子目錄都是獨立的,移動到$CVSROOT目錄下都可以作為新的獨立項目:好比一顆樹,其實砍下任意一枝都能獨立存活),對目錄進行了修改后,要求其開發人員重新導出項目cvs checkout project_name 或者用cvs update -dP同步。

    3  CVS Branch:項目多分支同步開發
    =============================
    確認版本里程碑:多個文件各自版本號不一樣,項目到一定階段,可以給所有文件統一指定一個階段里程碑版本號,方便以后按照這個階段里程碑版本號導出項目,同時也是項目的多個分支開發的基礎。
    cvs tag release_1_0
    開始一個新的里程碑:
    cvs commit -r 2 標記所有文件開始進入2.x的開發
    注意:CVS里的revsion和軟件包的發布版本可以沒有直接的關系。但所有文件使用和發布版本一致的版本號比較有助于維護。
    在開發項目的2.x版本的時候發現1.x有問題,但2.x又不敢用,則從先前標記的里程碑:release_1_0導出一個分支release_1_0_patch
    cvs rtag -b -r release_1_0 release_1_0_patch proj_dir

    一些人先在另外一個目錄下導出release_1_0_patch這個分支:解決1.0中的緊急問題,
    cvs checkout -r release_1_0_patch
    而其他人員仍舊在項目的主干分支2.x上開發
    在release_1_0_patch上修正錯誤后,標記一個1.0的錯誤修正版本號
    cvs tag release_1_0_patch_1

    如果2.0認為這些錯誤修改在2.0里也需要,也可以在2.0的開發目錄下合并release_1_0_patch_1中的修改到當前代碼中:
    cvs update -j release_1_0_patch_1

    4  CVS的遠程認證:通過SSH遠程訪問CVS
    ================================
    使用cvs本身的遠程認證很麻煩,需要定義服務器和用戶組,用戶名,設置密碼等,而且不安全,因此和系統本地帳號認證并通過SSH傳輸是比較好的辦法,通過在客戶機的/etc/profile里設置一下內容:
    CVSROOT=:ext:$USER@test.server.address#port:/path/to/cvsroot CVS_RSH=ssh; export CVSROOT CVS_RSH
    所有客戶機所有本地用戶都可以映射到CVS服務器相應同名帳號了。
    如果CVS所在服務器的SSH端口不在缺省的22,或者和客戶端與CVS服務器端SSH缺省端口不一致,有時候設置了:
    :ext:$USER@test.server.address#port:/path/to/cvsroot 
    仍然不行,比如有以下錯誤信息:
    ssh: test.server.address#port: Name or service not known
    cvs [checkout aborted]: end of file from server (consult above messages if any)

    解決的方法是做一個腳本指定端口轉向(不能使用alias,會出找不到文件錯誤):
    創建一個/usr/bin/ssh_cvs文件:
    #!/usr/bin/sh
    /path/to/ssh -p 34567 "$@"
    然后:chmod +x /usr/bin/ssh_cvs
    并CVS_RSH=ssh_cvs; export CVS_RSH

    注意:port是指相應服務器SSH的端口,不是cvs pserver的端口

    5  CVSWEB:提高程序員比較文件修改效率
    ================================
    CVSWEB就是CVS的WEB界面,可以大大提高程序員定位修改的效率:
    使用的樣例可以看:http://www.freebsd.org/cgi/cvsweb.cgi

    CVSWEB的下載:CVSWEB從最初的版本已經演化出很多功能界面更豐富的版本,這個是個人感覺覺得安裝設置比較方便的:
    http://www.spaghetti-code.de/software/linux/cvsweb/
    下載解包:
    tar zxf cvsweb.tgz
    把配置文件cvsweb.conf放到安全的地方(比如和apache的配置放在同一個目錄下),
    修改:cvsweb.cgi讓CGI找到配置文件:
    $config = $ENV{'CVSWEB_CONFIG'} || '/path/to/apache/conf/cvsweb.conf';

    轉到/path/to/apache/conf下并修改cvsweb.conf:

    修改CVSROOT路徑設置:
    %CVSROOT = (
    'Development' => '/path/to/cvsroot', #<==修改指向本地的CVSROOT
    ); 
    缺省不顯示已經刪除的文檔:
    "hideattic" => "1",#<==缺省不顯示已經刪除的文檔 
    在配置文件cvsweb.conf中還可以定制頁頭的描述信息,你可以修改$long_intro成你需要的文字 
    CVSWEB可不能隨便開放給所有用戶,因此需要使用WEB用戶認證:
    先生成 passwd:
    /path/to/apache/bin/htpasswd -c cvsweb.passwd user

    修改httpd.conf: 增加
    <Directory "/path/to/apache/cgi-bin/cvsweb/">
    AuthName "CVS Authorization"
    AuthType Basic
    AuthUserFile /path/to/cvsweb.passwd
    require valid-user
    </Directory>

    CVS TAGS: who? when?
    ====================
    將$Id$ 加在程序文件開頭的注釋里是一個很好的習慣,cvs能夠自動解釋更新其中的內容成:file_name version time user_name 的格式,比如:cvs_card.txt,v 1.1 2002/04/05 04:24:12 chedong Exp,可以這些信息了解文件的最后修改人和修改時間


    CVS HOME: http://www.cvshome.org
    CVS FAQ: http://www.loria.fr/~molli/cvs-index.html
    http://directory.google.com/Top/Computers/Software/Configuration_Management/Tools/Concurrent_Versions_System/
    http://cvsbook.red-bean.com/
    CVS 命令的卡片: http://www.refcards.com/about/cvs.html

     默默 回復于:2003-02-09 21:47:07
    支持

     iricyan 回復于:2003-02-10 01:13:35
    cvs是什么????

     默默 回復于:2003-02-10 08:15:11
    人家給你了網址,自己去看啊

     lanbird 回復于:2003-02-10 10:51:57
    版本控制系統 ,希望CVS能服務你的軟件開發,保證軟件質量

     kinux 回復于:2003-02-10 19:40:56
    [quote:c9be84e828="lanbird"] aborted]: end of file from server (consult above messages if any)

    解決的方法是做一個腳本指定端口轉向(不能使用alias,會出找不到文件錯誤):
    創建一個/usr/bin/ssh_cvs文件:
    #!/usr/bin/sh
    /path/to..........[/quote:c9be84e828]

    不錯的文章..
    不過,好像對*BSD 比較有用喔...  在Solaris 上沒有CVSUP的server...  怎么可以用CVS 更新呢???

     lanbird 回復于:2003-03-16 10:38:24
    有沒有用VSS的,可以比較使用CVS。

    延伸閱讀

    文章來源于領測軟件測試網 http://www.kjueaiud.com/


    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
    北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備10010545號-5
    技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>