Code Review工具简介和安装

阅读更多

    本文简要描述了Review Board Jupiter JCR Codestriker Rietveld 几种开源代码评审工具的功能特点,并介绍了在 windows 下的安装步骤。 如您想使用 Web 方式进行代码评审,推荐安装 Review Board ,如您想在 Eclipse 中进行代码评审请安装 Jupiter

 

一、Review Board

    Review Board 是基于WebCode Review 工具。适用于不同规模的项目,支持 pre-commit post-commit 两种 Review 方式,可查看对比代码的多次评审、修改情况, 并提供了多种工具,是当前最活跃的Code Review 项目。

官方主页: http://www.reviewboard.org/

当前版本:1.6.4.1(2012-02-28)

RBTools 当前版本:0.4.1(2012-02-29)

支持的SCMBazaarCVSClearCaseGitMercurialPerforcePlastic SCMSubversion

支持的数据库:MySQL v5.0.31 或更新、PostgreSQLsqlite v3

支持的Web ServerApache + mod_wsgi mod_python fastcgilighttpd + fastcgi

依赖软件:

  Python 2.7  http://python.org/

  Python Setuptools  http://pypi.python.org/pypi/setuptools

  GNU patch  http://sourceforge.net/projects/gnuwin32/files/patch/

  Memcached for Windows  http://code.jellycan.com/memcached/

  (Memcached 官方主页 http://memcached.org/ )

  Python Imaging Library  http://www.pythonware.com/products/pil/

  PyCrypto  http://files.cnblogs.com/brucenan/pycrypto-2.2.win32-py2.7.rar

Windows 下安装步骤

1 安装PythonSetuptools

安装完毕后,增加C:\Python27C:\Python27\Scripts Path 环境变量

2 安装GNU patch

安装完毕后,增加patch.exe 所在路径到 Path 环境变量

3 安装Memcached

Memcached 是一个高性能的缓存服务器。可选项,为提高服务器响应速度推荐安装。

1 )下载Memcached for Windows( http://code.jellycan.com/memcached/ )

2 )解压Memcached 到一个路径(如C:\memcached

3 )从命令行安装memcached 服务

memcached.exe -d install

4 )启动memcached 服务

   可从windows 服务管理器启动,也可运行如下命令启动服务:

   memcached.exe -d start

   ( 注:可通过memcached.exe -h 查看其它命令参数)

5 )安装python-memcached

easy_install python-memcached

4 安装Python Imaging Library

5 安装PyCrypto

PyCrypto 提供 SSH repository 支持。

官网提供的PyCrypto 下载地址为: http://www.voidspace.org.uk/python/modules.shtml#pycrypto ,安装后启动Apache 出错,输出如下日志:

File "D:\\Python27\\lib\\site-packages\\django-1.3.1-py2.7.egg\\django\\core\\handlers\\wsgi.py", line 250, in __call__

self.load_middleware()

File "D:\\Python27\\lib\\site-packages\\django-1.3.1-py2.7.egg\\django\\core\\handlers\\base.py", line 47, in load_middleware

raise exceptions.ImproperlyConfigured('Error importing middleware %s: "%s"' % (mw_module, e))

ImproperlyConfigured: Error importing middleware reviewboard.admin.middleware: "DLL load failed: \xd5\xd2\xb2\xbb\xb5\xbd\xd6\xb8\xb6\xa8\xb5\xc4\xc4\xa3\xbf\xe9\xa1\xa3"

mod_wsgi (pid=4524): Exception occurred processing WSGI script 'D:/Server/reviewboard/htdocs/reviewboard.wsgi'.

google 后发现是PyCrypto 编译的包有问题,需要在windows 下重新编译。

幸好有网友将其编译的包共享了(开头列出的PyCrypto 地址),大家就不用再下一堆东东自己重新编译了,其博文地址为:

http://www.cnblogs.com/Leo_wl/archive/2012/02/29/2373709.html

6 安装Review Board

easy_install ReviewBoard

