Trac+subversion拥有强大的bug管理能力

Trac 介绍

今天介绍一下Trac,一个基于Web的bug管理系统。

  • Trac官方主页
  • Trac示例

Trac拥有强大的bug管理 功能,并集成了Wiki 用于文档管理。它还支持代码管理工具Subversion ,这样可以在 bug管理和Wiki中方便地参考程序源代码。

bug管理

在Trac中,项目中出现的问题称为ticket。像bug、功能改进、 TODO等都可以写成一个ticket。

  • 可设置ticket的优先级别。
  • 可以设置ticket的里程碑,表明这个ticket应在何时完成,并能够通过条形图方式显示里程碑的完成度。
  • 可以自定义条件生成bug报告,并可以通过SQL语句自定义报告的格式。

Subversion集成

通过Subversion集成,开发者可在Trac中以Web方式浏览代码库中各个版本的代码和代码的修改历史,并可方便地比较各个版本间的差别。

Wiki

支持常用的Wiki语法。同时增加了许多bug管理的专用标记,可以方便地创建到ticket、代码行甚至修改历史的链接。

Trac使用Python写成,后台使用SQLite或PostgreSQL数据库,因此构筑一个完整的Trac系统需要安装以下软件:

  • Apache
  • Python
  • Subversion
  • PostgreSQL(可选)

下回继续介绍Trac的安装方法。

基于Trac的项目管理系统构建(Windows篇)

关于Trac的介绍请参见前一篇文章 。

这里我们要构建一个基于Trac的项目管理系统。代码管理使用subversion,项目管理使用Trac。所需要的软件包如下:

  • Trac 0.10 ,Trac程序
  • Apache 2.0.59 ,Web服务器
  • subversion 1.4.3 ,代码版本管理工具
  • Python 2.4.4 ,Python解释器
  • mod_python ,Python的Apache模块
  • ClearSilver 0.9.4 ,Python的模版工具
  • mxDateTime 2.0.3 ,Python必须库文件
  • PostgreSQL 8.2.3 ,数据库服务器
  • pyPgSQL 2.5.1 ,Python访问PostgreSQL数据库的模块

很遗憾subversion现在仍然不支持最新的Apache 2.2系列,因此我们只能使用Apache 2.0系列。而pyPgSQL 2.5.1版和ClearSilver 0.9.4不支持Python 2.5,因此只能用 Python 2.4。

另外,虽然Trac支持SQLite,但SQLite支持的SQL语法有限,实际应用中会有诸多不便,因此我们选择了PostgreSQL作为后台数据库。

安装错误时怎么办?

如果你安装过程中发现某些地方不正常,记住按照下面的方法来纠正:

  1. 查看错误信息,看是否能找到提示
  2. 检查有无忘了装的软件
  3. 检查httpd.conf是否有误
  4. 修改之后记得重新启动Apache

安装Apache和subversion

在Apache官方网站 上下载2.0.59版的msi安装包,执行即可。为方便起见,建议将Apache安装到根目录下,例如 D:/Apache。安装时的一些细节可以参考这篇文章 。安装完毕后用浏览器访问 http://localhost/ ,如能看到Apache的起始页面即安装成功。

从subversion 上下载zip包解压缩即可,目前最新版本为svn-win32-1.4.3.zip。假设解压到 D:/svn下。

然后将subversion与Apache集成在一起(也可参考这篇文章 )。将 D:/svn/bin 下的以下文件复制到 D:/Apache/Apache2/modules 目录下:

  • mod_authz_svn.so
  • mod_dav_svn.so

将 D:/svn/bin 下的以下文件复制到 D:/Apache/Apache2/bin 目录下:

  • libdb44.dll
  • intl3_svn.dll

然后建立代码仓库目录 D:/repos。

然后修改 D:/Apache/Apache2/conf/httpd.conf,查找下面这一行,去掉前面的 # 号。

LoadModule dav_module modules/mod_dav.so

然后在其附近添加以下这一行:

LoadModule dav_svn_module modules/mod_dav_svn.so

之后在 httpd.conf 的末尾添加以下内容:

<Location /repos>
DAV svn
SVNParentPath D:/repos
</Location>

然后重新启动Apache。之后试着访问一个不存在的页面,如 http://localhost/abc ,你会看到Not Found 页面下方的内容如下:

Apache/2.0.59 (Win32) SVN/1.4.3 DAV/2 Server at localhost Port 80

如果这里显示了 SVN/1.4.3 则说明安装成功。

安装Python、mod_python和SVN binding

从Python官方网站 下载Python 2.4的msi安装包进行安装,假设安装到D:/Python24目录下。

从mod_python的下载页面 上下载mod_python 3.3.0b的Win32版(mod_python-3.3.0b.win32-py2.4-Apache2.0.exe)。安装时它会问你Apache的安装位置,输入 D:/Apache/Apache2 即可。

