Matej Cepl: Current State of the Distributed Issue Tracking |
While listening to the old issue of The Git Minutes podcast, I was again reminded about the possibility of the distributed issue tracking. Albeit I have grown to be persuaded that the issue tracking has to have available web input (because “normals” won’t file bugs via git) and tried to work with normal Bugzilla (and found it surprisingly simple), I am still intrigued by the idea of the issues data (or metadata?) stored in the repository itself and followed with the git branches. Therefore, I have decided to write this brief overview of the current state (i.e., summer 2013) of the distributed issue trackers (mostly limited to those working with git), and to evaluate whether it would be possible to use some of them.
Generally to introduce whole landscape of the distributed issue trackers let me present you this very old photograph of the landscape after the Battle of Verdun
Unfortunately, this image really well represents the current situation of the distributed issue trackers. Most of the projects mentioned below are defunct and abandoned even by its original authors.
Generally I would say that the thinking in this area ended up in one of the two camps:
Seems like alive project (which is rare), the latest commit on master was just in the October last year (by me, true ;)). Also, written in Python, which is a plus (for me).
gitissius is another rare example of the project which is not completely dead yet. Also, I have been working on some improvements , but nothing has been merged in the upstream yet (perhaps, because it is broken?)
Rubyforge homesite, also some bugs are listed on Launchpad, and there is (dead) email list
Python clone ... pitz https://github.com/mw44118/pitz
Ditz commander https://code.google.com/p/ditz-commander/
There is also ditz-trac to sync ditz database with Trac. Not working ATM.
Presentation and code
http://www.ditrack.org/ ... SVN based
https://github.com/schacon/ticgit/wiki declares project as dead and suggests https://github.com/jeffWelling/ticgit
This is the granddaddy of all issues-in-separate-branch systems.
https://github.com/jwiegley/git-issues
I have my own version with an attempt to bring a little bit of sanity to the code on http://luther.ceplovi.cz/git/git-issues.git but truly, one should use gitissius instead.
http://dist-bugs.branchable.com/people/bartman/git-case/ and https://github.com/bartman/git-case
Looks like yet another bugs-stored-in-hidden-directory issue tracker. Also, it is dead (last commit is four years old).
http://www.eharning.us/wiki/stick/, unfortunately the link to the code gives 404.
https://lwn.net/Articles/434922/ and http://syncwith.us/sd/
Not part of any DVCS, distributed only the meaning that it is based on the distributed database Prophet. There is a nice discussion by Lars Wirzenius why he believes that’s The Right Thing™ to do, and why bugs shouldn’t be stored in the repository itself.
http://www.mrzv.org/software/artemis/ ... Mercurial extension, doesn’t work with git.
DisTract Linuxmafia article has this to say about it:
We're all now familiar with working with distributed software control systems, such as Monotone, Git, Darcs, Mercurial and others, but bug trackers still seem to be fully stuck in the centralised model: Bugzilla and Trac both have single centralised servers. This is clearly wrong, as if you're able to work on the Train, off the network and still perform local commits of code then surely you should also be able to locally close bugs too.
DisTract allows you to manage bugs in a distributed manner through your Web browser. Currently only Firefox is supported. The reason for this is that there is no local server used, and so the Web browser must directly (via Javascript) call programs on your local system. I only know how to do this in Firefox. The distribution is achieved by making use of a distributed software control system, Monotone. Thus Monotone is used to move files across the network, perform merging operations and track the development of every bug. Finally, the glue in the middle that generates the HTML summaries and modifies the bugs is written in Haskell.
Other features include the use of Markdown markup syntax for bug descriptions and comments, with live preview via a Javascript implementation of Markdown.
Code is Haskell and Javascript. New BSD licence.
Just to acknowledge that there also other reviews of this area:
https://luther.ceplovi.cz/blog/2014/04/30/current-state-distributed-issue-tracking/
Комментировать | « Пред. запись — К дневнику — След. запись » | Страницы: [1] [Новые] |