* Run code cleanup * Dotnet format benchmarks project * Fix up Test.Common * Run dotnet format + manual cleanup * Run code cleanup for unit tests * Run dotnet format * Fix up errors * Manual cleanup of Unit test project * Update tests/Umbraco.Tests.Benchmarks/HexStringBenchmarks.cs Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> * Update tests/Umbraco.Tests.Integration/Testing/TestDbMeta.cs Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> * Update tests/Umbraco.Tests.Benchmarks/TypeFinderBenchmarks.cs Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> * Update tests/Umbraco.Tests.Integration/Testing/UmbracoIntegrationTest.cs Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> * Update tests/Umbraco.Tests.Integration/Umbraco.Core/Events/EventAggregatorTests.cs Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> * Fix according to review * Fix after merge * Fix errors Co-authored-by: Nikolaj Geisle <niko737@edu.ucl.dk> Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> Co-authored-by: Zeegaan <nge@umbraco.dk>
126 lines
4.8 KiB
C#
126 lines
4.8 KiB
C#
// Copyright (c) Umbraco.
|
|
// See LICENSE for more details.
|
|
|
|
using Microsoft.Extensions.Options;
|
|
using Moq;
|
|
using NUnit.Framework;
|
|
using Umbraco.Cms.Core;
|
|
using Umbraco.Cms.Core.Configuration.Models;
|
|
using Umbraco.Cms.Core.Hosting;
|
|
using Umbraco.Cms.Core.Routing;
|
|
using Umbraco.Cms.Core.Services;
|
|
using Umbraco.Cms.Core.Web;
|
|
using Umbraco.Cms.Tests.UnitTests.TestHelpers;
|
|
using Umbraco.Cms.Web.BackOffice.Controllers;
|
|
using Umbraco.Cms.Web.BackOffice.Security;
|
|
using Umbraco.Extensions;
|
|
|
|
namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Web.BackOffice.Security;
|
|
|
|
[TestFixture]
|
|
public class BackOfficeCookieManagerTests
|
|
{
|
|
[Test]
|
|
public void ShouldAuthenticateRequest_When_Not_Configured()
|
|
{
|
|
var globalSettings = new GlobalSettings();
|
|
|
|
var runtime = Mock.Of<IRuntimeState>(x => x.Level == RuntimeLevel.Install);
|
|
var mgr = new BackOfficeCookieManager(
|
|
Mock.Of<IUmbracoContextAccessor>(),
|
|
runtime,
|
|
new UmbracoRequestPaths(Options.Create(globalSettings), TestHelper.GetHostingEnvironment()),
|
|
Mock.Of<IBasicAuthService>());
|
|
|
|
var result = mgr.ShouldAuthenticateRequest("/umbraco");
|
|
|
|
Assert.IsFalse(result);
|
|
}
|
|
|
|
[Test]
|
|
public void ShouldAuthenticateRequest_When_Configured()
|
|
{
|
|
var globalSettings = new GlobalSettings();
|
|
|
|
var runtime = Mock.Of<IRuntimeState>(x => x.Level == RuntimeLevel.Run);
|
|
var mgr = new BackOfficeCookieManager(
|
|
Mock.Of<IUmbracoContextAccessor>(),
|
|
runtime,
|
|
new UmbracoRequestPaths(
|
|
Options.Create(globalSettings),
|
|
Mock.Of<IHostingEnvironment>(x =>
|
|
x.ApplicationVirtualPath == "/" && x.ToAbsolute(globalSettings.UmbracoPath) == "/umbraco")),
|
|
Mock.Of<IBasicAuthService>());
|
|
|
|
var result = mgr.ShouldAuthenticateRequest("/umbraco");
|
|
|
|
Assert.IsTrue(result);
|
|
}
|
|
|
|
[Test]
|
|
public void ShouldAuthenticateRequest_Is_Back_Office()
|
|
{
|
|
var globalSettings = new GlobalSettings();
|
|
|
|
var runtime = Mock.Of<IRuntimeState>(x => x.Level == RuntimeLevel.Run);
|
|
|
|
GenerateAuthPaths(out var remainingTimeoutSecondsPath, out var isAuthPath);
|
|
|
|
var mgr = new BackOfficeCookieManager(
|
|
Mock.Of<IUmbracoContextAccessor>(),
|
|
runtime,
|
|
new UmbracoRequestPaths(
|
|
Options.Create(globalSettings),
|
|
Mock.Of<IHostingEnvironment>(x =>
|
|
x.ApplicationVirtualPath == "/" && x.ToAbsolute(globalSettings.UmbracoPath) == "/umbraco" &&
|
|
x.ToAbsolute(Constants.SystemDirectories.Install) == "/install")),
|
|
Mock.Of<IBasicAuthService>());
|
|
|
|
var result = mgr.ShouldAuthenticateRequest(remainingTimeoutSecondsPath);
|
|
Assert.IsTrue(result);
|
|
|
|
result = mgr.ShouldAuthenticateRequest(isAuthPath);
|
|
Assert.IsTrue(result);
|
|
}
|
|
|
|
[Test]
|
|
public void ShouldAuthenticateRequest_Not_Back_Office()
|
|
{
|
|
var globalSettings = new GlobalSettings();
|
|
|
|
var runtime = Mock.Of<IRuntimeState>(x => x.Level == RuntimeLevel.Run);
|
|
|
|
var mgr = new BackOfficeCookieManager(
|
|
Mock.Of<IUmbracoContextAccessor>(),
|
|
runtime,
|
|
new UmbracoRequestPaths(
|
|
Options.Create(globalSettings),
|
|
Mock.Of<IHostingEnvironment>(x =>
|
|
x.ApplicationVirtualPath == "/" && x.ToAbsolute(globalSettings.UmbracoPath) == "/umbraco" &&
|
|
x.ToAbsolute(Constants.SystemDirectories.Install) == "/install")),
|
|
Mock.Of<IBasicAuthService>());
|
|
|
|
var result = mgr.ShouldAuthenticateRequest("/notbackoffice");
|
|
Assert.IsFalse(result);
|
|
result = mgr.ShouldAuthenticateRequest("/umbraco/api/notbackoffice");
|
|
Assert.IsFalse(result);
|
|
result = mgr.ShouldAuthenticateRequest("/umbraco/surface/notbackoffice");
|
|
Assert.IsFalse(result);
|
|
}
|
|
|
|
private void GenerateAuthPaths(out string remainingTimeoutSecondsPath, out string isAuthPath)
|
|
{
|
|
var controllerName = ControllerExtensions.GetControllerName<AuthenticationController>();
|
|
|
|
// this path is not a back office request even though it's in the same controller - it's a 'special' endpoint
|
|
var rPath = remainingTimeoutSecondsPath =
|
|
$"/umbraco/{Constants.Web.Mvc.BackOfficePathSegment}/{Constants.Web.Mvc.BackOfficeApiArea}/{controllerName}/{nameof(AuthenticationController.GetRemainingTimeoutSeconds)}"
|
|
.ToLower();
|
|
|
|
// this is on the same controller but is considered a back office request
|
|
var aPath = isAuthPath =
|
|
$"/umbraco/{Constants.Web.Mvc.BackOfficePathSegment}/{Constants.Web.Mvc.BackOfficeApiArea}/{controllerName}/{nameof(AuthenticationController.IsAuthenticated)}"
|
|
.ToLower();
|
|
}
|
|
}
|