Where does a TeamCity build agent get its path environment from?
Solution 1
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.
Solution 2
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.)
Solution 3
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).
Solution 4
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.
Solution 5
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
Related videos on Youtube
erikkallen
Updated on July 09, 2022Comments
-
erikkallen almost 2 years
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?
-
tishma over 12 yearsI hate to guess, but if you are running it as a windows service, the environment would come from the user running the service.
-
erikkallen about 12 yearsNo, no solution. I ditched TeamCity and now use CruiseControl.net instead.
-
-
Joe Young almost 10 yearsSame here. Using 8.0.5 and had to restart the agents to get the changes picked up.
-
Jack Ukleja almost 8 yearsBe warned: I think
env.PATH=%env.PATH%:/my/path
will resolve to the literal"%env.PATH%:/my/path"
unless%env.PATH%
had already been previously defined in TC. But%env.PATH%
is not the same as trying to append to your existing path using %PATH%;... . To do that you might need to use %%PATH%% so that the percentages are escaped... -
Dirk Groeneveld over 5 yearsI just tried this, and found that Schneider's comment is wrong, and mockaroodev's approach works.