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.
 
 
 
 
 

163 lines
6.1 KiB

// ==========================================================================
// Squidex Headless CMS
// ==========================================================================
// Copyright (c) Squidex UG (haftungsbeschraenkt)
// All rights reserved. Licensed under the MIT license.
// ==========================================================================
using System.Linq;
using System.Threading.Tasks;
using FakeItEasy;
using Squidex.Domain.Apps.Core.Contents;
using Squidex.Domain.Apps.Entities.Contents.Queries.Steps;
using Squidex.Domain.Apps.Entities.TestHelpers;
using Squidex.Infrastructure;
using Xunit;
namespace Squidex.Domain.Apps.Entities.Contents.Queries
{
public class EnrichWithWorkflowsTests
{
private readonly IContentWorkflow contentWorkflow = A.Fake<IContentWorkflow>();
private readonly Context requestContext;
private readonly NamedId<DomainId> appId = NamedId.Of(DomainId.NewGuid(), "my-app");
private readonly NamedId<DomainId> schemaId = NamedId.Of(DomainId.NewGuid(), "my-schema");
private readonly RefToken user = new RefToken(RefTokenType.Subject, "me");
private readonly EnrichWithWorkflows sut;
public EnrichWithWorkflowsTests()
{
requestContext = new Context(Mocks.FrontendUser(), Mocks.App(appId));
sut = new EnrichWithWorkflows(contentWorkflow);
}
[Fact]
public async Task Should_enrich_content_with_next_statuses()
{
var content = new ContentEntity { SchemaId = schemaId };
var nexts = new[]
{
new StatusInfo(Status.Published, StatusColors.Published)
};
A.CallTo(() => contentWorkflow.GetNextAsync(content, content.Status, requestContext.User))
.Returns(nexts);
await sut.EnrichAsync(requestContext, new[] { content }, null!);
Assert.Equal(nexts, content.NextStatuses);
}
[Fact]
public async Task Should_enrich_content_with_next_statuses_if_draft_singleton()
{
var content = new ContentEntity { SchemaId = schemaId, IsSingleton = true, Status = Status.Draft };
await sut.EnrichAsync(requestContext, new[] { content }, null!);
Assert.Equal(Status.Published, content.NextStatuses?.Single().Status);
A.CallTo(() => contentWorkflow.GetNextAsync(content, A<Status>._, requestContext.User))
.MustNotHaveHappened();
}
[Fact]
public async Task Should_enrich_content_with_next_statuses_if_published_singleton()
{
var content = new ContentEntity { SchemaId = schemaId, IsSingleton = true, Status = Status.Published };
await sut.EnrichAsync(requestContext, new[] { content }, null!);
Assert.Empty(content.NextStatuses);
A.CallTo(() => contentWorkflow.GetNextAsync(content, A<Status>._, requestContext.User))
.MustNotHaveHappened();
}
[Fact]
public async Task Should_enrich_content_with_status_color()
{
var content = new ContentEntity { SchemaId = schemaId };
A.CallTo(() => contentWorkflow.GetInfoAsync(content, content.Status))
.Returns(new StatusInfo(Status.Published, StatusColors.Published));
await sut.EnrichAsync(requestContext, new[] { content }, null!);
Assert.Equal(StatusColors.Published, content.StatusColor);
}
[Fact]
public async Task Should_enrich_content_with_new_status_color()
{
var content = new ContentEntity { SchemaId = schemaId, NewStatus = Status.Archived };
A.CallTo(() => contentWorkflow.GetInfoAsync(content, content.NewStatus.Value))
.Returns(new StatusInfo(Status.Published, StatusColors.Archived));
await sut.EnrichAsync(requestContext, new[] { content }, null!);
Assert.Equal(StatusColors.Archived, content.NewStatusColor);
}
[Fact]
public async Task Should_enrich_content_with_scheduled_status_color()
{
var content = new ContentEntity { SchemaId = schemaId, ScheduleJob = ScheduleJob.Build(Status.Archived, user, default) };
A.CallTo(() => contentWorkflow.GetInfoAsync(content, content.ScheduleJob.Status))
.Returns(new StatusInfo(Status.Published, StatusColors.Archived));
await sut.EnrichAsync(requestContext, new[] { content }, null!);
Assert.Equal(StatusColors.Archived, content.ScheduledStatusColor);
}
[Fact]
public async Task Should_enrich_content_with_default_color_if_not_found()
{
var content = new ContentEntity { SchemaId = schemaId };
A.CallTo(() => contentWorkflow.GetInfoAsync(content, content.Status))
.Returns(Task.FromResult<StatusInfo>(null!));
var ctx = requestContext.Clone(b => b.WithResolveFlow(false));
await sut.EnrichAsync(ctx, new[] { content }, null!);
Assert.Equal(StatusColors.Draft, content.StatusColor);
}
[Fact]
public async Task Should_enrich_content_with_can_update()
{
var content = new ContentEntity { SchemaId = schemaId };
A.CallTo(() => contentWorkflow.CanUpdateAsync(content, content.Status, requestContext.User))
.Returns(true);
var ctx = requestContext.Clone(b => b.WithResolveFlow(false));
await sut.EnrichAsync(ctx, new[] { content }, null!);
Assert.True(content.CanUpdate);
}
[Fact]
public async Task Should_not_enrich_content_with_can_update_if_disabled_in_context()
{
var content = new ContentEntity { SchemaId = schemaId };
var ctx = new Context(Mocks.ApiUser(), Mocks.App(appId)).Clone(b => b.WithResolveFlow(false));
await sut.EnrichAsync(ctx, new[] { content }, null!);
Assert.False(content.CanUpdate);
A.CallTo(() => contentWorkflow.CanUpdateAsync(content, A<Status>._, requestContext.User))
.MustNotHaveHappened();
}
}
}