Merge branch 'quality-definitions' of https://github.com/Taloth/NzbDrone into Taloth-quality-definitions
commit
f832d55424
@ -0,0 +1,79 @@
|
|||||||
|
using System.Collections.Generic;
|
||||||
|
using Moq;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using NzbDrone.Core.Lifecycle;
|
||||||
|
using NzbDrone.Core.Qualities;
|
||||||
|
using NzbDrone.Core.Test.Framework;
|
||||||
|
|
||||||
|
namespace NzbDrone.Core.Test.Qualities
|
||||||
|
{
|
||||||
|
[TestFixture]
|
||||||
|
public class QualityDefinitionServiceFixture : CoreTest<QualityDefinitionService>
|
||||||
|
{
|
||||||
|
[Test]
|
||||||
|
public void init_should_add_all_definitions()
|
||||||
|
{
|
||||||
|
Subject.Handle(new ApplicationStartedEvent());
|
||||||
|
|
||||||
|
Mocker.GetMock<IQualityDefinitionRepository>()
|
||||||
|
.Verify(v => v.Insert(It.IsAny<QualityDefinition>()), Times.Exactly(Quality.All.Count));
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void init_should_insert_any_missing_definitions()
|
||||||
|
{
|
||||||
|
Mocker.GetMock<IQualityDefinitionRepository>()
|
||||||
|
.Setup(s => s.All())
|
||||||
|
.Returns(new List<QualityDefinition>
|
||||||
|
{
|
||||||
|
new QualityDefinition(Quality.SDTV) { Weight = 1, MinSize = 0, MaxSize = 100, Id = 20 }
|
||||||
|
});
|
||||||
|
|
||||||
|
Subject.Handle(new ApplicationStartedEvent());
|
||||||
|
|
||||||
|
Mocker.GetMock<IQualityDefinitionRepository>()
|
||||||
|
.Verify(v => v.Insert(It.IsAny<QualityDefinition>()), Times.Exactly(Quality.All.Count - 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void init_should_insert_missing_definitions_preserving_weight()
|
||||||
|
{
|
||||||
|
// User moved HDTV1080p to a higher weight.
|
||||||
|
var currentQualities = new List<QualityDefinition>
|
||||||
|
{
|
||||||
|
new QualityDefinition(Quality.SDTV) { Id = 5, Title = "SDTV", Weight = 1, MinSize=0, MaxSize=100 },
|
||||||
|
new QualityDefinition(Quality.WEBDL720p) { Id = 2, Title = "720p WEB-DL", Weight = 2, MinSize=0, MaxSize=100 },
|
||||||
|
new QualityDefinition(Quality.HDTV1080p) { Id = 4, Title = "1080p HDTV", Weight = 3, MinSize=0, MaxSize=100 },
|
||||||
|
new QualityDefinition(Quality.WEBDL1080p) { Id = 8, Title = "1080p WEB-DL", Weight = 4, MinSize=0, MaxSize=100 },
|
||||||
|
};
|
||||||
|
|
||||||
|
// Expected to insert Bluray720p above HDTV1080p.
|
||||||
|
// Expected to insert Bluray1080p above WEBDL1080p.
|
||||||
|
var addBluray1080p = new List<QualityDefinition>
|
||||||
|
{
|
||||||
|
new QualityDefinition(Quality.SDTV) { Title = "SDTV", Weight = 1, MinSize=0, MaxSize=100 },
|
||||||
|
new QualityDefinition(Quality.HDTV1080p) { Title = "1080p HDTV", Weight = 2, MinSize=0, MaxSize=100 },
|
||||||
|
new QualityDefinition(Quality.WEBDL720p) { Title = "720p WEB-DL", Weight = 3, MinSize=0, MaxSize=100 },
|
||||||
|
new QualityDefinition(Quality.Bluray720p) { Title = "720p BluRay", Weight = 4, MinSize=0, MaxSize=100 },
|
||||||
|
new QualityDefinition(Quality.WEBDL1080p) { Title = "1080p WEB-DL", Weight = 5, MinSize=0, MaxSize=100 },
|
||||||
|
new QualityDefinition(Quality.Bluray1080p) { Title = "1080p BluRay", Weight = 6, MinSize=0, MaxSize=100 }
|
||||||
|
};
|
||||||
|
|
||||||
|
Mocker.GetMock<IQualityDefinitionRepository>()
|
||||||
|
.Setup(v => v.All())
|
||||||
|
.Returns(currentQualities);
|
||||||
|
|
||||||
|
Subject.InsertMissingDefinitions(addBluray1080p);
|
||||||
|
|
||||||
|
Mocker.GetMock<IQualityDefinitionRepository>()
|
||||||
|
.Verify(v => v.Insert(It.Is<QualityDefinition>(p => p.Quality == Quality.Bluray720p && p.Weight == 4)), Times.Once());
|
||||||
|
|
||||||
|
Mocker.GetMock<IQualityDefinitionRepository>()
|
||||||
|
.Verify(v => v.Update(It.Is<QualityDefinition>(p => p.Quality == Quality.WEBDL1080p && p.Weight == 5)), Times.Once());
|
||||||
|
|
||||||
|
Mocker.GetMock<IQualityDefinitionRepository>()
|
||||||
|
.Verify(v => v.Insert(It.Is<QualityDefinition>(p => p.Quality == Quality.Bluray1080p && p.Weight == 6)), Times.Once());
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,39 +0,0 @@
|
|||||||
using System.Collections.Generic;
|
|
||||||
using Moq;
|
|
||||||
using NUnit.Framework;
|
|
||||||
using NzbDrone.Core.Lifecycle;
|
|
||||||
using NzbDrone.Core.Qualities;
|
|
||||||
using NzbDrone.Core.Test.Framework;
|
|
||||||
|
|
||||||
namespace NzbDrone.Core.Test.Qualities
|
|
||||||
{
|
|
||||||
[TestFixture]
|
|
||||||
|
|
||||||
public class QualitySizeServiceFixture : CoreTest<QualitySizeService>
|
|
||||||
{
|
|
||||||
[Test]
|
|
||||||
public void Init_should_add_all_sizes()
|
|
||||||
{
|
|
||||||
Subject.Handle(new ApplicationStartedEvent());
|
|
||||||
|
|
||||||
Mocker.GetMock<IQualitySizeRepository>()
|
|
||||||
.Verify(v => v.Insert(It.IsAny<QualitySize>()), Times.Exactly(Quality.All().Count));
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void Init_should_insert_any_missing_sizes()
|
|
||||||
{
|
|
||||||
Mocker.GetMock<IQualitySizeRepository>()
|
|
||||||
.Setup(s => s.All())
|
|
||||||
.Returns(new List<QualitySize>
|
|
||||||
{
|
|
||||||
new QualitySize { QualityId = 1, Name = "SDTV", MinSize = 0, MaxSize = 100 }
|
|
||||||
});
|
|
||||||
|
|
||||||
Subject.Handle(new ApplicationStartedEvent());
|
|
||||||
|
|
||||||
Mocker.GetMock<IQualitySizeRepository>()
|
|
||||||
.Verify(v => v.Insert(It.IsAny<QualitySize>()), Times.Exactly(Quality.All().Count - 1));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,31 @@
|
|||||||
|
<span class="span2">
|
||||||
|
{{quality.name}}
|
||||||
|
</span>
|
||||||
|
<span class="span2">
|
||||||
|
<input type="text" class="x-title input-block-level" value="{{title}}">
|
||||||
|
</span>
|
||||||
|
<span class="offset1 span4">
|
||||||
|
<div class="x-slider"></div>
|
||||||
|
<div class="size-label-wrapper">
|
||||||
|
<div class="pull-left">
|
||||||
|
<span class="label label-warning x-min-thirty"
|
||||||
|
name="thirtyMinuteMinSize"
|
||||||
|
title="Minimum size for a 30 minute episode">
|
||||||
|
</span>
|
||||||
|
<span class="label label-info x-min-sixty"
|
||||||
|
name="sixtyMinuteMinSize"
|
||||||
|
title="Minimum size for a 60 minute episode">
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<div class="pull-right">
|
||||||
|
<span class="label label-warning x-max-thirty"
|
||||||
|
name="thirtyMinuteMaxSize"
|
||||||
|
title="Maximum size for a 30 minute episode">
|
||||||
|
</span>
|
||||||
|
<span class="label label-info x-max-sixty"
|
||||||
|
name="sixtyMinuteMaxSize"
|
||||||
|
title="Maximum size for a 60 minute episode">
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</span>
|
@ -0,0 +1,9 @@
|
|||||||
|
'use strict';
|
||||||
|
define(
|
||||||
|
[
|
||||||
|
'marionette'
|
||||||
|
], function (Marionette) {
|
||||||
|
return Marionette.ItemView.extend({
|
||||||
|
template : 'Settings/Quality/Profile/EditQualityProfileItemViewTemplate'
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in new issue