Headless CMS and Content Managment Hub
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

114 lines
4.2 KiB

// ==========================================================================
// Squidex Headless CMS
// ==========================================================================
// Copyright (c) Squidex UG (haftungsbeschraenkt)
// All rights reserved. Licensed under the MIT license.
// ==========================================================================
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using FakeItEasy;
using Squidex.Domain.Apps.Core.Contents;
using Squidex.Domain.Apps.Core.Schemas;
using Squidex.Domain.Apps.Core.TestHelpers;
using Squidex.Domain.Apps.Entities.Schemas;
using Squidex.Domain.Apps.Entities.TestHelpers;
using Squidex.Infrastructure;
using Xunit;
namespace Squidex.Domain.Apps.Entities.Contents
{
public class DefaultWorkflowsValidatorTests : IClassFixture<TranslationsFixture>
{
private readonly IAppProvider appProvider = A.Fake<IAppProvider>();
private readonly NamedId<DomainId> appId = NamedId.Of(DomainId.NewGuid(), "my-app");
private readonly NamedId<DomainId> schemaId = NamedId.Of(DomainId.NewGuid(), "my-schema");
private readonly DefaultWorkflowsValidator sut;
public DefaultWorkflowsValidatorTests()
{
var schema = Mocks.Schema(appId, schemaId, new Schema(schemaId.Name));
A.CallTo(() => appProvider.GetSchemaAsync(appId.Id, A<DomainId>._, false, false))
.Returns(Task.FromResult<ISchemaEntity?>(null));
A.CallTo(() => appProvider.GetSchemaAsync(appId.Id, schemaId.Id, false, false))
.Returns(schema);
sut = new DefaultWorkflowsValidator(appProvider);
}
[Fact]
public async Task Should_generate_error_if_multiple_workflows_cover_all_schemas()
{
var workflows = Workflows.Empty
.Add(DomainId.NewGuid(), "workflow1")
.Add(DomainId.NewGuid(), "workflow2");
var errors = await sut.ValidateAsync(appId.Id, workflows);
Assert.Equal(new[] { "Multiple workflows cover all schemas." }, errors.ToArray());
}
[Fact]
public async Task Should_generate_error_if_multiple_workflows_cover_specific_schema()
{
var id1 = DomainId.NewGuid();
var id2 = DomainId.NewGuid();
var workflows = Workflows.Empty
.Add(id1, "workflow1")
.Add(id2, "workflow2")
.Update(id1, new Workflow(default, Workflow.EmptySteps, new List<DomainId> { schemaId.Id }))
.Update(id2, new Workflow(default, Workflow.EmptySteps, new List<DomainId> { schemaId.Id }));
var errors = await sut.ValidateAsync(appId.Id, workflows);
Assert.Equal(new[] { "The schema 'my-schema' is covered by multiple workflows." }, errors.ToArray());
}
[Fact]
public async Task Should_not_generate_error_if_schema_deleted()
{
var id1 = DomainId.NewGuid();
var id2 = DomainId.NewGuid();
var oldSchemaId = DomainId.NewGuid();
var workflows = Workflows.Empty
.Add(id1, "workflow1")
.Add(id2, "workflow2")
.Update(id1, new Workflow(default, Workflow.EmptySteps, new List<DomainId> { oldSchemaId }))
.Update(id2, new Workflow(default, Workflow.EmptySteps, new List<DomainId> { oldSchemaId }));
var errors = await sut.ValidateAsync(appId.Id, workflows);
Assert.Empty(errors);
}
[Fact]
public async Task Should_not_generate_errors_for_no_overlaps()
{
var id1 = DomainId.NewGuid();
var id2 = DomainId.NewGuid();
var workflows = Workflows.Empty
.Add(id1, "workflow1")
.Add(id2, "workflow2")
.Update(id1, new Workflow(default, Workflow.EmptySteps, new List<DomainId> { schemaId.Id }));
var errors = await sut.ValidateAsync(appId.Id, workflows);
Assert.Empty(errors);
}
[Fact]
public async Task Should_not_generate_errors_for_empty_workflows()
{
var errors = await sut.ValidateAsync(appId.Id, Workflows.Empty);
Assert.Empty(errors);
}
}
}