#21 Tests for InsertOrAppend xdt transform
This commit is contained in:
parent
4c2a57fd9e
commit
16ee691c3e
|
|
@ -1,6 +1,6 @@
|
|||
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||
# Visual Studio 15
|
||||
VisualStudioVersion = 15.0.26814.1
|
||||
VisualStudioVersion = 15.0.27004.2002
|
||||
MinimumVisualStudioVersion = 15.0.26730.03
|
||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.AspNetCore.AzureAppServicesIntegration", "src\Microsoft.AspNetCore.AzureAppServicesIntegration\Microsoft.AspNetCore.AzureAppServicesIntegration.csproj", "{5916BEB5-0969-469B-976C-A392E015DFAC}"
|
||||
EndProject
|
||||
|
|
@ -46,6 +46,10 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.AspNetCore.AzureA
|
|||
EndProject
|
||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Microsoft.AspNetCore.AzureAppServices.TestBundle", "src\Microsoft.AspNetCore.AzureAppServices.TestBundle\Microsoft.AspNetCore.AzureAppServices.TestBundle.csproj", "{1EC31DA1-131D-4257-B001-BE8391E6077E}"
|
||||
EndProject
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Microsoft.Web.Xdt.Extensions.Tests", "test\Microsoft.Web.Xdt.Extensions.Tests\Microsoft.Web.Xdt.Extensions.Tests.csproj", "{809AEE05-1B28-4E31-8959-776B249BD725}"
|
||||
EndProject
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Microsoft.AspNetCore.AzureAppServices.SiteExtension.Tests", "test\Microsoft.AspNetCore.AzureAppServices.SiteExtension.Tests\Microsoft.AspNetCore.AzureAppServices.SiteExtension.Tests.csproj", "{491A857A-3529-4375-985D-D748F9F01476}"
|
||||
EndProject
|
||||
Global
|
||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||
Debug|Any CPU = Debug|Any CPU
|
||||
|
|
@ -100,6 +104,14 @@ Global
|
|||
{1EC31DA1-131D-4257-B001-BE8391E6077E}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{1EC31DA1-131D-4257-B001-BE8391E6077E}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{1EC31DA1-131D-4257-B001-BE8391E6077E}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
{809AEE05-1B28-4E31-8959-776B249BD725}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{809AEE05-1B28-4E31-8959-776B249BD725}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{809AEE05-1B28-4E31-8959-776B249BD725}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{809AEE05-1B28-4E31-8959-776B249BD725}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
{491A857A-3529-4375-985D-D748F9F01476}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{491A857A-3529-4375-985D-D748F9F01476}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{491A857A-3529-4375-985D-D748F9F01476}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{491A857A-3529-4375-985D-D748F9F01476}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(SolutionProperties) = preSolution
|
||||
HideSolutionNode = FALSE
|
||||
|
|
@ -117,6 +129,8 @@ Global
|
|||
{0899A101-E451-40A4-81B0-7AA18202C25D} = {CD650B4B-81C2-4A44-AEF2-A251A877C1F0}
|
||||
{2B2C37FF-9249-4EA4-9A7F-038B55A15C2C} = {CD650B4B-81C2-4A44-AEF2-A251A877C1F0}
|
||||
{1EC31DA1-131D-4257-B001-BE8391E6077E} = {FF9B744E-6C59-40CC-9E41-9D2EBD292435}
|
||||
{809AEE05-1B28-4E31-8959-776B249BD725} = {CD650B4B-81C2-4A44-AEF2-A251A877C1F0}
|
||||
{491A857A-3529-4375-985D-D748F9F01476} = {CD650B4B-81C2-4A44-AEF2-A251A877C1F0}
|
||||
EndGlobalSection
|
||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||
SolutionGuid = {5743DFE7-1AA5-439D-84AE-A480EA389927}
|
||||
|
|
|
|||
|
|
@ -14,6 +14,9 @@
|
|||
Condition="'$(AntaresTests)' == ''"
|
||||
Include="$(FunctionalTestsProject)" />
|
||||
|
||||
<ExcludeFromTest Include="$(RepositoryRoot)test\Microsoft.AspNetCore.AzureAppServices.SiteExtension.Tests\*.csproj" Condition="'$(TRAVIS)' == 'true'" />
|
||||
<ExcludeFromTest Include="$(RepositoryRoot)test\Microsoft.Web.Xdt.Extensions.Tests\*.csproj" Condition="'$(TRAVIS)' == 'true'" />
|
||||
|
||||
<PackageLineup Include="Internal.AspNetCore.Universe.Lineup" Version="2.1.0-*" />
|
||||
<PackageLineup Include="Internal.AspNetCore.Partners.Lineup" Version="2.1.0-*" />
|
||||
</ItemGroup>
|
||||
|
|
|
|||
|
|
@ -107,10 +107,12 @@ namespace Microsoft.Web.Xdt.Extensions
|
|||
|
||||
foreach (XmlNode targetNode in TargetChildNodes)
|
||||
{
|
||||
var foundAttribute = false;
|
||||
foreach (XmlAttribute att in targetNode.Attributes)
|
||||
{
|
||||
if (string.Equals(att.Name, AttributeName, StringComparison.OrdinalIgnoreCase))
|
||||
{
|
||||
foundAttribute = true;
|
||||
if (string.IsNullOrEmpty(att.Value))
|
||||
{
|
||||
att.Value = transformAtt.Value;
|
||||
|
|
@ -128,6 +130,13 @@ namespace Microsoft.Web.Xdt.Extensions
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!foundAttribute)
|
||||
{
|
||||
var attribute = targetNode.OwnerDocument.CreateAttribute(AttributeName);
|
||||
attribute.Value = transformAtt.Value;
|
||||
targetNode.Attributes.Append(attribute);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -0,0 +1,29 @@
|
|||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net461</TargetFramework>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<Content Include="..\..\src\Microsoft.AspNetCore.AzureAppServices.SiteExtension\applicationHost.xdt" Link="applicationHost.xdt">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
<Content Include="config_empty.xml">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
<Content Include="config_existingemptyvalue.xml">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
<Content Include="config_existingline.xml">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
<Content Include="config_existingvalue.xml">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\..\src\Microsoft.Web.Xdt.Extensions\Microsoft.Web.Xdt.Extensions.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
|
|
@ -0,0 +1,78 @@
|
|||
// Copyright (c) .NET Foundation. All rights reserved.
|
||||
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
|
||||
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Xml;
|
||||
using Microsoft.Web.XmlTransform;
|
||||
using Xunit;
|
||||
|
||||
namespace Microsoft.AspNetCore.AzureAppServices.SiteExtension
|
||||
{
|
||||
public class TransformTest
|
||||
{
|
||||
[Theory]
|
||||
[InlineData("config_empty.xml")]
|
||||
[InlineData("config_existingline.xml")]
|
||||
[InlineData("config_existingEmptyValue.xml")]
|
||||
public void Transform_EmptyConfig_Added(string configFile)
|
||||
{
|
||||
var doc = LoadDocAndRunTransform(configFile);
|
||||
|
||||
Assert.Equal(2, doc.ChildNodes.Count);
|
||||
var envNode = doc["configuration"]?["system.webServer"]?["runtime"]?["environmentVariables"];
|
||||
|
||||
Assert.NotNull(envNode);
|
||||
|
||||
Assert.Equal(2, envNode.ChildNodes.Count);
|
||||
|
||||
var firstChild = envNode.FirstChild;
|
||||
Assert.Equal("add", firstChild.Name);
|
||||
Assert.Equal("DOTNET_ADDITIONAL_DEPS", firstChild.Attributes["name"].Value);
|
||||
Assert.Equal(@"%ProgramFiles%\dotnet\additionalDeps\Microsoft.AspNetCore.AzureAppServices.HostingStartup\",
|
||||
firstChild.Attributes["value"].Value);
|
||||
|
||||
var secondChild = firstChild.NextSibling;
|
||||
Assert.Equal("add", secondChild.Name);
|
||||
Assert.Equal("ASPNETCORE_HOSTINGSTARTUPASSEMBLIES", secondChild.Attributes["name"].Value);
|
||||
Assert.Equal("Microsoft.AspNetCore.AzureAppServices.HostingStartup", secondChild.Attributes["value"].Value);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void Transform_ExistingValue_AppendsValue()
|
||||
{
|
||||
var doc = LoadDocAndRunTransform("config_existingvalue.xml");
|
||||
|
||||
Assert.Equal(2, doc.ChildNodes.Count);
|
||||
var envNode = doc["configuration"]?["system.webServer"]?["runtime"]?["environmentVariables"];
|
||||
|
||||
Assert.NotNull(envNode);
|
||||
|
||||
Assert.Equal(2, envNode.ChildNodes.Count);
|
||||
|
||||
var firstChild = envNode.FirstChild;
|
||||
Assert.Equal("add", firstChild.Name);
|
||||
Assert.Equal("DOTNET_ADDITIONAL_DEPS", firstChild.Attributes["name"].Value);
|
||||
Assert.Equal(@"ExistingValue1;%ProgramFiles%\dotnet\additionalDeps\Microsoft.AspNetCore.AzureAppServices.HostingStartup\",
|
||||
firstChild.Attributes["value"].Value);
|
||||
|
||||
var secondChild = firstChild.NextSibling;
|
||||
Assert.Equal("add", secondChild.Name);
|
||||
Assert.Equal("ASPNETCORE_HOSTINGSTARTUPASSEMBLIES", secondChild.Attributes["name"].Value);
|
||||
Assert.Equal("ExistingValue2;Microsoft.AspNetCore.AzureAppServices.HostingStartup", secondChild.Attributes["value"].Value);
|
||||
}
|
||||
|
||||
private static XmlDocument LoadDocAndRunTransform(string docName)
|
||||
{
|
||||
// Microsoft.Web.Hosting.Transformers.ApplicationHost.SiteExtensionDefinition.Transform
|
||||
// (See Microsoft.Web.Hosting, Version=7.1.0.0) replaces variables for you in Azure.
|
||||
var transformFile = File.ReadAllText("applicationHost.xdt");
|
||||
transformFile = transformFile.Replace("%XDT_EXTENSIONPATH%", AppDomain.CurrentDomain.BaseDirectory);
|
||||
var transform = new XmlTransformation(transformFile, isTransformAFile: false, logger: null);
|
||||
var doc = new XmlDocument();
|
||||
doc.Load(docName);
|
||||
Assert.True(transform.Apply(doc));
|
||||
return doc;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,3 @@
|
|||
<?xml version="1.0"?>
|
||||
<configuration>
|
||||
</configuration>
|
||||
|
|
@ -0,0 +1,11 @@
|
|||
<?xml version="1.0"?>
|
||||
<configuration>
|
||||
<system.webServer>
|
||||
<runtime>
|
||||
<environmentVariables>
|
||||
<add name="DOTNET_ADDITIONAL_DEPS" value="" />
|
||||
<add name="ASPNETCORE_HOSTINGSTARTUPASSEMBLIES" value="" />
|
||||
</environmentVariables>
|
||||
</runtime>
|
||||
</system.webServer>
|
||||
</configuration>
|
||||
|
|
@ -0,0 +1,11 @@
|
|||
<?xml version="1.0"?>
|
||||
<configuration>
|
||||
<system.webServer>
|
||||
<runtime>
|
||||
<environmentVariables>
|
||||
<add name="DOTNET_ADDITIONAL_DEPS" />
|
||||
<add name="ASPNETCORE_HOSTINGSTARTUPASSEMBLIES" />
|
||||
</environmentVariables>
|
||||
</runtime>
|
||||
</system.webServer>
|
||||
</configuration>
|
||||
|
|
@ -0,0 +1,11 @@
|
|||
<?xml version="1.0"?>
|
||||
<configuration>
|
||||
<system.webServer>
|
||||
<runtime>
|
||||
<environmentVariables>
|
||||
<add name="DOTNET_ADDITIONAL_DEPS" value="ExistingValue1" />
|
||||
<add name="ASPNETCORE_HOSTINGSTARTUPASSEMBLIES" value="ExistingValue2" />
|
||||
</environmentVariables>
|
||||
</runtime>
|
||||
</system.webServer>
|
||||
</configuration>
|
||||
|
|
@ -0,0 +1,109 @@
|
|||
// Copyright (c) .NET Foundation. All rights reserved.
|
||||
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
|
||||
|
||||
using System.IO;
|
||||
using System.Xml;
|
||||
using Microsoft.Web.XmlTransform;
|
||||
using Xunit;
|
||||
|
||||
namespace Microsoft.Web.Xdt.Extensions
|
||||
{
|
||||
public class InsertOrAppendAttributeTests
|
||||
{
|
||||
[Fact]
|
||||
public void InsertOrAppend_NoExesitingLine_InsertsLine()
|
||||
{
|
||||
var transform = new XmlTransformation(Path.GetFullPath("transform.xdt"));
|
||||
var doc = new XmlDocument();
|
||||
doc.Load("config_empty.xml");
|
||||
Assert.True(transform.Apply(doc));
|
||||
|
||||
Assert.Equal(2, doc.ChildNodes.Count);
|
||||
var configurationNode = doc["configuration"];
|
||||
|
||||
Assert.Equal(2, configurationNode.ChildNodes.Count);
|
||||
|
||||
var firstChild = configurationNode.FirstChild;
|
||||
Assert.Equal("add", firstChild.Name);
|
||||
Assert.Equal("KeyName1", firstChild.Attributes["name"].Value);
|
||||
Assert.Equal("InsertValue1", firstChild.Attributes["value"].Value);
|
||||
|
||||
var secondChild = firstChild.NextSibling;
|
||||
Assert.Equal("add", secondChild.Name);
|
||||
Assert.Equal("KeyName2", secondChild.Attributes["name"].Value);
|
||||
Assert.Equal("InsertValue2", secondChild.Attributes["value"].Value);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void InsertOrAppend_LineExistsButNoValueField_FieldInserted()
|
||||
{
|
||||
var transform = new XmlTransformation(Path.GetFullPath("transform.xdt"));
|
||||
var doc = new XmlDocument();
|
||||
doc.Load("config_existingline.xml");
|
||||
Assert.True(transform.Apply(doc));
|
||||
|
||||
Assert.Equal(2, doc.ChildNodes.Count);
|
||||
var configurationNode = doc["configuration"];
|
||||
|
||||
Assert.Equal(2, configurationNode.ChildNodes.Count);
|
||||
|
||||
var firstChild = configurationNode.FirstChild;
|
||||
Assert.Equal("add", firstChild.Name);
|
||||
Assert.Equal("KeyName1", firstChild.Attributes["name"].Value);
|
||||
Assert.Equal("InsertValue1", firstChild.Attributes["value"].Value);
|
||||
|
||||
var secondChild = firstChild.NextSibling;
|
||||
Assert.Equal("add", secondChild.Name);
|
||||
Assert.Equal("KeyName2", secondChild.Attributes["name"].Value);
|
||||
Assert.Equal("InsertValue2", secondChild.Attributes["value"].Value);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void InsertOrAppend_ExistingEmptyValue_InsertsValue()
|
||||
{
|
||||
var transform = new XmlTransformation(Path.GetFullPath("transform.xdt"));
|
||||
var doc = new XmlDocument();
|
||||
doc.Load("config_existingemptyvalue.xml");
|
||||
Assert.True(transform.Apply(doc));
|
||||
|
||||
Assert.Equal(2, doc.ChildNodes.Count);
|
||||
var configurationNode = doc["configuration"];
|
||||
|
||||
Assert.Equal(2, configurationNode.ChildNodes.Count);
|
||||
|
||||
var firstChild = configurationNode.FirstChild;
|
||||
Assert.Equal("add", firstChild.Name);
|
||||
Assert.Equal("KeyName1", firstChild.Attributes["name"].Value);
|
||||
Assert.Equal("InsertValue1", firstChild.Attributes["value"].Value);
|
||||
|
||||
var secondChild = firstChild.NextSibling;
|
||||
Assert.Equal("add", secondChild.Name);
|
||||
Assert.Equal("KeyName2", secondChild.Attributes["name"].Value);
|
||||
Assert.Equal("InsertValue2", secondChild.Attributes["value"].Value);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void InsertOrAppend_ExistingValue_AppendsValue()
|
||||
{
|
||||
var transform = new XmlTransformation(Path.GetFullPath("transform.xdt"));
|
||||
var doc = new XmlDocument();
|
||||
doc.Load("config_existingvalue.xml");
|
||||
Assert.True(transform.Apply(doc));
|
||||
|
||||
Assert.Equal(2, doc.ChildNodes.Count);
|
||||
var configurationNode = doc["configuration"];
|
||||
|
||||
Assert.Equal(2, configurationNode.ChildNodes.Count);
|
||||
|
||||
var firstChild = configurationNode.FirstChild;
|
||||
Assert.Equal("add", firstChild.Name);
|
||||
Assert.Equal("KeyName1", firstChild.Attributes["name"].Value);
|
||||
Assert.Equal("ExistingValue1;InsertValue1", firstChild.Attributes["value"].Value);
|
||||
|
||||
var secondChild = firstChild.NextSibling;
|
||||
Assert.Equal("add", secondChild.Name);
|
||||
Assert.Equal("KeyName2", secondChild.Attributes["name"].Value);
|
||||
Assert.Equal("ExistingValue2;InsertValue2", secondChild.Attributes["value"].Value);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,33 @@
|
|||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net461</TargetFramework>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<None Remove="transform.xdt" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<Content Include="config_existingemptyvalue.xml">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
<Content Include="config_existingvalue.xml">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
<Content Include="config_existingline.xml">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
<Content Include="config_empty.xml">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
<Content Include="transform.xdt">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</Content>
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\..\src\Microsoft.Web.Xdt.Extensions\Microsoft.Web.Xdt.Extensions.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
|
|
@ -0,0 +1,3 @@
|
|||
<?xml version="1.0"?>
|
||||
<configuration>
|
||||
</configuration>
|
||||
|
|
@ -0,0 +1,5 @@
|
|||
<?xml version="1.0"?>
|
||||
<configuration>
|
||||
<add name="KeyName1" value="" />
|
||||
<add name="KeyName2" value="" />
|
||||
</configuration>
|
||||
|
|
@ -0,0 +1,5 @@
|
|||
<?xml version="1.0"?>
|
||||
<configuration>
|
||||
<add name="KeyName1" />
|
||||
<add name="KeyName2" />
|
||||
</configuration>
|
||||
|
|
@ -0,0 +1,5 @@
|
|||
<?xml version="1.0"?>
|
||||
<configuration>
|
||||
<add name="KeyName1" value="ExistingValue1" />
|
||||
<add name="KeyName2" value="ExistingValue2" />
|
||||
</configuration>
|
||||
|
|
@ -0,0 +1,9 @@
|
|||
<?xml version="1.0"?>
|
||||
<configuration xmlns:xdt="http://schemas.microsoft.com/XML-Document-Transform">
|
||||
|
||||
<xdt:Import path="Microsoft.Web.Xdt.Extensions.dll"
|
||||
namespace="Microsoft.Web.Xdt.Extensions" />
|
||||
|
||||
<add name="KeyName1" value="InsertValue1" xdt:Locator="Match(name)" xdt:Transform="InsertOrAppendAttribute(Attribute='value')" />
|
||||
<add name="KeyName2" value="InsertValue2" xdt:Locator="Match(name)" xdt:Transform="InsertOrAppendAttribute(Attribute='value')" />
|
||||
</configuration>
|
||||
Loading…
Reference in New Issue