将自动下载和安装最新稳定版本的Review Board 及其依赖(DjbletsDjango-EvolutionDjangoparamikoflup

7 安装数据库绑定

MySQL

easy_install mysql-python

 

PostgreSQL

easy_install psycopg2

 

SQLite

easy_install pysqlite

注:如果使用Python2.5 或更高版本,已经包含SQLite ,不需要安装。

8 安装版本控制组件

SVN 为例,需安装PySVN ,下载地址:

http://pysvn.tigris.org/servlets/ProjectDocumentList?folderID=1768

安装slik subversion http://www.sliksvn.com/en/download ( 使用 post-review 时,用到此 SVN 客户端工具 )

可安装TortoiseSVN( http://tortoisesvn.net/downloads.html ) 客户端工具,用来生成diff 文件。

淘宝开发的基于EclipseReviewboard 开源插件 Tao-ReviewBoard ,支持 svn ,更方便安装和使用。

Tao-ReviewBoard  http://code.taobao.org/p/tao-reviewboard/wiki/index/

其它请参阅ReveiwBoard 安装文档。

9 安装Amazon S3 Support (可选)

easy_install django-storages

Review Board 可以使用Amazon S3 来存储上传的screenshotReview Board 默认文件存储方法为“Host file system ”,将使用本地路径“media/uploaded ”来存储文件。在ReviewBoard 管理页面的File Storage Settings 中可设置存储方法。

Amazon S3 http://aws.amazon.com/s3/

10 、创建ReviewBoard 站点

运行如下命令:

rb-site install D:\reviewboard

说明:“D:\reviewboard” 为站点安装路径,要使用不存在的路径,rb-site 会自动创建。运行命令后,按提示输入各参数值。使用Apache 时推荐使用 mod_wsgi fastcgi 有内存泄漏问题, mod_python Apache 已经不再开发(最后更新日期为 2003-07-09 )。推荐安装和使用 memcached ,将很大的提高 ReviewBoard 性能。

11 、配置Web Server

rb-site conf 路径下创建了Web Server 样例配置文件。

Apache 为例,如果选用了mod_wsgi ,要先 安装mod_wsgi 模块, 下载地址为:

http://code.google.com/p/modwsgi/downloads/detail?name=mod_wsgi-win32-ap22py27-3.3.so

下载后将文件重命名为 mod_wsgi.so ,然后拷贝到 Apache modules 目录下,在 Apache\conf\httpd.conf 配置文件中添加: LoadModule wsgi_module modules/mod_wsgi.so

最后将 rb-site 生成的apache-wsgi.conf 的文件内容拷贝到httpd.conf

重启 Apache ,访问 http://localhost

12 安装 RBTools

运行如下命令安装 RBTools

easy_install -U RBTools

安装 diffutils http://gnuwin32.sourceforge.net/packages/diffutils.htm

在目录$USERPROFILE\AppData\Roaming(Win7) 下,创建.reviewboardrc 文件,在其中添加如下内容:

REVIEWBOARD_URL = http://10.1.39.84

安装完毕后,就可以使用 post-review 命令了。如:

pre-commit review

post-review (创建新的 Review 请求 ,并post 未提交的修改差异)

post-review -r 42 (更新存在的Review 请求)

post-commit review:

post-review --revision-range=STARTREV:STOPREV

post-review --revision-range=REVISION

二、Jupiter

    Jupiter Eclipse IDE 的一个开源Code Review 插件。以XML 格式存储数据,安装及使用都比较简单,它的文档内容也比较全面。

官方主页: http://code.google.com/p/jupiter-eclipse-plugin/

当前版本:3.6.0(2011-01) ,支持Eclipse3.3 及以上版本。

    装:下载jar 包,拷贝到Eclipse plugins 目录即可。

三、JCR - Java Code Reviewer

    JCR 是一个基于PythonWeb 应用,面向大型项目和非常正式的Code Review ,评审流程比较严格。可以用来Review 任何类型的代码,不仅是Java 代码,但一些特殊的功能只适用于Java 项目。

    JCR 主要想协助:

审查者 - 所有的代码更改都会高亮显示,支持大多数语言的语法高亮。会显示出添加评语的代码块。如果Review Java 代码,可以点击代码中的类名来查看相关类的声明。

项目所有者 - 可以轻松创建并配置需要Review 的项目,支持( 但不需要) 集成SCM

流程信仰者 - 所有评语的细节都会记录在数据库中,包括每一个评语需要的动作及完成状态,并且会有状态报告,以及各种各样的统计。

架构师和开发者 - 可以查看所有Review 项目的细节,也可以查看特定文件的评语,有利于重构代码。

官方主页: http://jcodereview.sourceforge.net

当前版本:0.7.2.1(2010-04-13)

支持的SCMSVN ,也支持上传文件的方式。

支持的数据库:PostgreSQL 8.xMySQL 5.xSqlite

Web Server JCR 使用Pylons 内建的Web Server ,不需要其他的Server

依赖的软件:

    Python 2.4 或更新( 推荐2.5+)  http://python.org/

    Pysqlite(DB-API 2.0 interface for SQLite databases) http://code.google.com/p/pysqlite/

    Setuptools http://pypi.python.org/pypi/setuptools

    Pysvn http://pysvn.tigris.org/servlets/ProjectDocumentList?folderID=1768 (使用svn 时需安装)

注意:下载PysqliteSetuptools 时,应选择与Python 一致的版本。

Windows 下安装步骤

    本例使用SQLite 数据库,仅为体验JCR ,采用了最精简的安装方式。如正式使用推荐使用其它数据库,安装步骤请参阅JCR 安装文档。

    JCR 使用了一些Linux/UNIX/GNU 工具 (targzipunzip) 来支持上传文件方式的Review 。因此在windows 下仅能使用svn 的方式,或者在windows 下安装Cygwin(http://cygwin.com/) ,它提供了GNU 工具。另外http://gnuwin32.sourceforge.net/ 提供了很多GNU 工具,不知是否能被利用,JCR 文档中没有提及。

1) 安装Python

2) 安装Setuptools

安装完后,增加“Python/Scripts ”到PATH 环境变量。

3) 安装Pysqlite

