79 lines
2.1 KiB
C#
Raw Permalink Normal View History

2024-10-25 14:31:50 -04:00
// Copyright (C) 2024 Intro-Skipper contributors <intro-skipper.org>
// SPDX-License-Identifier: GPL-3.0-only.
2024-10-25 14:15:12 -04:00
namespace IntroSkipper.Tests;
2022-11-01 00:53:56 -05:00
using System;
using System.Collections.Generic;
using IntroSkipper.Analyzers;
using IntroSkipper.Data;
2022-11-02 17:06:21 -05:00
using Microsoft.Extensions.Logging;
2022-11-01 00:53:56 -05:00
using Xunit;
public class TestBlackFrames
{
[FactSkipFFmpegTests]
public void TestBlackFrameDetection()
{
2022-11-02 17:06:21 -05:00
var range = 1e-5;
2022-11-01 00:53:56 -05:00
var expected = new List<BlackFrame>();
Recaps and Previews Support (#357) * Recaps and Previews Support * Add draft UI of preview / recap edit * remove intro/credit tasks * Update configPage.html * rename task * Reorganize settings by relation * More standardized formatting * Some additional formatting * fix a typo * Update configPage.html * Allow missing recap / prview data * More risk to corrupt than benefit * Update TimeStamps.cs * Update PluginConfiguration.cs * Update configPage.html * Update PluginConfiguration.cs * Add chapter regex to settings * Move all UI into UI section * Move ending seconds with similar * Add default * fixes * Update SkipIntroController.cs * Autoskip all segments * Check if adjacent segment * Update AutoSkip.cs * Update AutoSkip.cs * Settings apply to all segment types * Update SegmentProvider * Update configPage.html Whoops * Update Plugin.cs * Update AutoSkip.cs * Let’s call it missing instead * Update BaseItemAnalyzerTask.cs * Update BaseItemAnalyzerTask.cs * Update BaseItemAnalyzerTask.cs * Move "select" all below list * Clarify button wording * Update configPage.html * Nope, long client list will hide it * Simplify wording * Update QueuedEpisode.cs * fix unit test for ffmpeg7 * Add migration * Restore DataContract * update * Update configPage.html * remove analyzed status * Update AutoSkip.cs * Update configPage.html typo * Store analyzed items in seasoninfo * Update VisualizationController.cs * update * Update IntroSkipperDbContext.cs * Add preview / recap delete * This keeps changing itself * Update SkipIntroController.cs * Rather add it to be removed --------- Co-authored-by: rlauu <46294892+rlauu@users.noreply.github.com> Co-authored-by: TwistedUmbrellaX <1173913+AbandonedCart@users.noreply.github.com> Co-authored-by: Kilian von Pflugk <github@jumoog.io>
2024-11-21 15:42:55 +01:00
expected.AddRange(CreateFrameSequence(2, 3));
2022-11-01 00:53:56 -05:00
expected.AddRange(CreateFrameSequence(5, 6));
expected.AddRange(CreateFrameSequence(8, 9.96));
2024-09-25 17:23:25 +02:00
var actual = FFmpegWrapper.DetectBlackFrames(QueueFile("rainbow.mp4"), new(0, 10), 85);
2022-11-01 00:53:56 -05:00
for (var i = 0; i < expected.Count; i++)
{
var (e, a) = (expected[i], actual[i]);
Assert.Equal(e.Percentage, a.Percentage);
2022-11-02 17:06:21 -05:00
Assert.InRange(a.Time, e.Time - range, e.Time + range);
2022-11-01 00:53:56 -05:00
}
}
2022-11-02 17:06:21 -05:00
[FactSkipFFmpegTests]
public void TestEndCreditDetection()
{
2024-05-19 17:49:43 +02:00
// new strategy new range
var range = 3;
2022-11-29 20:11:22 -06:00
2022-11-02 17:06:21 -05:00
var analyzer = CreateBlackFrameAnalyzer();
2024-09-25 17:23:25 +02:00
var episode = QueueFile("credits.mp4");
2022-11-02 17:06:21 -05:00
episode.Duration = (int)new TimeSpan(0, 5, 30).TotalSeconds;
Recaps and Previews Support (#357) * Recaps and Previews Support * Add draft UI of preview / recap edit * remove intro/credit tasks * Update configPage.html * rename task * Reorganize settings by relation * More standardized formatting * Some additional formatting * fix a typo * Update configPage.html * Allow missing recap / prview data * More risk to corrupt than benefit * Update TimeStamps.cs * Update PluginConfiguration.cs * Update configPage.html * Update PluginConfiguration.cs * Add chapter regex to settings * Move all UI into UI section * Move ending seconds with similar * Add default * fixes * Update SkipIntroController.cs * Autoskip all segments * Check if adjacent segment * Update AutoSkip.cs * Update AutoSkip.cs * Settings apply to all segment types * Update SegmentProvider * Update configPage.html Whoops * Update Plugin.cs * Update AutoSkip.cs * Let’s call it missing instead * Update BaseItemAnalyzerTask.cs * Update BaseItemAnalyzerTask.cs * Update BaseItemAnalyzerTask.cs * Move "select" all below list * Clarify button wording * Update configPage.html * Nope, long client list will hide it * Simplify wording * Update QueuedEpisode.cs * fix unit test for ffmpeg7 * Add migration * Restore DataContract * update * Update configPage.html * remove analyzed status * Update AutoSkip.cs * Update configPage.html typo * Store analyzed items in seasoninfo * Update VisualizationController.cs * update * Update IntroSkipperDbContext.cs * Add preview / recap delete * This keeps changing itself * Update SkipIntroController.cs * Rather add it to be removed --------- Co-authored-by: rlauu <46294892+rlauu@users.noreply.github.com> Co-authored-by: TwistedUmbrellaX <1173913+AbandonedCart@users.noreply.github.com> Co-authored-by: Kilian von Pflugk <github@jumoog.io>
2024-11-21 15:42:55 +01:00
var result = analyzer.AnalyzeMediaFile(episode, 240, 85);
2022-11-02 17:06:21 -05:00
Assert.NotNull(result);
Assert.InRange(result.Start, 300 - range, 300 + range);
2022-11-02 17:06:21 -05:00
}
2024-09-25 17:23:25 +02:00
private static QueuedEpisode QueueFile(string path)
2022-11-01 00:53:56 -05:00
{
return new()
{
EpisodeId = Guid.NewGuid(),
2022-11-02 17:06:21 -05:00
Name = path,
2022-11-01 00:53:56 -05:00
Path = "../../../video/" + path
};
}
2024-09-25 17:23:25 +02:00
private static BlackFrame[] CreateFrameSequence(double start, double end)
2022-11-01 00:53:56 -05:00
{
var frames = new List<BlackFrame>();
for (var i = start; i < end; i += 0.04)
{
frames.Add(new(100, i));
}
2024-09-25 17:23:25 +02:00
return [.. frames];
2022-11-01 00:53:56 -05:00
}
2022-11-02 17:06:21 -05:00
2024-09-25 17:23:25 +02:00
private static BlackFrameAnalyzer CreateBlackFrameAnalyzer()
2022-11-02 17:06:21 -05:00
{
var logger = new LoggerFactory().CreateLogger<BlackFrameAnalyzer>();
return new(logger);
}
2022-11-01 00:53:56 -05:00
}