mirror of
https://github.com/Ombi-app/Ombi.git
synced 2025-07-15 01:32:55 -07:00
Some unit tests for the issues
This commit is contained in:
parent
9450127893
commit
14ca513555
3 changed files with 152 additions and 0 deletions
149
PlexRequests.UI.Tests/IssuesModuleTests.cs
Normal file
149
PlexRequests.UI.Tests/IssuesModuleTests.cs
Normal file
|
@ -0,0 +1,149 @@
|
||||||
|
#region Copyright
|
||||||
|
// /************************************************************************
|
||||||
|
// Copyright (c) 2016 Jamie Rees
|
||||||
|
// File: IssuesModuleTests.cs
|
||||||
|
// Created By: Jamie Rees
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
// a copy of this software and associated documentation files (the
|
||||||
|
// "Software"), to deal in the Software without restriction, including
|
||||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
// the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be
|
||||||
|
// included in all copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
// ************************************************************************/
|
||||||
|
#endregion
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
using Moq;
|
||||||
|
|
||||||
|
using Nancy;
|
||||||
|
using Nancy.Testing;
|
||||||
|
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
|
||||||
|
using NUnit.Framework;
|
||||||
|
|
||||||
|
using PlexRequests.Core;
|
||||||
|
using PlexRequests.Core.Models;
|
||||||
|
using PlexRequests.Core.SettingModels;
|
||||||
|
using PlexRequests.Helpers;
|
||||||
|
using PlexRequests.Services.Interfaces;
|
||||||
|
using PlexRequests.UI.Models;
|
||||||
|
using PlexRequests.UI.Modules;
|
||||||
|
|
||||||
|
using Ploeh.AutoFixture;
|
||||||
|
|
||||||
|
namespace PlexRequests.UI.Tests
|
||||||
|
{
|
||||||
|
[TestFixture]
|
||||||
|
public class IssuesModuleTests
|
||||||
|
{
|
||||||
|
[SetUp]
|
||||||
|
public void Setup()
|
||||||
|
{
|
||||||
|
var f = new Fixture();
|
||||||
|
ModelList = f.CreateMany<IssuesModel>();
|
||||||
|
PlexRequestMock = new Mock<ISettingsService<PlexRequestSettings>>();
|
||||||
|
PlexRequestMock.Setup(x => x.GetSettings()).Returns(new PlexRequestSettings());
|
||||||
|
PlexRequestMock.Setup(x => x.GetSettingsAsync()).Returns(Task.FromResult(new PlexRequestSettings()));
|
||||||
|
IssueServiceMock = new Mock<IIssueService>();
|
||||||
|
RequestServiceMock = new Mock<IRequestService>();
|
||||||
|
NotificationServiceMock = new Mock<INotificationService>();
|
||||||
|
IssueServiceMock.Setup(x => x.GetAllAsync()).Returns(Task.FromResult(ModelList));
|
||||||
|
|
||||||
|
Bootstrapper = new ConfigurableBootstrapper(
|
||||||
|
with =>
|
||||||
|
{
|
||||||
|
with.Module<IssuesModule>();
|
||||||
|
with.Dependency(PlexRequestMock.Object);
|
||||||
|
with.Dependency(IssueServiceMock.Object);
|
||||||
|
with.Dependency(RequestServiceMock.Object);
|
||||||
|
with.Dependency(NotificationServiceMock.Object);
|
||||||
|
with.RootPathProvider<TestRootPathProvider>();
|
||||||
|
});
|
||||||
|
|
||||||
|
Bootstrapper.WithSession(new Dictionary<string, object> { { SessionKeys.UsernameKey, "abc" } });
|
||||||
|
}
|
||||||
|
|
||||||
|
private Mock<ISettingsService<PlexRequestSettings>> PlexRequestMock { get; set; }
|
||||||
|
private Mock<IIssueService> IssueServiceMock { get; set; }
|
||||||
|
private Mock<IRequestService> RequestServiceMock { get; set; }
|
||||||
|
private Mock<INotificationService> NotificationServiceMock { get; set; }
|
||||||
|
private ConfigurableBootstrapper Bootstrapper { get; set; }
|
||||||
|
private IEnumerable<IssuesModel> ModelList { get; set; }
|
||||||
|
|
||||||
|
private IEnumerable<IssuesModel> NonResolvedModel => ModelList.Where(x => x.IssueStatus != IssueStatus.ResolvedIssue);
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void GetIssuesNonAdminButAllCanSee()
|
||||||
|
{
|
||||||
|
var browser = new Browser(Bootstrapper);
|
||||||
|
var result = browser.Get(
|
||||||
|
"/issues/pending",
|
||||||
|
with =>
|
||||||
|
{
|
||||||
|
with.HttpRequest();
|
||||||
|
with.Header("Accept", "application/json");
|
||||||
|
});
|
||||||
|
|
||||||
|
Assert.That(HttpStatusCode.OK, Is.EqualTo(result.StatusCode));
|
||||||
|
Assert.That(result.Context.Request.Session[SessionKeys.UsernameKey], Is.EqualTo("abc"));
|
||||||
|
|
||||||
|
var body = JsonConvert.DeserializeObject<List<IssuesViewModel>>(result.Body.AsString());
|
||||||
|
|
||||||
|
Assert.That(body.Count, Is.EqualTo(NonResolvedModel.Count()));
|
||||||
|
Assert.That(body[0].Title, Is.Not.Empty);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void GetIssuesForAdmin()
|
||||||
|
{
|
||||||
|
Bootstrapper = new ConfigurableBootstrapper(
|
||||||
|
with =>
|
||||||
|
{
|
||||||
|
with.Module<IssuesModule>();
|
||||||
|
with.Dependency(PlexRequestMock.Object);
|
||||||
|
with.Dependency(IssueServiceMock.Object);
|
||||||
|
with.Dependency(RequestServiceMock.Object);
|
||||||
|
with.Dependency(NotificationServiceMock.Object);
|
||||||
|
with.RootPathProvider<TestRootPathProvider>();
|
||||||
|
with.RequestStartup(
|
||||||
|
(container, pipelines, context) =>
|
||||||
|
{
|
||||||
|
context.CurrentUser = new UserIdentity() { Claims = new[] { UserClaims.Admin } };
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
Bootstrapper.WithSession(new Dictionary<string, object> { { SessionKeys.UsernameKey, "abc" } });
|
||||||
|
var browser = new Browser(Bootstrapper);
|
||||||
|
var result = browser.Get(
|
||||||
|
"/issues/pending",
|
||||||
|
with =>
|
||||||
|
{
|
||||||
|
with.HttpRequest();
|
||||||
|
with.Header("Accept", "application/json");
|
||||||
|
});
|
||||||
|
|
||||||
|
Assert.That(HttpStatusCode.OK, Is.EqualTo(result.StatusCode));
|
||||||
|
Assert.That(result.Context.Request.Session[SessionKeys.UsernameKey], Is.EqualTo("abc"));
|
||||||
|
|
||||||
|
var body = JsonConvert.DeserializeObject<List<IssuesViewModel>>(result.Body.AsString());
|
||||||
|
Assert.That(body.Count, Is.EqualTo(NonResolvedModel.Count()));
|
||||||
|
Assert.That(body[0].Title, Is.Not.Empty);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -105,6 +105,7 @@
|
||||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||||
<Compile Include="StringHelperTests.cs" />
|
<Compile Include="StringHelperTests.cs" />
|
||||||
<Compile Include="TestRootPathProvider.cs" />
|
<Compile Include="TestRootPathProvider.cs" />
|
||||||
|
<Compile Include="IssuesModuleTests.cs" />
|
||||||
<Compile Include="UserLoginModuleTests.cs" />
|
<Compile Include="UserLoginModuleTests.cs" />
|
||||||
<Compile Include="AdminModuleTests.cs" />
|
<Compile Include="AdminModuleTests.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
|
@ -317,6 +317,8 @@ namespace PlexRequests.UI.Modules
|
||||||
/// Filters the issues. Checks to see if we have set <c>UsersCanViewOnlyOwnIssues</c> in the database and filters upon the user logged in and that setting.
|
/// Filters the issues. Checks to see if we have set <c>UsersCanViewOnlyOwnIssues</c> in the database and filters upon the user logged in and that setting.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="issues">The issues.</param>
|
/// <param name="issues">The issues.</param>
|
||||||
|
/// <param name="showResolved">if set to <c>true</c> [show resolved].</param>
|
||||||
|
/// <returns></returns>
|
||||||
private async Task<IEnumerable<IssuesModel>> FilterIssuesAsync(IEnumerable<IssuesModel> issues, bool showResolved = false)
|
private async Task<IEnumerable<IssuesModel>> FilterIssuesAsync(IEnumerable<IssuesModel> issues, bool showResolved = false)
|
||||||
{
|
{
|
||||||
var settings = await PlexRequestSettings.GetSettingsAsync();
|
var settings = await PlexRequestSettings.GetSettingsAsync();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue