The following instructions show how to set up a trigger script in Perforce which will notify FogBugz whenever a check-in occurs that is related to a particular bug.
We provide sample scripts in both Perl and VBScript. This article describes using Perl. If your Perforce server is on Windows and you would rather use VBScript, see the alternate instructions here.
If you are a trial user, you can download the trial versions of these scripts by logging into FogBugz and clicking "Demo Source Control Integration" on the main menu.
1. Find the logBugDataP4.pl script which is located in your FogBugz\Accessories\SourceControl\Perforce folder, and then place it in the directory that contains your Perforce server executable (e.g. C:\Program Files\Perforce\).
2. Edit the file as follows (Trial users: You only need to edit the P4USERNAME and P4PASSWORD variables. The rest of this step is set up automatically for your trial server.):
-
Bring up FogBugz in a browser and look at the url you use to access FogBugz.
-
BUGZ_SERVER: Set this to the DNS name of the web server running FogBugz, for example, www.example.com.
-
BUGZ_PORT: Only change this if FogBugz is not running on the default port 80.
-
BUGZ_URL: Set this to the virtual path to your FogBugz installation. For many sites this is "/FogBugz/". Just take the full URL of your FogBugz installation - "http://www.example.com/bugz/" and remove the "http://www.example.com" part. If FogBugz is running at the root, use "/".
-
P4USERNAME: Perforce passwords cannot be accessed from trigger scripts, so the good folks at Perforce will give you a free "background" or "automation" user for this purpose, please contact them at support@perforce.com to pursue this option. Enter the name of that user here.
-
P4PASSWORD: Enter the password of the automation user here. If you do NOT have Perforce passwords enabled, just leave this blank.
3. Perforce will let you call an executable every time files are submitted (actually, just before the submission occurs). This is called a trigger. We want to use a trigger to call the logBugDataP4.pl file every time any files are submitted in Perforce. Type p4 triggers on the command line (DOS window). A text file appears in Notepad. (If it doesn't, make sure the full path to p4.exe is in your Path environment variable.) To add the FogBugz trigger you need to add a line to at the bottom of this file.
The trigger looks slightly different depending on what version of Perforce you use:
Perforce Version 2003.2 - all triggers are of type "submit", no need to specify type:
FogBugzTrigger //... "C:\path\to\your\perl.exe C:\path\to\your\logBugDataP4.pl %changelist% %serverport% %client%"
Perforce Version 2004.2 - you must specify the type of trigger as "submit":
FogBugzTrigger submit //... "C:\path\to\your\perl.exe C:\path\to\your\logBugDataP4.pl %changelist% %serverport% %client%"
Note that this new line has a tab at the beginning. Adjust the path to the perl interpreter, and the path to the logBugDataP4.pl file to make sure it points to logBugDataP4.pl on your server (wherever you put it).
Save this temp file and close Notepad. The trigger is now added. To see how to use this integration, click here for our screenshot tutorial.
If you don't see the checkin entries in the FogBugz case, here is some troubleshooting help:
- Here is a Perforce triggers troubleshooting guide.
- Perforce version 2003.2 user manual entry on triggers.
- Perforce version 2004.2 user manual entry on triggers.
- Perforce 2004.2 global options for Perforce commands.