-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
BufferedRequestTests.cs
209 lines (173 loc) · 7.05 KB
/
BufferedRequestTests.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
using System;
using System.Collections.Generic;
using Funq;
using NUnit.Framework;
using ServiceStack.Text;
using System.Runtime.Serialization;
using System.Threading;
using System.Threading.Tasks;
using ServiceStack.Auth;
using ServiceStack.Configuration;
using ServiceStack.Web;
namespace ServiceStack.WebHost.Endpoints.Tests
{
[TestFixture]
public class BufferedRequestTests
{
private BufferedRequestAppHost appHost;
[OneTimeSetUp]
public void TestFixtureSetUp()
{
appHost = new BufferedRequestAppHost();
appHost.Init();
appHost.Start(Config.AbsoluteBaseUri);
}
[OneTimeTearDown]
public void TestFixtureTearDown()
{
appHost.Dispose();
}
[Test]
public void BufferedRequest_allows_rereading_of_Request_InputStream()
{
appHost.LastRequestBody = null;
appHost.UseBufferedStream = true;
var client = new JsonServiceClient(Config.ServiceStackBaseUri);
var request = new MyRequest { Data = "RequestData" };
var response = client.Post(request);
Assert.That(response.Data, Is.EqualTo(request.Data));
Assert.That(appHost.LastRequestBody, Is.EqualTo(request.ToJson()));
}
[Test]
public void Cannot_reread_Request_InputStream_without_buffering()
{
appHost.LastRequestBody = null;
appHost.UseBufferedStream = false;
var client = new JsonServiceClient(Config.ServiceStackBaseUri);
var request = new MyRequest { Data = "RequestData" };
try
{
var response = client.Post(request);
Assert.That(appHost.LastRequestBody, Is.EqualTo(request.ToJson()));
Assert.That(response.Data, Is.Null);
}
catch (WebServiceException e)
{
//.NET 5
Assert.That(e.Message, Does.StartWith("Could not deserialize 'application/json' request"));
}
}
[Test]
public void Cannot_see_RequestBody_in_RequestLogger_without_buffering()
{
appHost.LastRequestBody = null;
appHost.UseBufferedStream = false;
var client = new JsonServiceClient(Config.ServiceStackBaseUri);
var request = new MyRequest { Data = "RequestData" };
try
{
var response = client.Post(request);
Assert.That(appHost.LastRequestBody, Is.EqualTo(request.ToJson()));
Assert.That(response.Data, Is.Null);
var requestLogger = appHost.TryResolve<IRequestLogger>();
var lastEntry = requestLogger.GetLatestLogs(1);
Assert.That(lastEntry[0].RequestBody, Is.Null);
}
catch (WebServiceException e)
{
//.NET 5
Assert.That(e.Message, Does.StartWith("Could not deserialize 'application/json' request"));
}
}
}
[TestFixture]
public class BufferedRequestLoggerTests
{
private BufferedRequestAppHost appHost;
MyRequest request = new MyRequest { Data = "RequestData" };
[OneTimeSetUp]
public void TestFixtureSetUp()
{
appHost = new BufferedRequestAppHost { EnableRequestBodyTracking = true };
appHost.Init();
appHost.Start(Config.AbsoluteBaseUri);
}
[OneTimeTearDown]
public void TestFixtureTearDown()
{
appHost.Dispose();
}
[Test]
public void Can_see_RequestBody_in_RequestLogger_when_EnableRequestBodyTracking()
{
var logBody = Run(new JsonServiceClient(Config.ServiceStackBaseUri));
Assert.That(appHost.LastRequestBody, Is.EqualTo(request.ToJson()));
Assert.That(logBody, Is.EqualTo(request.ToJson()));
}
#if !NETCORE
[Test]
public void Can_see_RequestBody_in_RequestLogger_when_EnableRequestBodyTracking_Soap12()
{
const string soap12start = @"<s:Envelope xmlns:s=""http://www.w3.org/2003/05/soap-envelope"" xmlns:a=""http://www.w3.org/2005/08/addressing""><s:Header><a:Action s:mustUnderstand=""1"">MyRequest</a:Action><a:MessageID>urn:uuid:";
const string soap12end = "<Data>RequestData</Data></MyRequest></s:Body></s:Envelope>";
var logBody = Run(new Soap12ServiceClient(Config.ServiceStackBaseUri));
Assert.That(appHost.LastRequestBody, Does.StartWith(soap12start));
Assert.That(appHost.LastRequestBody, Does.EndWith(soap12end));
Assert.That(logBody, Does.StartWith(soap12start));
Assert.That(logBody, Does.EndWith(soap12end));
}
[Test]
public void Can_see_RequestBody_in_RequestLogger_when_EnableRequestBodyTracking_Soap11()
{
const string soap11 = @"<s:Envelope xmlns:s=""http://schemas.xmlsoap.org/soap/envelope/""><s:Body><MyRequest xmlns=""http://schemas.servicestack.net/types"" xmlns:i=""http://www.w3.org/2001/XMLSchema-instance""><Data>RequestData</Data></MyRequest></s:Body></s:Envelope>";
var logBody = Run(new Soap11ServiceClient(Config.ServiceStackBaseUri));
Assert.That(appHost.LastRequestBody, Is.EqualTo(soap11));
Assert.That(logBody, Is.EqualTo(soap11));
}
#endif
string Run(IServiceClient client)
{
var requestLogger = appHost.TryResolve<IRequestLogger>();
appHost.LastRequestBody = null;
appHost.UseBufferedStream = false;
var response = client.Send(request);
//Debug.WriteLine(appHost.LastRequestBody);
Assert.That(response.Data, Is.EqualTo(request.Data));
var lastEntry = requestLogger.GetLatestLogs(int.MaxValue);
return lastEntry[lastEntry.Count - 1].RequestBody;
}
}
public class BufferedRequestAppHost : AppHostHttpListenerBase
{
public BufferedRequestAppHost() : base(nameof(BufferedRequestTests), typeof(MyService).Assembly) { }
public string LastRequestBody { get; set; }
public bool UseBufferedStream { get; set; }
public bool EnableRequestBodyTracking { get; set; }
public override void Configure(Container container)
{
#if !NETCORE
Plugins.Add(new SoapFormat());
#endif
PreRequestFilters.Add((httpReq, httpRes) => {
if (UseBufferedStream)
httpReq.UseBufferedStream = UseBufferedStream;
LastRequestBody = null;
LastRequestBody = httpReq.GetRawBody();
});
Plugins.Add(new RequestLogsFeature { EnableRequestBodyTracking = EnableRequestBodyTracking });
}
}
[DataContract]
public class MyRequest : IReturn<MyRequest>
{
[DataMember]
public string Data { get; set; }
}
public class MyService : IService
{
public object Any(MyRequest request)
{
return request;
}
}
}