mirror of
https://github.com/bitwarden/server.git
synced 2025-01-09 19:57:37 +01:00
84b18e9de7
* Add Overridable Configuration * Add Remarks
88 lines
3.2 KiB
C#
88 lines
3.2 KiB
C#
using Bit.Identity.Models.Request.Accounts;
|
|
using Bit.IntegrationTestCommon.Factories;
|
|
using Microsoft.AspNetCore.Authentication.JwtBearer;
|
|
using Microsoft.AspNetCore.TestHost;
|
|
using Microsoft.Data.Sqlite;
|
|
|
|
#nullable enable
|
|
|
|
namespace Bit.Api.IntegrationTest.Factories;
|
|
|
|
public class ApiApplicationFactory : WebApplicationFactoryBase<Startup>
|
|
{
|
|
private readonly IdentityApplicationFactory _identityApplicationFactory;
|
|
private const string _connectionString = "DataSource=:memory:";
|
|
|
|
public ApiApplicationFactory()
|
|
{
|
|
SqliteConnection = new SqliteConnection(_connectionString);
|
|
SqliteConnection.Open();
|
|
|
|
_identityApplicationFactory = new IdentityApplicationFactory();
|
|
_identityApplicationFactory.SqliteConnection = SqliteConnection;
|
|
}
|
|
|
|
protected override void ConfigureWebHost(IWebHostBuilder builder)
|
|
{
|
|
base.ConfigureWebHost(builder);
|
|
|
|
builder.ConfigureTestServices(services =>
|
|
{
|
|
// Remove scheduled background jobs to prevent errors in parallel test execution
|
|
var jobService = services.First(sd => sd.ServiceType == typeof(IHostedService) && sd.ImplementationType == typeof(Jobs.JobsHostedService));
|
|
services.Remove(jobService);
|
|
|
|
services.Configure<JwtBearerOptions>(JwtBearerDefaults.AuthenticationScheme, options =>
|
|
{
|
|
options.BackchannelHttpHandler = _identityApplicationFactory.Server.CreateHandler();
|
|
});
|
|
});
|
|
}
|
|
|
|
/// <summary>
|
|
/// Helper for registering and logging in to a new account
|
|
/// </summary>
|
|
public async Task<(string Token, string RefreshToken)> LoginWithNewAccount(string email = "integration-test@bitwarden.com", string masterPasswordHash = "master_password_hash")
|
|
{
|
|
await _identityApplicationFactory.RegisterAsync(new RegisterRequestModel
|
|
{
|
|
Email = email,
|
|
MasterPasswordHash = masterPasswordHash,
|
|
});
|
|
|
|
return await _identityApplicationFactory.TokenFromPasswordAsync(email, masterPasswordHash);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Helper for logging in to an account
|
|
/// </summary>
|
|
public async Task<(string Token, string RefreshToken)> LoginAsync(string email = "integration-test@bitwarden.com", string masterPasswordHash = "master_password_hash")
|
|
{
|
|
return await _identityApplicationFactory.TokenFromPasswordAsync(email, masterPasswordHash);
|
|
}
|
|
|
|
protected override void Dispose(bool disposing)
|
|
{
|
|
base.Dispose(disposing);
|
|
SqliteConnection!.Dispose();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Helper for logging in via client secret.
|
|
/// Currently used for Secrets Manager service accounts
|
|
/// </summary>
|
|
public async Task<string> LoginWithClientSecretAsync(Guid clientId, string clientSecret)
|
|
{
|
|
return await _identityApplicationFactory.TokenFromAccessTokenAsync(clientId, clientSecret);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Helper for logging in with an Organization api key.
|
|
/// Currently used for the Public Api
|
|
/// </summary>
|
|
public async Task<string> LoginWithOrganizationApiKeyAsync(string clientId, string clientSecret)
|
|
{
|
|
return await _identityApplicationFactory.TokenFromOrganizationApiKeyAsync(clientId, clientSecret);
|
|
}
|
|
}
|