4) 安装JCR

解压JCR 压缩包到某一路径,如“D:\ jcr-0.7.2.1 ”,在命令行运行如下命令:

% cd D:\jcr-0.7.2.1

% easy_install -f . jcr

运行此命令后,将先安装一系列的依赖(PylonsPasterSqlalchemyAuthkit) ,然后安装JCRJCR 安装在“Python\Lib\site-packages ”路径下。

windows 下,还需执行如下命令安装webob

easy_install "WebOb==0.9.6.1"

5) 生成JCR 配置文件

    % cd D:\jcr-0.7.2.1

% paster make-config jcr jcr.ini

执行此命令后,将在当前路径下生成配置文件jcr.ini 。使用Sqlite 数据库时,不需修改任何配置;使用其他数据库时,应修改database URL(sqlalchemy.url)base directory(jcr.base.dir)log file pathargs )等。

6) 装配JCR

    % cd D:\jcr-0.7.2.1

% paster setup-app jcr.ini

执行此命令后,将初始化JCR 数据库,并建立一个样例工程。

注意:在windows 下安装时将提示缺少GNU 工具,输入“y ”后,才能继续安装。

7) 启动JCR

    % cd D:\jcr-0.7.2.1

% paster serve jcr.ini

执行完毕后,登录JCR http://localhost:5000/ JCR 预设了三个用户,密码为“password0 ”。

admin – 管理员或超级用户。

johnd – 正常用户,是样例工程的拥有者。

wille – 正常用户。

如果要使用Subversion repository ,必须使用admin 用户,选择Maintenance/Repositories ,维护repository 信息。

四、Codestriker

    Codestriker 是一个开源的、基于Web 的应用,支持在线Code Review ,支持常用的SCM 和数据库。CodestrikerPerl 语言编写,可运行在所有的主流平台和浏览器下。安装后体验了一下,本人感觉其仅提供了比较基础的功能,使用也不大方便。

官方主页: http://codestriker.sourceforge.net/

当前版本:1.9.10(2009-11-02)

支持的SCMCVSSubversionPerforceVisual Source SafeClearCaseBugzilla

支持的数据库:MySQLPostgreSQLOracleSQL ServerSqlite ,如要使用其它数据库需自己实现Perl DBI interface

支持的Web 服务器:Apache HTTP ServerIIS

依赖的软件:

    ActivePerl-5.8.8.822

注意:应使用ActivePerl5.8 ,可从网络搜索,ActivePerl 官方主页只提供了最新版本。

