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.
127 lines
3.3 KiB
127 lines
3.3 KiB
using System.Linq;
|
|
using Eloquera.Client;
|
|
using FizzWare.NBuilder;
|
|
using FluentAssertions;
|
|
using NUnit.Framework;
|
|
using NzbDrone.Core.Repository;
|
|
using NzbDrone.Core.Test.Framework;
|
|
|
|
namespace NzbDrone.Core.Test.Datastore
|
|
{
|
|
[TestFixture]
|
|
public class ObjectDatabaseFixture : ObjectDbTest
|
|
{
|
|
private Series testSeries;
|
|
private Episode testEpisode;
|
|
|
|
[SetUp]
|
|
public void SetUp()
|
|
{
|
|
WithObjectDb();
|
|
|
|
testSeries = Builder<Series>
|
|
.CreateNew()
|
|
.With(s => s.Id = 0)
|
|
.Build();
|
|
|
|
testEpisode = Builder<Episode>
|
|
.CreateNew()
|
|
.With(e => e.Id = 0)
|
|
.Build();
|
|
|
|
|
|
}
|
|
|
|
[Test]
|
|
public void should_be_able_to_write_to_database()
|
|
{
|
|
Db.Insert(testSeries);
|
|
Db.AsQueryable<Series>().Should().HaveCount(1);
|
|
}
|
|
|
|
[Test]
|
|
public void should_not_store_dirty_data_in_cache()
|
|
{
|
|
Db.Insert(testEpisode);
|
|
|
|
Db.AsQueryable<Episode>().Single().Series.Should().BeNull();
|
|
|
|
testEpisode.Series = Builder<Series>.CreateNew().Build();
|
|
|
|
Db.AsQueryable<Episode>().Single().Series.Should().BeNull();
|
|
}
|
|
|
|
[Test]
|
|
public void should_store_nested_objects()
|
|
{
|
|
testEpisode.Series = testSeries;
|
|
|
|
Db.Insert(testEpisode);
|
|
|
|
Db.AsQueryable<Episode>().Should().HaveCount(1);
|
|
Db.AsQueryable<Episode>().Single().Series.Should().NotBeNull();
|
|
}
|
|
|
|
[Test]
|
|
public void should_update_nested_objects()
|
|
{
|
|
testEpisode.Series = Builder<Series>
|
|
.CreateNew()
|
|
.With(s => s.Id = 0)
|
|
.Build();
|
|
|
|
Db.Insert(testEpisode);
|
|
|
|
testEpisode.Series.Title = "UpdatedTitle";
|
|
|
|
Db.Update(testEpisode);
|
|
|
|
Db.AsQueryable<Episode>().Should().HaveCount(1);
|
|
Db.AsQueryable<Episode>().Single().Series.Should().NotBeNull();
|
|
Db.AsQueryable<Episode>().Single().Series.Title.Should().Be("UpdatedTitle");
|
|
}
|
|
|
|
[Test]
|
|
public void new_objects_should_get_id()
|
|
{
|
|
testSeries.Id = Db.InsertAndGetId(testSeries);
|
|
testSeries.Id.Should().NotBe(0);
|
|
}
|
|
|
|
[Test]
|
|
public void should_have_id_when_returned_from_database()
|
|
{
|
|
testSeries.Id = Db.InsertAndGetId(testSeries);
|
|
var item = Db.AsQueryable<Series>();
|
|
|
|
item.Should().HaveCount(1);
|
|
item.First().Id.Should().NotBe(0);
|
|
item.First().Id.Should().Be(testSeries.Id);
|
|
}
|
|
|
|
[Test]
|
|
public void should_be_able_to_find_object_by_id()
|
|
{
|
|
testSeries.Id = Db.InsertAndGetId(testSeries);
|
|
var item = Db.AsQueryable<Series>().Single(c => c.Id == testSeries.Id);
|
|
|
|
item.Id.Should().NotBe(0);
|
|
item.Id.Should().Be(testSeries.Id);
|
|
}
|
|
|
|
[Test]
|
|
public void should_be_able_to_read_unknown_type()
|
|
{
|
|
Db.AsQueryable<UnknownType>().ToList().Should().BeEmpty();
|
|
}
|
|
}
|
|
|
|
public class UnknownType
|
|
{
|
|
[ID]
|
|
public string Id;
|
|
public string Field1 { get; set; }
|
|
}
|
|
}
|
|
|