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.
 
 
 
 
 

194 lines
6.3 KiB

// ==========================================================================
// Squidex Headless CMS
// ==========================================================================
// Copyright (c) Squidex UG (haftungsbeschraenkt)
// All rights reserved. Licensed under the MIT license.
// ==========================================================================
using Squidex.ClientLibrary;
using Squidex.ClientLibrary.Management;
using TestSuite.Fixtures;
using TestSuite.Model;
using Xunit;
#pragma warning disable SA1300 // Element should begin with upper-case letter
#pragma warning disable SA1507 // Code should not contain multiple blank lines in a row
namespace TestSuite.ApiTests
{
public class ContentScriptingTests : IClassFixture<CreatedAppFixture>
{
private readonly string schemaName = $"schema-{Guid.NewGuid()}";
public CreatedAppFixture _ { get; }
public ContentScriptingTests(CreatedAppFixture fixture)
{
_ = fixture;
}
[Fact]
public async Task Should_create_content_with_scripting()
{
var scripts = new SchemaScriptsDto
{
Create = @$"
ctx.data.{TestEntityData.NumberField}.iv *= 2;
replace()"
};
// STEP 1: Create a schema.
await TestEntity.CreateSchemaAsync(_.Schemas, _.AppName, schemaName, scripts);
// STEP 2: Create content
var contents = _.ClientManager.CreateContentsClient<TestEntity, TestEntityData>(schemaName);
var content = await contents.CreateAsync(new TestEntityData { Number = 13 });
Assert.Equal(26, content.Data.Number);
}
[Fact]
public async Task Should_query_content_with_scripting()
{
var scripts = new SchemaScriptsDto
{
Query = @$"
ctx.data.{TestEntityData.NumberField}.iv *= 2;
replace()",
};
// STEP 1: Create a schema.
await TestEntity.CreateSchemaAsync(_.Schemas, _.AppName, schemaName, scripts);
// STEP 2: Create content
var contents = _.ClientManager.CreateContentsClient<TestEntity, TestEntityData>(schemaName);
var content = await contents.CreateAsync(new TestEntityData { Number = 13 }, ContentCreateOptions.AsPublish);
Assert.Equal(26, content.Data.Number);
}
[Fact]
public async Task Should_query_content_with_scripting_and_pre_query()
{
var scripts = new SchemaScriptsDto
{
QueryPre = @$"
ctx.test = 17",
Query = @$"
ctx.data.{TestEntityData.NumberField}.iv = ctx.test + 2;
replace()",
};
// STEP 1: Create a schema.
await TestEntity.CreateSchemaAsync(_.Schemas, _.AppName, schemaName, scripts);
// STEP 2: Create content
var contents = _.ClientManager.CreateContentsClient<TestEntity, TestEntityData>(schemaName);
var content = await contents.CreateAsync(new TestEntityData { Number = 99 }, ContentCreateOptions.AsPublish);
Assert.Equal(19, content.Data.Number);
}
[Fact]
public async Task Should_create_bulk_content_with_scripting()
{
// STEP 1: Create a schema.
var scripts = new SchemaScriptsDto
{
Create = @$"
ctx.data.{TestEntityData.NumberField}.iv = incrementCounter('${schemaName}');
replace()"
};
await TestEntity.CreateSchemaAsync(_.Schemas, _.AppName, schemaName, scripts);
// STEP 2: Create content with a value that triggers the schema.
var contents = _.ClientManager.CreateContentsClient<TestEntity, TestEntityData>(schemaName);
var results = await contents.BulkUpdateAsync(new BulkUpdate
{
DoNotScript = false,
DoNotValidate = false,
Jobs = new List<BulkUpdateJob>
{
new BulkUpdateJob
{
Type = BulkUpdateType.Upsert,
Data = new
{
number = new
{
iv = 99
}
}
}
},
Publish = true
});
Assert.Single(results);
Assert.Null(results[0].Error);
// STEP 2: Query content.
var content = await contents.GetAsync(results[0].ContentId);
Assert.True(content.Data.Number > 0);
}
[Fact]
public async Task Should_create_bulk_content_with_scripting_but_disabled()
{
// STEP 1: Create a schema.
var scripts = new SchemaScriptsDto
{
Create = @$"
ctx.data.{TestEntityData.NumberField}.iv = incrementCounter('${schemaName}');
replace()"
};
await TestEntity.CreateSchemaAsync(_.Schemas, _.AppName, schemaName, scripts);
// STEP 1: Create content with a value that triggers the schema.
var contents = _.ClientManager.CreateContentsClient<TestEntity, TestEntityData>(schemaName);
var results = await contents.BulkUpdateAsync(new BulkUpdate
{
DoNotScript = true,
DoNotValidate = false,
Jobs = new List<BulkUpdateJob>
{
new BulkUpdateJob
{
Type = BulkUpdateType.Upsert,
Data = new
{
number = new
{
iv = 99
}
}
}
},
Publish = true
});
Assert.Single(results);
Assert.Null(results[0].Error);
// STEP 2: Query content.
var content = await contents.GetAsync(results[0].ContentId);
Assert.Equal(99, content.Data.Number);
}
}
}