diff --git a/NzbDrone.Api/NzbDrone.Api.csproj b/NzbDrone.Api/NzbDrone.Api.csproj index 8ff94211a..7694cf32b 100644 --- a/NzbDrone.Api/NzbDrone.Api.csproj +++ b/NzbDrone.Api/NzbDrone.Api.csproj @@ -112,8 +112,6 @@ - - diff --git a/NzbDrone.Api/Resolvers/EndTimeResolver.cs b/NzbDrone.Api/Resolvers/EndTimeResolver.cs deleted file mode 100644 index 6e078c52f..000000000 --- a/NzbDrone.Api/Resolvers/EndTimeResolver.cs +++ /dev/null @@ -1,17 +0,0 @@ -using System; -using System.Collections.Generic; -using System.Linq; -using AutoMapper; -using NzbDrone.Api.QualityProfiles; -using NzbDrone.Core.Tv; - -namespace NzbDrone.Api.Resolvers -{ - public class EndTimeResolver : ValueResolver - { - protected override DateTime ResolveCore(Episode source) - { - return source.AirDate.Value.AddMinutes(source.Series.Runtime); - } - } -} diff --git a/NzbDrone.Api/Resolvers/NextAiringResolver.cs b/NzbDrone.Api/Resolvers/NextAiringResolver.cs deleted file mode 100644 index a159b8239..000000000 --- a/NzbDrone.Api/Resolvers/NextAiringResolver.cs +++ /dev/null @@ -1,18 +0,0 @@ -using System; -using System.Linq; -using AutoMapper; - -namespace NzbDrone.Api.Resolvers -{ - public class NextAiringResolver : ValueResolver - { - protected override DateTime? ResolveCore(Core.Tv.Series source) - { - if (String.IsNullOrWhiteSpace(source.AirTime) || !source.NextAiring.HasValue) - return source.NextAiring; - - return source.NextAiring.Value.Add(Convert.ToDateTime(source.AirTime).TimeOfDay) - .AddHours(source.UtcOffset * -1); - } - } -} diff --git a/NzbDrone.Core.Test/MetadataSourceTests/TracktProxyFixture.cs b/NzbDrone.Core.Test/MetadataSourceTests/TracktProxyFixture.cs index e1e30136d..0a73855b4 100644 --- a/NzbDrone.Core.Test/MetadataSourceTests/TracktProxyFixture.cs +++ b/NzbDrone.Core.Test/MetadataSourceTests/TracktProxyFixture.cs @@ -4,6 +4,7 @@ using NUnit.Framework; using NzbDrone.Core.MetadataSource; using NzbDrone.Core.Test.Framework; +using NzbDrone.Core.Tv; namespace NzbDrone.Core.Test.MetadataSourceTests { @@ -18,6 +19,7 @@ public void successful_search(string title) var result = Subject.SearchForNewSeries(title); result.Should().NotBeEmpty(); + result[0].Title.Should().Be(title); } @@ -34,28 +36,51 @@ public void should_be_able_to_get_series_detail() { var details = Subject.GetSeriesInfo(75978); - details.Should().NotBeNull(); - details.Images.Should().NotBeEmpty(); + ValidateSeries(details); } - [Test] - public void none_unique_season_episode_number() - { - var result = Subject.GetEpisodeInfo(75978);//Family guy - - result.GroupBy(e => e.SeasonNumber.ToString("000") + e.EpisodeNumber.ToString("000")) - .Max(e => e.Count()).Should().Be(1); - - result.Select(c => c.TvDbEpisodeId).Should().OnlyHaveUniqueItems(); - } - - - [Test] public void should_be_able_to_get_list_of_episodes() { var details = Subject.GetEpisodeInfo(75978); + details.Should().NotBeEmpty(); + + details.GroupBy(e => e.SeasonNumber.ToString("000") + e.EpisodeNumber.ToString("000")) + .Max(e => e.Count()).Should().Be(1); + + details.Select(c => c.TvDbEpisodeId).Should().OnlyHaveUniqueItems(); + + details.Should().Contain(c => c.SeasonNumber > 0); + details.Should().Contain(c => !string.IsNullOrWhiteSpace(c.Overview)); + + foreach (var episode in details) + { + episode.AirDate.Should().HaveValue(); + episode.AirDate.Value.Kind.Should().Be(DateTimeKind.Utc); + episode.EpisodeNumber.Should().NotBe(0); + episode.Title.Should().NotBeBlank(); + episode.TvDbEpisodeId.Should().NotBe(0); + } + } + + + + private void ValidateSeries(Series series) + { + series.Should().NotBeNull(); + series.Title.Should().NotBeBlank(); + series.Overview.Should().NotBeBlank(); + series.AirTime.Should().NotBeBlank(); + series.FirstAired.Should().HaveValue(); + series.FirstAired.Value.Kind.Should().Be(DateTimeKind.Utc); + series.Images.Should().NotBeEmpty(); + series.ImdbId.Should().NotBeBlank(); + series.Network.Should().NotBeBlank(); + series.Runtime.Should().BeGreaterThan(0); + series.TitleSlug.Should().NotBeBlank(); + series.TvRageId.Should().BeGreaterThan(0); + series.TvdbId.Should().BeGreaterThan(0); } } } diff --git a/NzbDrone.Core/Datastore/Migration/Migration20130324.cs b/NzbDrone.Core/Datastore/Migration/Migration20130324.cs index c0b5685bf..46055442d 100644 --- a/NzbDrone.Core/Datastore/Migration/Migration20130324.cs +++ b/NzbDrone.Core/Datastore/Migration/Migration20130324.cs @@ -40,7 +40,6 @@ protected override void MainDbUpgrade() .WithColumn("Network").AsString().Nullable() .WithColumn("CustomStartDate").AsDateTime().Nullable() .WithColumn("UseSceneNumbering").AsBoolean() - .WithColumn("UtcOffSet").AsInt32() .WithColumn("FirstAired").AsDateTime().Nullable() .WithColumn("NextAiring").AsDateTime().Nullable(); diff --git a/NzbDrone.Core/MetadataSource/Trakt/Actor.cs b/NzbDrone.Core/MetadataSource/Trakt/Actor.cs deleted file mode 100644 index 2c0922770..000000000 --- a/NzbDrone.Core/MetadataSource/Trakt/Actor.cs +++ /dev/null @@ -1,8 +0,0 @@ -namespace NzbDrone.Core.MetadataSource.Trakt -{ - public class Actor - { - public string name { get; set; } - public string character { get; set; } - } -} \ No newline at end of file diff --git a/NzbDrone.Core/MetadataSource/Trakt/Episode.cs b/NzbDrone.Core/MetadataSource/Trakt/Episode.cs index 03eaa8c67..7045f31cb 100644 --- a/NzbDrone.Core/MetadataSource/Trakt/Episode.cs +++ b/NzbDrone.Core/MetadataSource/Trakt/Episode.cs @@ -1,6 +1,4 @@ -using System; - -namespace NzbDrone.Core.MetadataSource.Trakt +namespace NzbDrone.Core.MetadataSource.Trakt { public class Episode { @@ -10,9 +8,10 @@ public class Episode public int tvdb_id { get; set; } public string title { get; set; } public string overview { get; set; } - public DateTime? first_aired { get; set; } + public int first_aired { get; set; } + public string first_aired_iso { get; set; } + public int first_aired_utc { get; set; } public string url { get; set; } public string screen { get; set; } - public Ratings ratings { get; set; } } } \ No newline at end of file diff --git a/NzbDrone.Core/MetadataSource/Trakt/People.cs b/NzbDrone.Core/MetadataSource/Trakt/People.cs deleted file mode 100644 index 5a4a97755..000000000 --- a/NzbDrone.Core/MetadataSource/Trakt/People.cs +++ /dev/null @@ -1,9 +0,0 @@ -using System.Collections.Generic; - -namespace NzbDrone.Core.MetadataSource.Trakt -{ - public class People - { - public List actors { get; set; } - } -} \ No newline at end of file diff --git a/NzbDrone.Core/MetadataSource/Trakt/Ratings.cs b/NzbDrone.Core/MetadataSource/Trakt/Ratings.cs deleted file mode 100644 index 7ca617121..000000000 --- a/NzbDrone.Core/MetadataSource/Trakt/Ratings.cs +++ /dev/null @@ -1,10 +0,0 @@ -namespace NzbDrone.Core.MetadataSource.Trakt -{ - public class Ratings - { - public int percentage { get; set; } - public int votes { get; set; } - public int loved { get; set; } - public int hated { get; set; } - } -} \ No newline at end of file diff --git a/NzbDrone.Core/MetadataSource/Trakt/Show.cs b/NzbDrone.Core/MetadataSource/Trakt/Show.cs index dde25f9d4..bf7745d43 100644 --- a/NzbDrone.Core/MetadataSource/Trakt/Show.cs +++ b/NzbDrone.Core/MetadataSource/Trakt/Show.cs @@ -1,5 +1,4 @@ -using System; -using System.Collections.Generic; +using System.Collections.Generic; namespace NzbDrone.Core.MetadataSource.Trakt { @@ -8,14 +7,18 @@ public class Show public string title { get; set; } public int year { get; set; } public string url { get; set; } - public DateTime? first_aired { get; set; } + public int first_aired { get; set; } + public string first_aired_iso { get; set; } + public int first_aired_utc { get; set; } public string country { get; set; } public string overview { get; set; } public int runtime { get; set; } public string status { get; set; } public string network { get; set; } public string air_day { get; set; } + public string air_day_utc { get; set; } public string air_time { get; set; } + public string air_time_utc { get; set; } public string certification { get; set; } public string imdb_id { get; set; } public int tvdb_id { get; set; } @@ -23,11 +26,6 @@ public class Show public int last_updated { get; set; } public string poster { get; set; } public Images images { get; set; } - public List top_watchers { get; set; } - public List top_episodes { get; set; } - public Ratings ratings { get; set; } - public Stats stats { get; set; } - public People people { get; set; } public List genres { get; set; } public List seasons { get; set; } } diff --git a/NzbDrone.Core/MetadataSource/Trakt/Stats.cs b/NzbDrone.Core/MetadataSource/Trakt/Stats.cs deleted file mode 100644 index ed0243b33..000000000 --- a/NzbDrone.Core/MetadataSource/Trakt/Stats.cs +++ /dev/null @@ -1,14 +0,0 @@ -namespace NzbDrone.Core.MetadataSource.Trakt -{ - public class Stats - { - public int watchers { get; set; } - public int plays { get; set; } - public int scrobbles { get; set; } - public int scrobbles_unique { get; set; } - public int checkins { get; set; } - public int checkins_unique { get; set; } - public int collection { get; set; } - public int collection_unique { get; set; } - } -} \ No newline at end of file diff --git a/NzbDrone.Core/MetadataSource/Trakt/TopEpisode.cs b/NzbDrone.Core/MetadataSource/Trakt/TopEpisode.cs deleted file mode 100644 index 2db3d173e..000000000 --- a/NzbDrone.Core/MetadataSource/Trakt/TopEpisode.cs +++ /dev/null @@ -1,12 +0,0 @@ -namespace NzbDrone.Core.MetadataSource.Trakt -{ - public class TopEpisode - { - public int plays { get; set; } - public int season { get; set; } - public int number { get; set; } - public string title { get; set; } - public string url { get; set; } - public int first_aired { get; set; } - } -} \ No newline at end of file diff --git a/NzbDrone.Core/MetadataSource/Trakt/TopWatcher.cs b/NzbDrone.Core/MetadataSource/Trakt/TopWatcher.cs deleted file mode 100644 index 5dbffdc2e..000000000 --- a/NzbDrone.Core/MetadataSource/Trakt/TopWatcher.cs +++ /dev/null @@ -1,17 +0,0 @@ -namespace NzbDrone.Core.MetadataSource.Trakt -{ - public class TopWatcher - { - public int plays { get; set; } - public string username { get; set; } - public bool @protected { get; set; } - public object full_name { get; set; } - public object gender { get; set; } - public string age { get; set; } - public object location { get; set; } - public object about { get; set; } - public int joined { get; set; } - public string avatar { get; set; } - public string url { get; set; } - } -} \ No newline at end of file diff --git a/NzbDrone.Core/MetadataSource/TraktProxy.cs b/NzbDrone.Core/MetadataSource/TraktProxy.cs index e895050f0..96763657c 100644 --- a/NzbDrone.Core/MetadataSource/TraktProxy.cs +++ b/NzbDrone.Core/MetadataSource/TraktProxy.cs @@ -52,11 +52,11 @@ private static Series MapSeries(Show show) series.TvRageId = show.tvrage_id; series.ImdbId = show.imdb_id; series.Title = show.title; - series.FirstAired = show.first_aired; + series.FirstAired =FromEpoc(show.first_aired_utc); series.Overview = show.overview; series.Runtime = show.runtime; series.Network = show.network; - series.AirTime = show.air_time; + series.AirTime = show.air_time_utc; series.TitleSlug = show.url.ToLower().Replace("http://trakt.tv/show/", ""); series.Status = GetSeriesStatus(show.status); @@ -75,14 +75,14 @@ private static Episode MapEpisode(Trakt.Episode traktEpisode) episode.EpisodeNumber = traktEpisode.number; episode.TvDbEpisodeId = traktEpisode.tvdb_id; episode.Title = traktEpisode.title; - episode.AirDate = traktEpisode.first_aired; + episode.AirDate =FromEpoc(traktEpisode.first_aired_utc); return episode; } private static string GetPosterThumbnailUrl(string posterUrl) { - if(posterUrl.Contains("poster-small.jpg")) return posterUrl; + if (posterUrl.Contains("poster-small.jpg")) return posterUrl; var extension = Path.GetExtension(posterUrl); var withoutExtension = posterUrl.Substring(0, posterUrl.Length - extension.Length); @@ -95,5 +95,12 @@ private static SeriesStatusType GetSeriesStatus(string status) if (status.Equals("Ended", StringComparison.InvariantCultureIgnoreCase)) return SeriesStatusType.Ended; return SeriesStatusType.Continuing; } + + private static DateTime? FromEpoc(long ticks) + { + if (ticks == 0) return null; + + return new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc).AddMilliseconds(ticks); + } } } \ No newline at end of file diff --git a/NzbDrone.Core/NzbDrone.Core.csproj b/NzbDrone.Core/NzbDrone.Core.csproj index 08de40cd8..3483e533a 100644 --- a/NzbDrone.Core/NzbDrone.Core.csproj +++ b/NzbDrone.Core/NzbDrone.Core.csproj @@ -304,16 +304,10 @@ - - - - - - diff --git a/NzbDrone.Core/Tv/Episode.cs b/NzbDrone.Core/Tv/Episode.cs index cb70473bb..962459a11 100644 --- a/NzbDrone.Core/Tv/Episode.cs +++ b/NzbDrone.Core/Tv/Episode.cs @@ -44,17 +44,6 @@ public EpisodeStatuses Status } } - public DateTime? EndTime - { - get - { - if (!AirDate.HasValue) return null; - if (Series == null) return null; - - return AirDate.Value.AddMinutes(Series.Runtime); - } - } - public String SeriesTitle { get; private set; } public Series Series { get; set; } diff --git a/NzbDrone.Core/Tv/EpisodeService.cs b/NzbDrone.Core/Tv/EpisodeService.cs index c3e9f0549..12d68ab8a 100644 --- a/NzbDrone.Core/Tv/EpisodeService.cs +++ b/NzbDrone.Core/Tv/EpisodeService.cs @@ -172,17 +172,10 @@ public void RefreshEpisodeInfo(Series series) episodeToUpdate.TvDbEpisodeId = episode.TvDbEpisodeId; episodeToUpdate.EpisodeNumber = episode.EpisodeNumber; episodeToUpdate.SeasonNumber = episode.SeasonNumber; - episodeToUpdate.AbsoluteEpisodeNumber = episode.AbsoluteEpisodeNumber; episodeToUpdate.Title = episode.Title; episodeToUpdate.Overview = episode.Overview; episodeToUpdate.AirDate = episode.AirDate; - if (!String.IsNullOrWhiteSpace(series.AirTime) && episodeToUpdate.AirDate.HasValue) - { - episodeToUpdate.AirDate = episodeToUpdate.AirDate.Value.Add(Convert.ToDateTime(series.AirTime).TimeOfDay) - .AddHours(series.UtcOffset * -1); - } - successCount++; } catch (Exception e) diff --git a/NzbDrone.Core/Tv/Series.cs b/NzbDrone.Core/Tv/Series.cs index 000243606..54887e409 100644 --- a/NzbDrone.Core/Tv/Series.cs +++ b/NzbDrone.Core/Tv/Series.cs @@ -55,11 +55,7 @@ public string Path } } - //Todo: This should be a double since there are timezones that aren't on a full hour offset - public int UtcOffset { get; set; } - public DateTime? FirstAired { get; set; } public LazyLoaded QualityProfile { get; set; } - public DateTime? NextAiring { get; set; } } } \ No newline at end of file