mirror of
https://github.com/bitwarden/server.git
synced 2025-01-08 19:47:44 +01:00
4377c7a897
* Rewrite Icon fetching * Move validation to IconUri, Uri, or UriBuilder * `dotnet format` 🤖 * PR suggestions * Add not null compiler hint * Add twitter to test case * Move Uri manipulation to UriService * Implement MockedHttpClient Presents better, fluent handling of message matching and response building. * Add redirect handling tests * Add testing to models * More aggressively dispose content in icon link * Format 🤖 * Update icon lockfile * Convert to cloned stream for HttpResponseBuilder Content was being disposed when HttResponseMessage was being disposed. This avoids losing our reference to our content and allows multiple usages of the same `MockedHttpMessageResponse` * Move services to extension Extension is shared by testing and allows access to services from our service tests * Remove unused `using` * Prefer awaiting asyncs for better exception handling * `dotnet format` 🤖 * Await async * Update tests to use test TLD and ip ranges * Remove unused interfaces * Make assignments static when possible * Prefer invariant comparer to downcasing * Prefer injecting interface services to implementations * Prefer comparer set in HashSet initialization * Allow SVG icons * Filter out icons with unknown formats * Seek to beginning of MemoryStream after writing it * More appropriate to not return icon if it's invalid * Add svg icon test
85 lines
2.3 KiB
C#
85 lines
2.3 KiB
C#
using System.Net;
|
|
|
|
namespace Bit.Test.Common.MockedHttpClient;
|
|
|
|
public class HttpResponseBuilder : IDisposable
|
|
{
|
|
private bool _disposedValue;
|
|
|
|
public HttpStatusCode StatusCode { get; set; }
|
|
public IEnumerable<KeyValuePair<string, string>> Headers { get; set; } = new List<KeyValuePair<string, string>>();
|
|
public IEnumerable<string> HeadersToRemove { get; set; } = new List<string>();
|
|
public HttpContent Content { get; set; }
|
|
|
|
public async Task<HttpResponseMessage> ToHttpResponseAsync()
|
|
{
|
|
var copiedContentStream = new MemoryStream();
|
|
await Content.CopyToAsync(copiedContentStream); // This is important, otherwise the content stream will be disposed when the response is disposed.
|
|
copiedContentStream.Seek(0, SeekOrigin.Begin);
|
|
var message = new HttpResponseMessage(StatusCode)
|
|
{
|
|
Content = new StreamContent(copiedContentStream),
|
|
};
|
|
|
|
foreach (var header in Headers)
|
|
{
|
|
message.Headers.TryAddWithoutValidation(header.Key, header.Value);
|
|
}
|
|
|
|
return message;
|
|
}
|
|
|
|
public HttpResponseBuilder WithStatusCode(HttpStatusCode statusCode)
|
|
{
|
|
return new()
|
|
{
|
|
StatusCode = statusCode,
|
|
Headers = Headers,
|
|
HeadersToRemove = HeadersToRemove,
|
|
Content = Content,
|
|
};
|
|
}
|
|
|
|
public HttpResponseBuilder WithHeader(string name, string value)
|
|
{
|
|
return new()
|
|
{
|
|
StatusCode = StatusCode,
|
|
Headers = Headers.Append(new KeyValuePair<string, string>(name, value)),
|
|
HeadersToRemove = HeadersToRemove,
|
|
Content = Content,
|
|
};
|
|
}
|
|
|
|
public HttpResponseBuilder WithContent(HttpContent content)
|
|
{
|
|
return new()
|
|
{
|
|
StatusCode = StatusCode,
|
|
Headers = Headers,
|
|
HeadersToRemove = HeadersToRemove,
|
|
Content = content,
|
|
};
|
|
}
|
|
|
|
protected virtual void Dispose(bool disposing)
|
|
{
|
|
if (!_disposedValue)
|
|
{
|
|
if (disposing)
|
|
{
|
|
Content?.Dispose();
|
|
}
|
|
|
|
_disposedValue = true;
|
|
}
|
|
}
|
|
|
|
public void Dispose()
|
|
{
|
|
// Do not change this code. Put cleanup code in 'Dispose(bool disposing)' method
|
|
Dispose(disposing: true);
|
|
GC.SuppressFinalize(this);
|
|
}
|
|
}
|