mirror of
https://github.com/bitwarden/server.git
synced 2024-11-24 12:35:25 +01:00
daeaa42851
* Bump to .NET 6 * Update Docker images * Update docs * Update workflow for linter * Add all common versions to props file * Update tools manifest * Update csproj files * Update packages.lock.json files * Switch to setup-dotnet * Remove msbuild * Fix deps breaking changes * Manually install msbuild * Use msbuild for build * Fix verbosity switch * Remove unused exceptions * Address linter feedback * Make Obsolete warnings suggestions for now. * Force Evaluate * Format on tests * Run formatting again. * Use windows 2022 * force evaluate * Fix restore * Fix linter * Skip test * Update Directory.Build.props Co-authored-by: Matt Gibson <mgibson@bitwarden.com> * Address PR feedback * Add IntegationTest for Rate limiter * Fix test * Reenable test * Reorder test * Skip test again * Add tracking link * Update .github/workflows/build.yml Co-authored-by: Micaiah Martin <77340197+mimartin12@users.noreply.github.com> Co-authored-by: Matt Gibson <mgibson@bitwarden.com> Co-authored-by: Micaiah Martin <77340197+mimartin12@users.noreply.github.com>
74 lines
2.8 KiB
C#
74 lines
2.8 KiB
C#
using System;
|
|
using System.IO;
|
|
using System.Linq;
|
|
using System.Net;
|
|
using System.Net.Http;
|
|
using System.Threading.Tasks;
|
|
using Bit.Core.Utilities;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.AspNetCore.TestHost;
|
|
using Microsoft.Extensions.Primitives;
|
|
|
|
namespace Bit.IntegrationTestCommon.Factories
|
|
{
|
|
public static class WebApplicationFactoryExtensions
|
|
{
|
|
private static async Task<HttpContext> SendAsync(this TestServer server,
|
|
HttpMethod method,
|
|
string requestUri,
|
|
HttpContent content = null,
|
|
Action<HttpContext> extraConfiguration = null)
|
|
{
|
|
return await server.SendAsync(httpContext =>
|
|
{
|
|
// Automatically set the whitelisted IP so normal tests do not run into rate limit issues
|
|
// to test rate limiter, use the extraConfiguration parameter to set Connection.RemoteIpAddress
|
|
// it runs after this so it will take precedence.
|
|
httpContext.Connection.RemoteIpAddress = IPAddress.Parse(FactoryConstants.WhitelistedIp);
|
|
|
|
httpContext.Request.Path = new PathString(requestUri);
|
|
httpContext.Request.Method = method.Method;
|
|
|
|
if (content != null)
|
|
{
|
|
foreach (var header in content.Headers)
|
|
{
|
|
httpContext.Request.Headers.Add(header.Key, new StringValues(header.Value.ToArray()));
|
|
}
|
|
|
|
httpContext.Request.Body = content.ReadAsStream();
|
|
}
|
|
|
|
extraConfiguration?.Invoke(httpContext);
|
|
});
|
|
}
|
|
public static Task<HttpContext> PostAsync(this TestServer server,
|
|
string requestUri,
|
|
HttpContent content,
|
|
Action<HttpContext> extraConfiguration = null)
|
|
=> SendAsync(server, HttpMethod.Post, requestUri, content, extraConfiguration);
|
|
public static Task<HttpContext> GetAsync(this TestServer server,
|
|
string requestUri,
|
|
Action<HttpContext> extraConfiguration = null)
|
|
=> SendAsync(server, HttpMethod.Get, requestUri, content: null, extraConfiguration);
|
|
|
|
public static HttpContext SetAuthEmail(this HttpContext context, string username)
|
|
{
|
|
context.Request.Headers.Add("Auth-Email", CoreHelpers.Base64UrlEncodeString(username));
|
|
return context;
|
|
}
|
|
|
|
public static HttpContext SetIp(this HttpContext context, string ip)
|
|
{
|
|
context.Connection.RemoteIpAddress = IPAddress.Parse(ip);
|
|
return context;
|
|
}
|
|
|
|
public static async Task<string> ReadBodyAsStringAsync(this HttpContext context)
|
|
{
|
|
using var sr = new StreamReader(context.Response.Body);
|
|
return await sr.ReadToEndAsync();
|
|
}
|
|
}
|
|
}
|