Mantis Bug Tracker

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search

Mantis Bug Tracker
MantisBT logo (2012).png
Original author(s)Kenzaburo Ito
Developer(s)Various (Open-source contributors)
Initial release2000; 21 years ago (2000)
Stable release
2.24.4 (December 30, 2020; 3 months ago (2020-12-30)) [±]
Preview release
2.25.0-dev (February 23, 2021; 57 days ago (2021-02-23)) [±]
Repository Edit this at Wikidata
Written inPHP
Operating systemCross-platform
Available in49 languages
List of languages
Afrikaans, Amharic, Arabic, Arabic (Egyptian), Breton, Bulgarian, Catalan, Chinese (Simplified), Chinese (Traditional), Croatian, Czech, Danish, Dutch, English, Estonian, Finnish, French, Galician, German, Greek, Hebrew, Hungarian, Icelandic, Italian, Japanese, Korean, Latvian, Lithuanian, Macedonian, Norwegian (Bokmål), Norwegian (Nynorsk), Occitan, Polish, Portuguese (Standard), Portuguese (Brazilian), Ripuarian, Romanian, Russian, Serbian, Slovak, Slovene, Spanish, Swiss German, Swedish, Tagalog, Turkish, Ukrainian, Urdu, Volapuk
TypeBug tracking system
LicenseGNU General Public License version 2

Mantis Bug Tracker is a free and open source, web-based bug tracking system. The most common use of MantisBT is to track software defects. However, MantisBT is often configured by users to serve as a more generic issue tracking system and project management tool.

The name Mantis and the logo of the project refer to the insect family Mantidae, known for the tracking of and feeding on other insects, colloquially referred to as "bugs". The name of the project is typically abbreviated to either MantisBT or just Mantis.


Kenzaburo Ito started development of the Mantis Bug Tracking project in 2000. In 2002, Kenzaburo was joined by Jeroen Latour, Victor Boctor and Julian Fitzell to be the administrators and it became a team project.[1] Version 1.0.0 was released in February 2006.[2] Version 1.1.0 was released in December 2007.[3] In November 2008, after a long discussion,[4] the project switched[5] from using the Subversion revision control tool to Git, a distributed revision control tool. In February 2010, version 1.2.0 was released.[6] In July 2012, the MantisBT organization on GitHub became the official repository for the Project's source code.[7]



An event-driven plug-in system was introduced with the release of version 1.2.0.[8] This plug-in system allows extension of MantisBT through both officially maintained and third party plug-ins. As of November 2013, there are over 50 plug-ins available on the MantisBT-plugins organization on GitHub.

Prior to version 1.2.0, a third party plug-in system created by Vincent Debout was available to users along with a variety of different plug-ins.[9] This system was not officially supported by the MantisBT project and is incompatible with MantisBT 1.2.0 and later.


MantisBT supports the sending of e-mail notifications upon changes being made to issues in the system. Users have the ability to specify the type of e-mails they receive and set filters to define the minimum severity of issues to receive notifications about. Users also have the ability to explicitly subscribe to issues that affect them.

RSS feeds are available for users who wish to keep track of issues that have been resolved. Additionally, MantisBT has integration with Twitter via a plugin, to allow a notification to be tweeted when an issue is resolved.

Via MantisBT's event-driven plug-in system, it is possible to extend the built in notification support to run advanced scripts that perform additional notification actions (such as sending SMS messages or updating statuses in external project management systems).

Revision control system integration[edit]

Versions of MantisBT prior to 1.2.0 allowed for limited integration with the CVS revision control system.[10] With the introduction of plug-in capabilities in MantisBT 1.2.0, revision control integration was redeveloped by John Reese in the SourceIntegration plugin.

The initial release of the SourceIntegration plugin supported GitHub, GitWeb, SourceForge and WebSVN.[11] Over time, two additional modules were added and as of November 2013, source integration is supported for the following revision control tools and web-based providers:

  • cgit, a web interface for Git repositories, written in C
  • GitHub, an open-source software hosting facility that hosts Git repositories
  • Gitweb, a free and open source web interface for Git repositories
  • HgWeb, a cgi web front-end for Mercurial repositories
  • SourceForge (for Subversion integration only), an open-source software hosting facility that hosts various types of software repositories
  • WebSVN, a free and open source web interface for Subversion repositories
  • RhodeCode, an OpenSource web interface to Mercurial, Git and Subversion repositories[12]

Upon committing changesets to a source code repository, post-commit hooks within Git or Subversion can be configured to automatically notify MantisBT that changes have been made to the repository. GitHub is also capable of remotely notifying a MantisBT installation of changes to a source code repository. Another technique used for integrating MantisBT with web-based source code hosting providers is the use of a job scheduler such as cron to manually check for changes to a repository every few minutes, reporting any changes back to MantisBT.[11]

