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.
 
 
 
 
 

96 lines
3.1 KiB

// ==========================================================================
// Squidex Headless CMS
// ==========================================================================
// Copyright (c) Squidex UG (haftungsbeschränkt)
// All rights reserved. Licensed under the MIT license.
// ==========================================================================
using System.Security.Claims;
using Jint;
using Squidex.Domain.Apps.Core.Scripting;
using Squidex.Infrastructure.Security;
using Squidex.Shared.Identity;
using Xunit;
#pragma warning disable xUnit2004 // Do not use equality check to test for boolean conditions
namespace Squidex.Domain.Apps.Core.Operations.Scripting
{
public class JintUserTests
{
[Fact]
public void Should_set_user_id_from_client_id()
{
var identity = new ClaimsIdentity();
identity.AddClaim(new Claim(OpenIdClaims.ClientId, "1"));
Assert.Equal("1", GetValue(identity, "user.id"));
Assert.Equal(true, GetValue(identity, "user.isClient"));
}
[Fact]
public void Should_set_user_id_from_subject_id()
{
var identity = new ClaimsIdentity();
identity.AddClaim(new Claim(OpenIdClaims.Subject, "2"));
Assert.Equal("2", GetValue(identity, "user.id"));
Assert.Equal(false, GetValue(identity, "user.isClient"));
}
[Fact]
public void Should_set_email_from_claim()
{
var identity = new ClaimsIdentity();
identity.AddClaim(new Claim(OpenIdClaims.Email, "hello@squidex.io"));
Assert.Equal("hello@squidex.io", GetValue(identity, "user.email"));
}
[Fact]
public void Should_simplify_squidex_claims()
{
var identity = new ClaimsIdentity();
identity.AddClaim(new Claim(SquidexClaimTypes.PictureUrl, "my-picture"));
Assert.Equal(new[] { "my-picture" }, GetValue(identity, "user.claims.picture"));
}
[Fact]
public void Should_simplify_default_claims()
{
var identity = new ClaimsIdentity();
identity.AddClaim(new Claim(ClaimTypes.Role, "my-role"));
Assert.Equal(new[] { "my-role" }, GetValue(identity, "user.claims.role"));
}
[Fact]
public void Should_set_claims()
{
var identity = new ClaimsIdentity();
identity.AddClaim(new Claim("claim1", "1a"));
identity.AddClaim(new Claim("claim1", "1b"));
identity.AddClaim(new Claim("claim2", "2a"));
identity.AddClaim(new Claim("claim2", "2b"));
Assert.Equal(new[] { "1a", "1b" }, GetValue(identity, "user.claims.claim1"));
Assert.Equal(new[] { "2a", "2b" }, GetValue(identity, "user.claims.claim2"));
}
private static object GetValue(ClaimsIdentity identity, string script)
{
var engine = new Engine();
engine.SetValue("user", new JintUser(engine, new ClaimsPrincipal(new[] { identity })));
return engine.Execute(script).GetCompletionValue().ToObject();
}
}
}