mirror of
https://github.com/bitwarden/server.git
synced 2025-04-04 12:40:22 -05:00
cleanup, add tests
This commit is contained in:
parent
2f381ec006
commit
7ddc9fd933
@ -1,7 +1,6 @@
|
||||
using Bit.Core.Entities;
|
||||
using Bit.Core.Enums;
|
||||
using Bit.Core.Exceptions;
|
||||
using Bit.Core.Models.Commands;
|
||||
using Bit.Core.Models.Data;
|
||||
using Bit.Core.OrganizationFeatures.OrganizationUsers.Interfaces;
|
||||
using Bit.Core.Repositories;
|
||||
@ -27,7 +26,7 @@ public class InitPendingOrganizationCommand : IInitPendingOrganizationCommand
|
||||
_organizationRepository = organizationRepository;
|
||||
}
|
||||
|
||||
public async Task<CommandResult> InitPendingOrganizationAsync(Guid userId, Guid organizationId, Guid organizationUserId, string publicKey, string privateKey, string collectionName)
|
||||
public async Task InitPendingOrganizationAsync(Guid userId, Guid organizationId, Guid organizationUserId, string publicKey, string privateKey, string collectionName)
|
||||
{
|
||||
await _organizationService.ValidateSignUpPoliciesAsync(userId);
|
||||
|
||||
@ -73,7 +72,5 @@ public class InitPendingOrganizationCommand : IInitPendingOrganizationCommand
|
||||
};
|
||||
await _collectionRepository.CreateAsync(defaultCollection, null, defaultOwnerAccess);
|
||||
}
|
||||
|
||||
return new CommandResult();
|
||||
}
|
||||
}
|
||||
|
@ -1,10 +1,9 @@
|
||||
using Bit.Core.Models.Commands;
|
||||
namespace Bit.Core.OrganizationFeatures.OrganizationUsers.Interfaces;
|
||||
namespace Bit.Core.OrganizationFeatures.OrganizationUsers.Interfaces;
|
||||
|
||||
public interface IInitPendingOrganizationCommand
|
||||
{
|
||||
/// <summary>
|
||||
/// Accept an invitation to initialize and join an organization created via the Admin Portal
|
||||
/// </summary>
|
||||
Task<CommandResult> InitPendingOrganizationAsync(Guid userId, Guid organizationId, Guid organizationUserId, string publicKey, string privateKey, string collectionName);
|
||||
Task InitPendingOrganizationAsync(Guid userId, Guid organizationId, Guid organizationUserId, string publicKey, string privateKey, string collectionName);
|
||||
}
|
||||
|
@ -0,0 +1,131 @@
|
||||
using Bit.Core.AdminConsole.Entities;
|
||||
using Bit.Core.AdminConsole.OrganizationFeatures.OrganizationUsers;
|
||||
using Bit.Core.Entities;
|
||||
using Bit.Core.Exceptions;
|
||||
using Bit.Core.Models.Data;
|
||||
using Bit.Core.Repositories;
|
||||
using Bit.Core.Services;
|
||||
using Bit.Test.Common.AutoFixture;
|
||||
using Bit.Test.Common.AutoFixture.Attributes;
|
||||
using NSubstitute;
|
||||
using Xunit;
|
||||
|
||||
namespace Bit.Core.Test.AdminConsole.OrganizationFeatures.Organizations;
|
||||
|
||||
[SutProviderCustomize]
|
||||
public class InitPendingOrganizationCommandTests
|
||||
{
|
||||
[Theory, BitAutoData]
|
||||
public async Task Init_Organization_Success(Guid userId, Guid orgId, Guid orgUserId, string publicKey,
|
||||
string privateKey, SutProvider<InitPendingOrganizationCommand> sutProvider, Organization org)
|
||||
{
|
||||
org.PrivateKey = null;
|
||||
org.PublicKey = null;
|
||||
|
||||
var organizationRepository = sutProvider.GetDependency<IOrganizationRepository>();
|
||||
organizationRepository.GetByIdAsync(orgId).Returns(org);
|
||||
|
||||
var organizationServcie = sutProvider.GetDependency<IOrganizationService>();
|
||||
var collectionRepository = sutProvider.GetDependency<ICollectionRepository>();
|
||||
|
||||
await sutProvider.Sut.InitPendingOrganizationAsync(userId, orgId, orgUserId, publicKey, privateKey, "");
|
||||
|
||||
await organizationServcie.Received().ValidateSignUpPoliciesAsync(userId);
|
||||
await organizationRepository.Received().GetByIdAsync(orgId);
|
||||
await organizationServcie.Received().UpdateAsync(org);
|
||||
await collectionRepository.DidNotReceiveWithAnyArgs().CreateAsync(default);
|
||||
|
||||
}
|
||||
|
||||
[Theory, BitAutoData]
|
||||
public async Task Init_Organization_With_CollectionName_Success(Guid userId, Guid orgId, Guid orgUserId, string publicKey,
|
||||
string privateKey, SutProvider<InitPendingOrganizationCommand> sutProvider, Organization org, string collectionName)
|
||||
{
|
||||
org.PrivateKey = null;
|
||||
org.PublicKey = null;
|
||||
org.Id = orgId;
|
||||
|
||||
var organizationRepository = sutProvider.GetDependency<IOrganizationRepository>();
|
||||
organizationRepository.GetByIdAsync(orgId).Returns(org);
|
||||
|
||||
var organizationServcie = sutProvider.GetDependency<IOrganizationService>();
|
||||
var collectionRepository = sutProvider.GetDependency<ICollectionRepository>();
|
||||
|
||||
await sutProvider.Sut.InitPendingOrganizationAsync(userId, orgId, orgUserId, publicKey, privateKey, collectionName);
|
||||
|
||||
await organizationServcie.Received().ValidateSignUpPoliciesAsync(userId);
|
||||
await organizationRepository.Received().GetByIdAsync(orgId);
|
||||
await organizationServcie.Received().UpdateAsync(org);
|
||||
|
||||
await collectionRepository.Received().CreateAsync(
|
||||
Arg.Any<Collection>(),
|
||||
Arg.Is<List<CollectionAccessSelection>>(l => l == null),
|
||||
Arg.Is<List<CollectionAccessSelection>>(l => l.Any(i => i.Manage == true)));
|
||||
|
||||
}
|
||||
|
||||
[Theory, BitAutoData]
|
||||
public async Task Init_Organization_When_Organization_Is_Enabled(Guid userId, Guid orgId, Guid orgUserId, string publicKey,
|
||||
string privateKey, SutProvider<InitPendingOrganizationCommand> sutProvider, Organization org)
|
||||
|
||||
{
|
||||
org.Enabled = true;
|
||||
|
||||
var organizationRepository = sutProvider.GetDependency<IOrganizationRepository>();
|
||||
organizationRepository.GetByIdAsync(orgId).Returns(org);
|
||||
|
||||
var exception = await Assert.ThrowsAsync<BadRequestException>(() => sutProvider.Sut.InitPendingOrganizationAsync(userId, orgId, orgUserId, publicKey, privateKey, ""));
|
||||
|
||||
Assert.Equal("Organization is already enabled.", exception.Message);
|
||||
|
||||
}
|
||||
|
||||
[Theory, BitAutoData]
|
||||
public async Task Init_Organization_When_Organization_Is_Not_Pending(Guid userId, Guid orgId, Guid orgUserId, string publicKey,
|
||||
string privateKey, SutProvider<InitPendingOrganizationCommand> sutProvider, Organization org)
|
||||
|
||||
{
|
||||
org.Status = Enums.OrganizationStatusType.Created;
|
||||
|
||||
var organizationRepository = sutProvider.GetDependency<IOrganizationRepository>();
|
||||
organizationRepository.GetByIdAsync(orgId).Returns(org);
|
||||
|
||||
var exception = await Assert.ThrowsAsync<BadRequestException>(() => sutProvider.Sut.InitPendingOrganizationAsync(userId, orgId, orgUserId, publicKey, privateKey, ""));
|
||||
|
||||
Assert.Equal("Organization is not on a Pending status.", exception.Message);
|
||||
|
||||
}
|
||||
|
||||
[Theory, BitAutoData]
|
||||
public async Task Init_Organization_When_Organization_Has_Public_Key(Guid userId, Guid orgId, Guid orgUserId, string publicKey,
|
||||
string privateKey, SutProvider<InitPendingOrganizationCommand> sutProvider, Organization org)
|
||||
|
||||
{
|
||||
org.PublicKey = publicKey;
|
||||
|
||||
var organizationRepository = sutProvider.GetDependency<IOrganizationRepository>();
|
||||
organizationRepository.GetByIdAsync(orgId).Returns(org);
|
||||
|
||||
var exception = await Assert.ThrowsAsync<BadRequestException>(() => sutProvider.Sut.InitPendingOrganizationAsync(userId, orgId, orgUserId, publicKey, privateKey, ""));
|
||||
|
||||
Assert.Equal("Organization already has a Public Key.", exception.Message);
|
||||
|
||||
}
|
||||
|
||||
[Theory, BitAutoData]
|
||||
public async Task Init_Organization_When_Organization_Has_Private_Key(Guid userId, Guid orgId, Guid orgUserId, string publicKey,
|
||||
string privateKey, SutProvider<InitPendingOrganizationCommand> sutProvider, Organization org)
|
||||
|
||||
{
|
||||
org.PublicKey = null;
|
||||
org.PrivateKey = privateKey;
|
||||
|
||||
var organizationRepository = sutProvider.GetDependency<IOrganizationRepository>();
|
||||
organizationRepository.GetByIdAsync(orgId).Returns(org);
|
||||
|
||||
var exception = await Assert.ThrowsAsync<BadRequestException>(() => sutProvider.Sut.InitPendingOrganizationAsync(userId, orgId, orgUserId, publicKey, privateKey, ""));
|
||||
|
||||
Assert.Equal("Organization already has a Private Key.", exception.Message);
|
||||
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user