ActivePerl 官方主页: http://www.activestate.com/activeperl/downloads )。

    highlight-setup-3.5 http://www.andre-simon.de/ 用来高亮显示代码。

Windows 下安装步骤

1 下载codestriker 压缩包并解压到某个路径,如“D:\codestriker-1.9.10 ”。

2 建立codestriker 数据库

MySQL 为例,在mysql 的提示符下输入下面的命令并执行:

CREATE DATABASE codestrikerdb CHARACTER SET utf8;

GRANT SELECT,INSERT,UPDATE,DELETE,INDEX,ALTER,CREATE,DROP,REFERENCES

ON codestrikerdb.* TO codestriker@localhost IDENTIFIED BY ‘cspasswd’;

FLUSH PRIVILEGES;

QUIT

注意:如未使用以上数据库名、用户名、密码,或使用了其他数据库,应修改codestriker 根目录下的配置文件codestriker.conf 。配置文件中提供了几种数据库配置示例。

3 安装ActivePerl

安装完毕后,增加“C:\Perl\bin ”到 path 环境变量。

4 安装highlight

安装完毕后,修改codestriker 配置中的$highlighter 项。

5 运行install.pl

% cd D:\codestriker-1.9.10\bin

% install.pl

运行install.pl 后,将提示缺少的Perl modules 及安装方法。

需运行如下命令后,然后再次运行install.pl

ppm install http://theoryx5.uwinnipeg.ca/ppms/DBD-mysql.ppd

ppm install http://theoryx5.uwinnipeg.ca/ppms/Template-Toolkit.ppd

install.pl 成功运行后将初始化codestriker 数据库。

install.pl 可多次运行,可用来升级codestriker ,或codestriker 安装位置变更后,用来更新配置。

6 安装配置Apache HTTP Server

使用的Apache HTTP Server 的版本为2.0 ,为避免一些问题,安装路径不要有空格,安装完毕后需修改conf 中的配置文件httpd.conf ,并重启Apache

Codestriker 可运行在两种模式下CGI ScriptmodPerlmodPerl 模式性能更高。

CGI Script 配置

apache 配置文件中增加如下配置,其中“D:/codestriker-1.9.10 ”为codestriker 安装位置。

ScriptAlias /codestriker/ "D:/codestriker-1.9.10/cgi-bin/"

Alias /codestrikerhtml/ "D:/codestriker-1.9.10/html/"

 

    AllowOverride None

    Options ExecCGI

    Order allow,deny

    Allow from all

    SetHandler cgi-script

 

    AllowOverride None

    Allow from all

modPerl 配置

先安装mod_perl ,命令如下(可到http://theoryx5.uwinnipeg.ca/ppms/ 查看mod_perl 对应的apache 版本):

ppm install http://theoryx5.uwinnipeg.ca/ppms/mod_perl-2.0.ppd

 

修改apache 配置文件,增加如下内容:

LoadFile "C:/Perl/bin/perl58.dll"

LoadModule perl_module modules/mod_perl.so

 

Alias /codestriker/ "D:/codestriker-1.9.10/cgi-bin/"

Alias /codestrikerhtml/ "D:/codestriker-1.9.10/html/"

 

    SetHandler perl-script

    PerlHandler ModPerl::Registry

    Options +ExecCGI

    AllowOverride None

    Allow from all

本人曾尝试使用Apache 2.2 ,在modPerl 模式下,不能访问网页。

7 运行codestriker

重启Apache 后,在浏览器地址栏输入 http://localhost/codestriker/codestriker.pl

其它emailscm 等配置请参阅codestriker 文档。

五、Rietveld

    Rietveld 是基于WebCode Review 工具,作者为Python 之父Guido van Rossum ,是在Mondrian 工具基础上开发的。它使用了目前流行的web 开发框架Django ,支持Subversion 。现在,任何在 Google Code 上托管的项目都可以使用 Rietveld 以及 Python Subversion 服务器。可以从官网下载它的源码。

官方主页: http://code.google.com/p/rietveld/

中文文档: http://code.google.com/intl/zh-CN/appengine/articles/rietveld.html

依赖软件:Python 2.5+ (不支持Python 3

 

你可能感兴趣的:(Review,Board,Jupiter,JCR,Code,Review,安装)