Skip to content

Commit

Permalink
Update Handlebars.Net.Helpers.XPath to fix issue with 'xml version' (#…
Browse files Browse the repository at this point in the history
…619)

Update Handlebars.Net.Helpers.XPath to fix issue with 'xml version'
  • Loading branch information
StefH authored Jul 10, 2021
1 parent 5e7cb44 commit 4b435fa
Show file tree
Hide file tree
Showing 2 changed files with 64 additions and 7 deletions.
14 changes: 7 additions & 7 deletions src/WireMock.Net/WireMock.Net.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -121,13 +121,13 @@
</ItemGroup>

<ItemGroup>
<PackageReference Include="Handlebars.Net.Helpers" Version="2.2.0" />
<PackageReference Include="Handlebars.Net.Helpers.DynamicLinq" Version="2.2.0" />
<PackageReference Include="Handlebars.Net.Helpers.Humanizer" Version="2.2.0" />
<PackageReference Include="Handlebars.Net.Helpers.Json" Version="2.2.0" />
<PackageReference Include="Handlebars.Net.Helpers.XPath" Version="2.2.0" />
<PackageReference Include="Handlebars.Net.Helpers.Xeger" Version="2.2.0" />
<PackageReference Include="Handlebars.Net.Helpers.Random" Version="2.2.0" />
<PackageReference Include="Handlebars.Net.Helpers" Version="2.2.1" />
<PackageReference Include="Handlebars.Net.Helpers.DynamicLinq" Version="2.2.1" />
<PackageReference Include="Handlebars.Net.Helpers.Humanizer" Version="2.2.1" />
<PackageReference Include="Handlebars.Net.Helpers.Json" Version="2.2.1" />
<PackageReference Include="Handlebars.Net.Helpers.XPath" Version="2.2.1" />
<PackageReference Include="Handlebars.Net.Helpers.Xeger" Version="2.2.1" />
<PackageReference Include="Handlebars.Net.Helpers.Random" Version="2.2.1" />
</ItemGroup>

<ItemGroup>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
using Xunit;
using Moq;
using WireMock.Handlers;
using FluentAssertions;
#if !NETSTANDARD1_3
using Wmhelp.XPath2;
#endif
Expand Down Expand Up @@ -119,6 +120,62 @@ public async Task Response_ProvideResponse_Handlebars_XPath_SelectNodes_Request_
Check.That(nodes.Count + 1).IsEqualTo(3);
}

[Fact]
public async Task Response_ProvideResponse_Handlebars_XPath_SelectSingleNode_Request_SoapXML_BodyAsString()
{
// Assign
string soap = @"
<soapenv:Envelope xmlns:soapenv=""http://schemas.xmlsoap.org/soap/envelope/"" xmlns:ns=""http://www.Test.nl/XMLHeader/10"" xmlns:req=""http://www.Test.nl/Betalen/COU/Services/RdplDbTknLystByOvkLyst/8/Req"">
<soapenv:Header>
<ns:TestHeader>
<ns:HeaderVersion>10</ns:HeaderVersion>
<ns:MessageId>MsgId10</ns:MessageId>
<ns:ServiceRequestorDomain>Betalen</ns:ServiceRequestorDomain>
<ns:ServiceRequestorId>CRM</ns:ServiceRequestorId>
<ns:ServiceProviderDomain>COU</ns:ServiceProviderDomain>
<ns:ServiceId>RdplDbTknLystByOvkLyst</ns:ServiceId>
<ns:ServiceVersion>8</ns:ServiceVersion>
<ns:FaultIndication>N</ns:FaultIndication>
<ns:MessageTimestamp>?</ns:MessageTimestamp>
</ns:TestHeader>
</soapenv:Header>
<soapenv:Body>
<req:RdplDbTknLystByOvkLyst_REQ>
<req:AanleveraarCode>CRM</req:AanleveraarCode>
<!--Optional:-->
<req:AanleveraarDetail>CRMi</req:AanleveraarDetail>
<req:BerichtId>BerId</req:BerichtId>
<req:BerichtType>RdplDbTknLystByOvkLyst</req:BerichtType>
<!--Optional:-->
<req:OpgenomenBedragenGewenstIndicatie>N</req:OpgenomenBedragenGewenstIndicatie>
<req:TokenIdLijst>
<!--1 to 10 repetitions:-->
<req:TokenId>0000083256</req:TokenId>
<req:TokenId>0000083259</req:TokenId>
</req:TokenIdLijst>
</req:RdplDbTknLystByOvkLyst_REQ>
</soapenv:Body>
</soapenv:Envelope>";
var body = new BodyData
{
BodyAsString = soap,
DetectedBodyType = BodyType.String
};

var request = new RequestMessage(new UrlDetails("http://localhost:1234"), "POST", ClientIp, body);

var responseBuilder = Response.Create()
.WithHeader("Content-Type", "application/xml")
.WithBody("<response>{{XPath.SelectSingleNode request.body \"//*[local-name()='TokenIdLijst']\"}}</response>")
.WithTransformer();

// Act
var response = await responseBuilder.ProvideResponseAsync(request, _settings);

// Assert
response.Message.BodyData.BodyAsString.Should().Contain("TokenIdLijst").And.Contain("0000083256").And.Contain("0000083259");
}

[Fact]
public async Task Response_ProvideResponse_Handlebars_XPath_Evaluate_Request_BodyAsString()
{
Expand Down

0 comments on commit 4b435fa

Please sign in to comment.