Where does a TeamCity build agent get its path environment from?

30.4k views Asked by At

I'm trying to set up TeamCity to build my project, but my psake buildscript fails, with the reason being narrowed down to its inability to find the git executable, which is supposed to be on the path. When I start a PowerShell and execute the thing by myself, everything works fine.

The content of the Path environment variable (as shown in the System variables list in the windows Environment Variables dialog, as well as the registry at HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Control\Session Manager\Environment\Path) is

%SystemRoot%\system32;%SystemRoot%;%SystemRoot%\System32\Wbem;c:\Program Files (x86)\Microsoft SQL Server\90\Tools\binn\;c:\Program Files (x86)\Microsoft SQL Server\100\Tools\Binn\;c:\Program Files\Microsoft SQL Server\100\Tools\Binn\;c:\Program Files\Microsoft SQL Server\100\DTS\Binn\;c:\Program Files (x86)\Microsoft SQL Server\100\Tools\Binn\VSShell\Common7\IDE\;c:\Program Files (x86)\Microsoft SQL Server\100\DTS\Binn\;C:\Program Files (x86)\Git\cmd

yet TeamCity says its env.Path is just

C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;c:\Program Files (x86)\Microsoft SQL Server\90\Tools\binn\;C:\Windows\System32\WindowsPowerShell\v1.0

I have restarted the computer (multiple times) which does not help whatsoever.

Why is the TeamCity build agent's PATH variable different from the system default, and how can I fix it?

5

There are 5 answers

0
Patrick McDonald On

My solution, hinted at by tishma's comment, was to modify the Path environment variable for the User and restart the Team City Build Agent Service

Edit: This bug has been fixed as of TeamCity 7.1

1
Sean On

I ran into this same issue and only needed to restart the Team City Build Agent Service to pick up changes to the PATH variable.

0
yves amsellem On

Some previous answers are correct, but are lacking details (and take me some time to really understand them) — Where the Default Agent takes its environment variables is not clear to me: so here is a way to clearly fix them in the agent configuration.

Editing the TeamCity/buildAgent/conf/buildAgent.properties file with env.PATH=/usr/whatever will do the trick. The documentation has a small hint on that.

Once, you've edited that file, you can check in the UI, in Agents > Default Agent > Agent Parameters > Environment Variables that they've been updated (careful, thought, those variables are only refreshed in the UI when the agent is connected; if it's disconnected, the UI displays the previous values).

2
mockaroodev On

You can expand the path for a build agent by adding a build parameter named "env.PATH" with the following value on Mac OS and Linux.

%env.PATH%:/my/path

On Windows use ";" instead of ":" as the path delimiter.

You can also add the following to conf/buildAgent.properties in your build agent installation directory.

env.PATH=%env.PATH%:/my/path

(There is a comment at the bottom of the file that shows how to set environment vars.)

0
tishma On

The solution is in Build Configuration/6 Build Parameters where you can override env.[ANYTHING] variables.

P.S. Sry to hear that. I'm still determined to succeed with TeamCity.