Problems using MSBuild XMLUpdate and UpdateFiles

Hi,
We have a large application and are trying to automate the build process between different environments.
I have an MSBuild script working quite well for the majority.
I have successfully got FileUpdate working in the "UpdateConnections" target (see below), and this loops through the .config files and .cs files etc replacing any instance it comes across.
It also does the connectionstrings in web.config which is great.

I'm now looking to tackle the web.config for other things.
We have a number of appSettings we need to change, and also have an identity we impersonate in system.web.

See below for an example of this web.config.

As you can see, we would like to update appVersion, and SCIUploadPath.
I have tried:

<XmlUpdate      
                  Namespace="http://schemas.microsoft.com/.NetConfiguration/v2.0"            
                  XmlFileName="$(BuildDirectory)\web.config"
                  Xpath="/configuration/appSettings/add[@key='appVersion']/@value"
                  Value="154"
              />

But this didn't bring any luck.
In the log I just got:

<message level="normal"><![CDATA[Updating Xml Document "E:\Builds\build\PreProduction\Apps\web.config".]]></message>
      <message level="normal"><![CDATA[  0 node(s) selected for update.]]></message>
      <message level="normal"><![CDATA[XmlUpdate Wrote: "154".]]></message>

This implies it found the file etc no problem (correct path), but had a problem finding the node?

I've found exmaples online, but the Community Tasks stuff seems to be pretty porrly documented.



Also having a poor time using FileUpdate when trying to change the identity line.

             <FileUpdate Files="$(BuildDirectory)\web.config"
                          Regex="domain\user"
                          ReplacementText ="NEWDOMAIN\NEWUSER" />

Log shows:
      <message level="normal"><![CDATA[Updating File "E:\Builds\build\PreProduction\Apps\web.config".]]></message>
      <message level="normal"><![CDATA[  Replaced matches with "NEWDOMAIN\NEWUSER".]]></message>

But nothing has changed in the file.

Can anyone assist?
Code from MSBuild file: 
<Target Name="UpdateConnections" DependsOnTargets ="GetConnectionFiles">
  <Attrib Files="@(ConnectionFiles)" ReadOnly="false"/>
  <FileUpdate Files="@(ConnectionFiles)" 
      Regex="DEVELOPMENT_SERVER_DNS" 
      ReplacementText ="$(NewServer)" />
</Target>
 
 
Our web.config file: 
<?xml version="1.0" encoding="utf-8"?>
<configuration xmlns="http://schemas.microsoft.com/.NetConfiguration/v2.0">
  <configSections>
    <!--blah blah -->
  </configSections>
  <connectionStrings>
    <!--blah blah -->
  </connectionStrings>
    <compilation debug="true">
      <assemblies>
        <!--blah blah -->
      </assemblies>
    </compilation>
    <pages autoEventWireup="false" buffer="true" enableSessionState="true" viewStateEncryptionMode="Auto" enableViewStateMac="true">
      <controls>
        <!--blah blah -->
      </controls>
      <namespaces>
        <!--blah blah -->
      </namespaces>
    </pages>
    <identity impersonate="true" userName="domain\user" password="987654321" />
  </system.web>
  <location allowOverride="true" inheritInChildApplications="true">
    <appSettings>
      
      <add key="appVersion" value="v1.4.8" />
      <add key="SCIUploadPath" value="\\devserver\eprDocDump\" />
    </appSettings>
  </location>
</configuration>

Open in new window

LVL 2
SkidmercAsked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

ToddBeaulieuCommented:
Your xpath is missing a level.

Your syntax looks correct. I just checked it against my usage of the same task. It should work. Have you triple checked that the referenced file is the right COPY of that file and that you're updating it BEFORE publishing the app, where the file is copied out into the bin fodler?

Using "FileUpdate" task from assembly "C:\Program Files (x86)\MSBuild\MSBuildCommunityTasks\MSBuild.Community.Tasks.dll".
Task "FileUpdate"
  Updating File "C:\BUILDS\Work\24\BuildType\..\Sources\Dev\Core\AssemblyInfo.cs".
    Replaced matches with "AssemblyVersion("2.0.0.0")]".
  Updating File "C:\BUILDS\Work\24\BuildType\..\Sources\Dev\Core\Tests\Properties\AssemblyInfo.cs".
    Replaced matches with "AssemblyVersion("2.0.0.0")]".
Done executing task "FileUpdate".
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
SkidmercAuthor Commented:
Definitely updating the right file.
Well spotted, forgot about the location level.
However, still getting the 0 node(s) selected for read message
Using XMLRead just to output the value:

<XmlRead
            Namespace="http://schemas.microsoft.com/.NetConfiguration/v2.0"
                  XmlFileName="$(BuildDirectory)\web.config"
                  XPath="/configuration/location/appSettings/add[@key='appVersion']/@value">
                  <Output TaskParameter="Value" PropertyName="appVersion"/>
            </XmlRead>


Heard some people mention it's down to the xlmns at the top of web config and it may work without it?
0
SkidmercAuthor Commented:
I can confirm the following code works it I remove the xmlns attribute from the top line in web.config:
<configuration xmlns="http://schemas.microsoft.com/.NetConfiguration/v2.0">
leaving it as
<configuration>

<XmlRead
                  Namespace="http://schemas.microsoft.com/.NetConfiguration/v2.0"
                  XmlFileName="$(BuildDirectory)\web.config"
                  XPath="configuration/location/appSettings/add[@key='appVersion']/@value">
                  <Output TaskParameter="Value" PropertyName="appVersion"/>
            </XmlRead>

However, i don't want to have to change my web.config for the whole solution, just to be able to do this.
There must be another way?
0
Get your problem seen by more experts

Be seen. Boost your question’s priority for more expert views and faster solutions

ToddBeaulieuCommented:
I'm just heading out on vacation NOW, but I will say that if you can't find resolution quickly, it's REALLY easy to oll your own custom task that you will then have complete control over. I whipped up some to update project and assemblyinfo.cs properties in my builds. Something to consider...
0
SkidmercAuthor Commented:
That's exactly what I'm looking at just now.

Might try put together a custom WebConfigUpdate task of some sort that will be bespoke to our own processes.
0
SkidmercAuthor Commented:
Sorted.

Bit of a back possibly - but it works.

<FileUpdate Files="$(BuildDirectory)\web.config"
                          Regex="xmlns%3D%22http://schemas.microsoft.com/.NetConfiguration/v2.0%22"
                          ReplacementText =" " />
      
      <!-- Update the app version -->
            <XmlUpdate      
                  XmlFileName="$(BuildDirectory)\web.config"
                  Xpath="/configuration/location/appSettings/add[@key='appVersion']/@value"
                  Value="v$(Major).$(Minor).$(Revision)"
              />


The first one remove the "xmlns" line from the configration.
This then lets the xpath work it's stuff for the rest of the XMLUpdates.
0
SkidmercAuthor Commented:
Helped give me pointers for future work i can do with the Community Tasks project source, and helped me narrow down what was going wrong with current way of working.
0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Software

From novice to tech pro — start learning today.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.