最后打开 D:/Apache/Apache2/conf/httpd.conf,查找 LoadModule,加入下面这一行:

LoadModule python_module modules/mod_python.so

然后重新启动Apache。之后试着访问一个不存在的页面,如 http://localhost/abc ,你会看到Not Found 页面下方的内容如下:

Apache/2.0.59 (Win32) SVN/1.4.3 mod_python/3.3.0b Python/2.4.4 DAV/2 Server at localhost Port 80

如果这里显示了 mod_python/3.3.0b Python/2.4.4 则说明安装成功。

最后要安装subversion binding使Python支持subversion。到刚才下载subversion的地方 下载 svn-win32-1.4.3_py2.4.exe 文件并安装。

安装PostgreSQL和pyPgSQL

到PostgreSQL官方主页 下载最新版8.2.3(postgresql-8.2.3-1.zip)并安装。

为了让Python支持PostgreSQL,我们还需要安装pyPgSQL模块。到pyPgSQL主页 下载2.5.1版并安装。

安装结束之后,需要将 bin 目录下的以下文件复制到 D:/Python24/Lib/site-packages/pyPgSQL/libpq 下。

  • libpq.dll
  • comerr32.dll
  • libeay32.dll
  • libintl-2.dll
  • libiconv-2.dll
  • krb5_32.dll
  • ssleay32.dll

安装ClearSilver和mxDateTime

在ClearSilver的下载页面 选择0.9.4的py2.4版下载 (win32/clearsilver-0.9.14.win32-py2.4.exe)并安装。

Trac官方文档 中虽然没有说明mxDateTime,但是建立项目时Trac会报错,要求你安装mxDateTime库。从mxDateTime主页 下载并安装。

安装Trac

最后终于轮到主角Trac出场了。在Trac下载页面 上下载 Trac安装程序(trac-0.10.3.win32.exe)并安装。

然后建立项目目录 D:/projects。

然后打开 D:/Apache/Apache2/conf/httpd.conf,在最末尾添加以下内容:

<Location /projects>
SetHandler mod_python
PythonHandler trac.web.modpython_frontend
PythonOption TracEnvParentDir D:/projects
PythonOption TracUriRoot /projects
</Location>

然后重新启动Apache,访问 http://localhost/projects/ ,你会看到Available Projects 字样,则说明安装成功。至此安装全部完毕。

建立项目

下面我们要建立一个实际开发中使用的项目。我们为这个项目命名为 hello。

首先要建立一个代码仓库。打开命令行,输入以下命令:

D:
cd D:/repos
md hello
cd hello
D:/svn/bin/svnadmin create .

然后打开浏览器,访问 http://localhost/repos/hello/ 。如果你上面的设置都正确,你将会看到下面的内容:

Revision 0: /
----------------------------------------------
Powered by Subversion version 1.4.3 (r23084).

即说明代码仓库建立成功,而 http://localhost/repos/hello/ 就是代码仓库的 URL。

然后建立数据库。从开始菜单中启动PostgreSQL的 pg Admin III工具,新建一个数据库 hello,注意将字符编码设置为UTF8。

然后建立Trac项目。打开命令行,输入以下命令:

D:
cd D:/projects
D:/Python24/python.exe D:/Python24/Scripts/trac-admin hello initenv

trac-admin 为Trac的管理工具,hello为项目名,initenv命令指示Trac新建一个项目。然后按照下面的内容输入:

Project Name [My Project]> Hello World
Database connection string [sqlite:db/trac.db]> postgres://<username>:<password>@localhost/hello
Repository type [svn]> svn
Path to repository [/path/to/repos]> D:/repos/hello
Templates directory [D:/Python24/share/trac/templates]>

数据库连接那一行,<username>和<password>分别为安装PostgreSQL时设置的用户名和密码。如果创建失败,则需要删除 D:/projects/hello 之后再重试。

最后打开浏览器,访问 http://localhost/projects/hello 即可看到Trac的界面了。

设置HTTP认证

在Trac界面右上方有个Login菜单,通过这个菜单登录之后,创建bug或者做其他修改时就不用每次都输入用户名。不过这个菜单需要单独配置才能正常工作。

首先我们要生成密码文件。打开命令行,输入以下命令:

D:
cd D:/projects
D:/Apache/Apache2/bin/htpasswd -c .htpasswd admin
Automatically using MD5 format.
New password: *****
Re-type new password: *****
Adding password for user admin

即可生成密码文件 .htpasswd。以后向该密码文件里追加用户只需这样即可。

D:/Apache/Apache2/bin/htpasswd .htpasswd user

然后编辑 httpd.conf,在最末尾加入以下内容:

<LocationMatch "/projects/[^/]+/login">
AuthType Basic
AuthName "Trac"
AuthUserFile D:/projects/trac.htpasswd
Require valid-user
</LocationMatch>

然后重新启动Apache。

你可能感兴趣的:(Trac+subversion拥有强大的bug管理能力)