aboutsummaryrefslogtreecommitdiff
path: root/tests/Jellyfin.MediaEncoding.Keyframes.Tests/FfProbe/FfProbeKeyframeExtractorTests.cs
diff options
context:
space:
mode:
authorcvium <clausvium@gmail.com>2021-09-26 21:07:30 +0200
committercvium <clausvium@gmail.com>2021-09-26 21:07:30 +0200
commit2899b77cd58456470b8dd4d01d3a8c525a9b5911 (patch)
treedecd61105f437fb0c0efc75b02d433b1aca29407 /tests/Jellyfin.MediaEncoding.Keyframes.Tests/FfProbe/FfProbeKeyframeExtractorTests.cs
parent41383e6fe4d2ae80552c1b3df0b469f5416f2d89 (diff)
Implement FfProbeKeyframeExtractor and add tests for it
Diffstat (limited to 'tests/Jellyfin.MediaEncoding.Keyframes.Tests/FfProbe/FfProbeKeyframeExtractorTests.cs')
-rw-r--r--tests/Jellyfin.MediaEncoding.Keyframes.Tests/FfProbe/FfProbeKeyframeExtractorTests.cs28
1 files changed, 28 insertions, 0 deletions
diff --git a/tests/Jellyfin.MediaEncoding.Keyframes.Tests/FfProbe/FfProbeKeyframeExtractorTests.cs b/tests/Jellyfin.MediaEncoding.Keyframes.Tests/FfProbe/FfProbeKeyframeExtractorTests.cs
new file mode 100644
index 000000000..e410fa29f
--- /dev/null
+++ b/tests/Jellyfin.MediaEncoding.Keyframes.Tests/FfProbe/FfProbeKeyframeExtractorTests.cs
@@ -0,0 +1,28 @@
+using System.IO;
+using System.Text.Json;
+using Xunit;
+
+namespace Jellyfin.MediaEncoding.Keyframes.FfProbe
+{
+ public class FfProbeKeyframeExtractorTests
+ {
+ [Theory]
+ [InlineData("keyframes.txt", "keyframes_result.json")]
+ [InlineData("keyframes_streamduration.txt", "keyframes_streamduration_result.json")]
+ public void ParseStream_Valid_Success(string testDataFileName, string resultFileName)
+ {
+ var testDataPath = Path.Combine("FfProbe/Test Data", testDataFileName);
+ var resultPath = Path.Combine("FfProbe/Test Data", resultFileName);
+ var resultFileStream = File.OpenRead(resultPath);
+ var expectedResult = JsonSerializer.Deserialize<KeyframeData>(resultFileStream)!;
+
+ using var fileStream = File.OpenRead(testDataPath);
+ using var streamReader = new StreamReader(fileStream);
+
+ var result = FfProbeKeyframeExtractor.ParseStream(streamReader);
+
+ Assert.Equal(expectedResult.TotalDuration, result.TotalDuration);
+ Assert.Equal(expectedResult.KeyframeTicks, result.KeyframeTicks);
+ }
+ }
+}