2020-12-20 08:36:11 +01:00
|
|
|
// Copyright (c) Umbraco.
|
|
|
|
|
// See LICENSE for more details.
|
|
|
|
|
|
|
|
|
|
using Moq;
|
2016-02-17 10:59:48 +01:00
|
|
|
using NUnit.Framework;
|
2021-03-05 15:36:27 +01:00
|
|
|
using Umbraco.Cms.Core.Cache;
|
2021-02-18 11:06:02 +01:00
|
|
|
using Umbraco.Cms.Core.Models;
|
|
|
|
|
using Umbraco.Cms.Core.Models.Entities;
|
|
|
|
|
using Umbraco.Cms.Core.Models.Membership;
|
|
|
|
|
using Umbraco.Cms.Core.Security;
|
|
|
|
|
using Umbraco.Cms.Core.Services;
|
|
|
|
|
using Umbraco.Cms.Tests.Common.Builders;
|
|
|
|
|
using Umbraco.Cms.Tests.Common.Builders.Extensions;
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2021-02-18 11:06:02 +01:00
|
|
|
namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Core.Security
|
2016-02-17 10:59:48 +01:00
|
|
|
{
|
|
|
|
|
[TestFixture]
|
2020-11-24 00:37:26 +11:00
|
|
|
public class MediaPermissionsTests
|
2016-02-17 10:59:48 +01:00
|
|
|
{
|
|
|
|
|
[Test]
|
|
|
|
|
public void Access_Allowed_By_Path()
|
|
|
|
|
{
|
2020-12-20 08:36:11 +01:00
|
|
|
// Arrange
|
|
|
|
|
IUser user = CreateUser(id: 9);
|
2016-02-17 10:59:48 +01:00
|
|
|
var mediaMock = new Mock<IMedia>();
|
|
|
|
|
mediaMock.Setup(m => m.Path).Returns("-1,1234,5678");
|
2020-12-20 08:36:11 +01:00
|
|
|
IMedia media = mediaMock.Object;
|
2017-07-20 11:21:28 +02:00
|
|
|
var mediaServiceMock = new Mock<IMediaService>();
|
2016-02-17 10:59:48 +01:00
|
|
|
mediaServiceMock.Setup(x => x.GetById(1234)).Returns(media);
|
2020-12-20 08:36:11 +01:00
|
|
|
IMediaService mediaService = mediaServiceMock.Object;
|
2017-09-14 19:29:12 +02:00
|
|
|
var entityServiceMock = new Mock<IEntityService>();
|
2020-12-20 08:36:11 +01:00
|
|
|
IEntityService entityService = entityServiceMock.Object;
|
2021-03-05 15:36:27 +01:00
|
|
|
var mediaPermissions = new MediaPermissions(mediaService, entityService, AppCaches.Disabled);
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Act
|
|
|
|
|
MediaPermissions.MediaAccess result = mediaPermissions.CheckPermissions(user, 1234, out _);
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Assert
|
2020-11-24 00:37:26 +11:00
|
|
|
Assert.AreEqual(MediaPermissions.MediaAccess.Granted, result);
|
2016-02-17 10:59:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
2020-11-24 00:37:26 +11:00
|
|
|
public void Returns_Not_Found_When_No_Media_Found()
|
2016-02-17 10:59:48 +01:00
|
|
|
{
|
2020-12-20 08:36:11 +01:00
|
|
|
// Arrange
|
|
|
|
|
IUser user = CreateUser(id: 9);
|
2016-02-17 10:59:48 +01:00
|
|
|
var mediaMock = new Mock<IMedia>();
|
|
|
|
|
mediaMock.Setup(m => m.Path).Returns("-1,1234,5678");
|
2020-12-20 08:36:11 +01:00
|
|
|
IMedia media = mediaMock.Object;
|
2016-02-17 10:59:48 +01:00
|
|
|
var mediaServiceMock = new Mock<IMediaService>();
|
|
|
|
|
mediaServiceMock.Setup(x => x.GetById(0)).Returns(media);
|
2020-12-20 08:36:11 +01:00
|
|
|
IMediaService mediaService = mediaServiceMock.Object;
|
2017-09-14 19:29:12 +02:00
|
|
|
var entityServiceMock = new Mock<IEntityService>();
|
2020-12-20 08:36:11 +01:00
|
|
|
IEntityService entityService = entityServiceMock.Object;
|
2021-03-05 15:36:27 +01:00
|
|
|
var mediaPermissions = new MediaPermissions(mediaService, entityService, AppCaches.Disabled);
|
2017-07-20 11:21:28 +02:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Act/assert
|
|
|
|
|
MediaPermissions.MediaAccess result = mediaPermissions.CheckPermissions(user, 1234, out _);
|
2020-11-24 00:37:26 +11:00
|
|
|
Assert.AreEqual(MediaPermissions.MediaAccess.NotFound, result);
|
2016-02-17 10:59:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void No_Access_By_Path()
|
|
|
|
|
{
|
2020-12-20 08:36:11 +01:00
|
|
|
// Arrange
|
|
|
|
|
IUser user = CreateUser(id: 9, startMediaId: 9876);
|
2016-02-17 10:59:48 +01:00
|
|
|
var mediaMock = new Mock<IMedia>();
|
|
|
|
|
mediaMock.Setup(m => m.Path).Returns("-1,1234,5678");
|
2020-12-20 08:36:11 +01:00
|
|
|
IMedia media = mediaMock.Object;
|
2016-02-17 10:59:48 +01:00
|
|
|
var mediaServiceMock = new Mock<IMediaService>();
|
|
|
|
|
mediaServiceMock.Setup(x => x.GetById(1234)).Returns(media);
|
2020-12-20 08:36:11 +01:00
|
|
|
IMediaService mediaService = mediaServiceMock.Object;
|
2017-09-14 19:29:12 +02:00
|
|
|
var entityServiceMock = new Mock<IEntityService>();
|
|
|
|
|
entityServiceMock.Setup(x => x.GetAllPaths(It.IsAny<UmbracoObjectTypes>(), It.IsAny<int[]>()))
|
2018-01-10 12:48:51 +01:00
|
|
|
.Returns(new[] { Mock.Of<TreeEntityPath>(entity => entity.Id == 9876 && entity.Path == "-1,9876") });
|
2020-12-20 08:36:11 +01:00
|
|
|
IEntityService entityService = entityServiceMock.Object;
|
2021-03-05 15:36:27 +01:00
|
|
|
var mediaPermissions = new MediaPermissions(mediaService, entityService, AppCaches.Disabled);
|
2017-07-20 11:21:28 +02:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Act
|
|
|
|
|
MediaPermissions.MediaAccess result = mediaPermissions.CheckPermissions(user, 1234, out _);
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Assert
|
2020-11-24 00:37:26 +11:00
|
|
|
Assert.AreEqual(MediaPermissions.MediaAccess.Denied, result);
|
2016-02-17 10:59:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void Access_To_Root_By_Path()
|
|
|
|
|
{
|
2020-12-20 08:36:11 +01:00
|
|
|
// Arrange
|
|
|
|
|
IUser user = CreateUser();
|
2017-09-14 19:29:12 +02:00
|
|
|
var mediaServiceMock = new Mock<IMediaService>();
|
2020-12-20 08:36:11 +01:00
|
|
|
IMediaService mediaService = mediaServiceMock.Object;
|
2017-09-14 19:29:12 +02:00
|
|
|
var entityServiceMock = new Mock<IEntityService>();
|
2020-12-20 08:36:11 +01:00
|
|
|
IEntityService entityService = entityServiceMock.Object;
|
2021-03-05 15:36:27 +01:00
|
|
|
var mediaPermissions = new MediaPermissions(mediaService, entityService, AppCaches.Disabled);
|
2017-07-20 11:21:28 +02:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Act
|
|
|
|
|
MediaPermissions.MediaAccess result = mediaPermissions.CheckPermissions(user, -1, out _);
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Assert
|
2020-11-24 00:37:26 +11:00
|
|
|
Assert.AreEqual(MediaPermissions.MediaAccess.Granted, result);
|
2016-02-17 10:59:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void No_Access_To_Root_By_Path()
|
|
|
|
|
{
|
2020-12-20 08:36:11 +01:00
|
|
|
// Arrange
|
|
|
|
|
IUser user = CreateUser(startMediaId: 1234);
|
2017-09-14 19:29:12 +02:00
|
|
|
var mediaServiceMock = new Mock<IMediaService>();
|
2020-12-20 08:36:11 +01:00
|
|
|
IMediaService mediaService = mediaServiceMock.Object;
|
2017-09-14 19:29:12 +02:00
|
|
|
var entityServiceMock = new Mock<IEntityService>();
|
|
|
|
|
entityServiceMock.Setup(x => x.GetAllPaths(It.IsAny<UmbracoObjectTypes>(), It.IsAny<int[]>()))
|
2018-01-10 12:48:51 +01:00
|
|
|
.Returns(new[] { Mock.Of<TreeEntityPath>(entity => entity.Id == 1234 && entity.Path == "-1,1234") });
|
2020-12-20 08:36:11 +01:00
|
|
|
IEntityService entityService = entityServiceMock.Object;
|
2021-03-05 15:36:27 +01:00
|
|
|
var mediaPermissions = new MediaPermissions(mediaService, entityService, AppCaches.Disabled);
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Act
|
|
|
|
|
MediaPermissions.MediaAccess result = mediaPermissions.CheckPermissions(user, -1, out _);
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Assert
|
2020-11-24 00:37:26 +11:00
|
|
|
Assert.AreEqual(MediaPermissions.MediaAccess.Denied, result);
|
2016-02-17 10:59:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void Access_To_Recycle_Bin_By_Path()
|
|
|
|
|
{
|
2020-12-20 08:36:11 +01:00
|
|
|
// Arrange
|
|
|
|
|
IUser user = CreateUser();
|
2017-09-14 19:29:12 +02:00
|
|
|
var mediaServiceMock = new Mock<IMediaService>();
|
2020-12-20 08:36:11 +01:00
|
|
|
IMediaService mediaService = mediaServiceMock.Object;
|
2017-09-14 19:29:12 +02:00
|
|
|
var entityServiceMock = new Mock<IEntityService>();
|
2020-12-20 08:36:11 +01:00
|
|
|
IEntityService entityService = entityServiceMock.Object;
|
2021-03-05 15:36:27 +01:00
|
|
|
var mediaPermissions = new MediaPermissions(mediaService, entityService, AppCaches.Disabled);
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Act
|
|
|
|
|
MediaPermissions.MediaAccess result = mediaPermissions.CheckPermissions(user, -21, out _);
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Assert
|
2020-11-24 00:37:26 +11:00
|
|
|
Assert.AreEqual(MediaPermissions.MediaAccess.Granted, result);
|
2016-02-17 10:59:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
public void No_Access_To_Recycle_Bin_By_Path()
|
|
|
|
|
{
|
2020-12-20 08:36:11 +01:00
|
|
|
// Arrange
|
|
|
|
|
IUser user = CreateUser(startMediaId: 1234);
|
2017-09-14 19:29:12 +02:00
|
|
|
var mediaServiceMock = new Mock<IMediaService>();
|
2020-12-20 08:36:11 +01:00
|
|
|
IMediaService mediaService = mediaServiceMock.Object;
|
2017-09-14 19:29:12 +02:00
|
|
|
var entityServiceMock = new Mock<IEntityService>();
|
|
|
|
|
entityServiceMock.Setup(x => x.GetAllPaths(It.IsAny<UmbracoObjectTypes>(), It.IsAny<int[]>()))
|
2018-01-10 12:48:51 +01:00
|
|
|
.Returns(new[] { Mock.Of<TreeEntityPath>(entity => entity.Id == 1234 && entity.Path == "-1,1234") });
|
2020-12-20 08:36:11 +01:00
|
|
|
IEntityService entityService = entityServiceMock.Object;
|
2021-03-05 15:36:27 +01:00
|
|
|
var mediaPermissions = new MediaPermissions(mediaService, entityService, AppCaches.Disabled);
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Act
|
|
|
|
|
MediaPermissions.MediaAccess result = mediaPermissions.CheckPermissions(user, -21, out _);
|
2016-02-17 10:59:48 +01:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
// Assert
|
2020-11-24 00:37:26 +11:00
|
|
|
Assert.AreEqual(MediaPermissions.MediaAccess.Denied, result);
|
2016-02-17 10:59:48 +01:00
|
|
|
}
|
2020-10-06 12:02:29 +02:00
|
|
|
|
2020-12-20 08:36:11 +01:00
|
|
|
private IUser CreateUser(int id = 0, int? startMediaId = null) =>
|
|
|
|
|
new UserBuilder()
|
2020-10-06 12:02:29 +02:00
|
|
|
.WithId(id)
|
2020-10-06 13:24:32 +02:00
|
|
|
.WithStartMediaIds(startMediaId.HasValue ? new[] { startMediaId.Value } : new int[0])
|
2020-10-06 12:02:29 +02:00
|
|
|
.AddUserGroup()
|
|
|
|
|
.WithId(1)
|
|
|
|
|
.WithName("admin")
|
|
|
|
|
.WithAlias("admin")
|
|
|
|
|
.Done()
|
|
|
|
|
.Build();
|
2016-02-17 10:59:48 +01:00
|
|
|
}
|
2017-07-20 11:21:28 +02:00
|
|
|
}
|