SourceIntegration allows for issues within MantisBT to be automatically resolved when a changeset message contains special strings such as "Fixes #12345", which are configurable using regular expressions. This also allows for relationships to be automatically created between changesets and corresponding issues recorded in MantisBT. Multiple issue IDs can be specified in a single changeset message, although this is commonly discouraged as it indicates the changeset doesn't have a single, clear and logical purpose.[13]

Minor features[edit]

In addition to the features mentioned above, MantisBT also has support for:[14]

Technical design[edit]

Development languages[edit]

MantisBT is mainly written in PHP and uses SQL to interface with databases. The web-based user interface of MantisBT is written using HTML which is styled and presented using CSS.[15] The UI also uses the jQuery client-side JavaScript library to provide optional features such as Ajax and JSON powered dynamic page content.

Development tools and build scripts are written predominantly in Python with some Shell script and PHP.

MantisBT's codebase dates back to a time when PHP's support for object-oriented programming principles was in its infancy.[16] As of version 1.2.0, the majority of the MantisBT codebase still uses procedural programming principles, however some sections have been converted to make use of PHP 5's new object model.[17][18]

Database storage[edit]

Data is stored in a relational database management system by means of the ADOdb database abstraction library. MantisBT supports MySQL. Support for other databases ( PostgreSQL, Microsoft SQL, Oracle ) is known to be problematic. The development team are looking to fix this for the 2.0 release.[10]

MantisBT maintains a database upgrade path between versions by modifying the database schema incrementally.[19] During the installation of MantisBT, database schema modifications are replayed all the way back from early versions of MantisBT to reach the latest state.


MantisBT requires a configured web server, the PHP programming language interpreter and a relational database management system supported by MantisBT[10] and ADOdb.[20]

The stable branch of MantisBT (version numbers within 1.2.x) requires PHP 5.1.0 or later. For the development branch (1.3.x), the minimum PHP version is 5.3.2.[21]

Several PHP extensions are required[10] to enable specific functionality or for performance reasons; the extension for the RDBMS being used (i.e. mysqli) is mandatory.

MantisBT bundles a number of dependencies with each release including:[22]

For drawing graphs of relationships between issues, GraphViz is required. MantisBT also has an alternative dependency upon the commercial JpGraph graphics library for plotting of statistics.

See also[edit]


  1. ^ "team of MantisBT. This marks a new era in MantisBT lifetime where it is now a team project".
  2. ^ "Mantis 1.0.0 (stable) Released". MantisBT announcements mailing list. February 4, 2006.
  3. ^ "Mantis 1.1.0 Released". Mantis Bug Tracker Blog. December 20, 2007.
  4. ^ "Moving from SVN to Git". Mantisbt-dev mailing list. November 4, 2008.
  5. ^ John Reese (November 10, 2008). "First MantisBT Git commit".
  6. ^ "MantisBT 1.2.0 Released". Mantis Bug Tracker Blog. February 22, 2010.
  7. ^ "MantisBT Moving to Github". MantisBT announcements mailing list. July 12, 2011.
  8. ^ "MantisBT 1.2.0rc1 Release Candidate 1". Mantis Bug Tracker Blog. June 23, 2009.
  9. ^ "Mantis bugtracker plugins". Retrieved July 14, 2010. CS1 maint: discouraged parameter (link)
  10. ^ a b c d e f "Mantis Bug Tracker Administration Guide". Archived from the original on December 2, 2013. Retrieved November 11, 2013. CS1 maint: discouraged parameter (link)
  11. ^ a b Reese, John (January 7, 2009). "Integrating Git and SVN with the Mantis Bug Tracker". Retrieved November 11, 2013. CS1 maint: discouraged parameter (link)
  12. ^
  13. ^ "Subversion Best Practices". Retrieved August 22, 2012. CS1 maint: discouraged parameter (link)
  14. ^ "Mantis Feature List". MantisBT wiki. September 25, 2012. Retrieved November 11, 2013. CS1 maint: discouraged parameter (link)
  15. ^ "Languages". Retrieved November 12, 2013. CS1 maint: discouraged parameter (link)
  16. ^ "History of PHP". November 8, 2013. Retrieved November 12, 2013. CS1 maint: discouraged parameter (link)
  17. ^ "MantisBT source code". June 11, 2009.
  18. ^ "MantisBT source code". February 6, 2008.
  19. ^ "MantisBT source code - admin/schema.php". Retrieved November 12, 2013. CS1 maint: discouraged parameter (link)
  20. ^ "ADODB Manual". Retrieved November 12, 2013. CS1 maint: discouraged parameter (link)
  21. ^ "Mantis Bug Tracker | Requirements". Archived from the original on September 5, 2012. Retrieved November 12, 2013. CS1 maint: discouraged parameter (link)
  22. ^ "MantisBT source code - library/README.libs". Retrieved November 12, 2013. CS1 maint: discouraged parameter (link)

External links[edit]