From dac48456b68262c0ca569ab4f5a3dac6ca323e34 Mon Sep 17 00:00:00 2001 From: Mantas Date: Fri, 19 Apr 2024 15:35:54 +0300 Subject: [PATCH] Improve srt and docx file recognition --- src/Code/Converters/AssConverter.php | 2 +- src/Code/Converters/ConverterContract.php | 2 +- src/Code/Converters/CsvConverter.php | 2 +- src/Code/Converters/DfxpConverter.php | 2 +- src/Code/Converters/DocxReader.php | 20 +++++++++++++++++-- src/Code/Converters/EbuStlReader.php | 2 +- src/Code/Converters/LrcConverter.php | 2 +- src/Code/Converters/RtfReader.php | 2 +- src/Code/Converters/SbvConverter.php | 2 +- src/Code/Converters/SccConverter.php | 2 +- src/Code/Converters/SmiConverter.php | 2 +- src/Code/Converters/SrtConverter.php | 4 ++-- src/Code/Converters/StlConverter.php | 2 +- src/Code/Converters/SubMicroDvdConverter.php | 2 +- src/Code/Converters/SubViewerConverter.php | 2 +- src/Code/Converters/TtmlConverter.php | 2 +- src/Code/Converters/TxtConverter.php | 2 +- src/Code/Converters/TxtQuickTimeConverter.php | 2 +- src/Code/Converters/VttConverter.php | 2 +- src/Code/Helpers.php | 4 ++-- src/Code/Other/DocxToText.php | 3 ++- src/Subtitles.php | 2 +- tests/PublicInterfaceTest.php | 2 +- tests/formats/AssTest.php | 4 ++-- tests/formats/CsvTest.php | 8 ++++---- tests/formats/DfxpTest.php | 2 +- tests/formats/DocxTest.php | 13 ++++++++++-- tests/formats/LrcTest.php | 4 ++-- tests/formats/SbvTest.php | 2 +- tests/formats/SccTest.php | 2 +- tests/formats/SmiTest.php | 2 +- tests/formats/SrtTest.php | 14 ++++++++++++- tests/formats/StlTest.php | 2 +- tests/formats/SubMicroDvdTest.php | 2 +- tests/formats/SubViewerTest.php | 2 +- tests/formats/TtmlTest.php | 2 +- tests/formats/TxtQuickTimeTest.php | 2 +- tests/formats/VttTest.php | 4 ++-- 38 files changed, 86 insertions(+), 48 deletions(-) diff --git a/src/Code/Converters/AssConverter.php b/src/Code/Converters/AssConverter.php index 7aa5e63..74fe9c6 100644 --- a/src/Code/Converters/AssConverter.php +++ b/src/Code/Converters/AssConverter.php @@ -6,7 +6,7 @@ class AssConverter implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return preg_match('/\[Script Info\]\R/m', $file_content) === 1; } diff --git a/src/Code/Converters/ConverterContract.php b/src/Code/Converters/ConverterContract.php index 0dc8a57..4225ff4 100644 --- a/src/Code/Converters/ConverterContract.php +++ b/src/Code/Converters/ConverterContract.php @@ -10,7 +10,7 @@ interface ConverterContract * @param string $file_content * @return bool */ - public function canParseFileContent($file_content); + public function canParseFileContent($file_content, $original_file_content); /** * Converts file content (.srt, .stl... file content) to library's "internal format" diff --git a/src/Code/Converters/CsvConverter.php b/src/Code/Converters/CsvConverter.php index d82ce58..d019cbf 100644 --- a/src/Code/Converters/CsvConverter.php +++ b/src/Code/Converters/CsvConverter.php @@ -13,7 +13,7 @@ private static function timeRegex() return rtrim(TxtConverter::$time_regexp, '/') . '|(\d+)/'; } - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { $csv = self::csvToArray(trim($file_content)); diff --git a/src/Code/Converters/DfxpConverter.php b/src/Code/Converters/DfxpConverter.php index 20286d1..24f8e35 100644 --- a/src/Code/Converters/DfxpConverter.php +++ b/src/Code/Converters/DfxpConverter.php @@ -4,7 +4,7 @@ class DfxpConverter implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return (preg_match('/xmlns="http:\/\/www\.w3\.org\/ns\/ttml"/m', $file_content) === 1 && preg_match('/xml:id="d1"/m', $file_content) === 1) // old netflix format; diff --git a/src/Code/Converters/DocxReader.php b/src/Code/Converters/DocxReader.php index 1741ae4..a245add 100644 --- a/src/Code/Converters/DocxReader.php +++ b/src/Code/Converters/DocxReader.php @@ -7,9 +7,25 @@ class DocxReader implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { - return strpos($file_content, 'PK') === 0 && strpos($file_content, '[Content_Types].xml') !== false; + if (strpos($original_file_content, 'PK') === 0 && strpos($original_file_content, '[Content_Types].xml') !== false) { + $tmp_file = tempnam(sys_get_temp_dir(), 'prefix_'); + file_put_contents($tmp_file, $original_file_content); + + $zip = new \ZipArchive(); + $opened = $zip->open($tmp_file, \ZipArchive::RDONLY); // zip archive can only open real file + if ($opened === true) { + $zip->close(); + } + unlink($tmp_file); + + if ($opened === true) { + return true; + } + } + + return false; } public function fileContentToInternalFormat($file_content, $original_file_content) diff --git a/src/Code/Converters/EbuStlReader.php b/src/Code/Converters/EbuStlReader.php index b8efd94..5d338d7 100644 --- a/src/Code/Converters/EbuStlReader.php +++ b/src/Code/Converters/EbuStlReader.php @@ -6,7 +6,7 @@ class EbuStlReader implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return substr($file_content, 3, 3) === 'STL' && is_numeric(substr($file_content, 6, 2)); } diff --git a/src/Code/Converters/LrcConverter.php b/src/Code/Converters/LrcConverter.php index d6bce5b..dc00e2a 100644 --- a/src/Code/Converters/LrcConverter.php +++ b/src/Code/Converters/LrcConverter.php @@ -9,7 +9,7 @@ class LrcConverter implements ConverterContract protected static $regexp = '/\[\s*(\d{2}:\d{2}(?:[:.]\d{1,3})?)\s*]/'; protected static $time_offset_regexp = '/\[offset:\s*\+?(-?\d+)\s*]/s'; - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { // only select when there is text after the timestamp // do not select files that have timestamp and text somewhere on the other line diff --git a/src/Code/Converters/RtfReader.php b/src/Code/Converters/RtfReader.php index 6886184..cab2120 100644 --- a/src/Code/Converters/RtfReader.php +++ b/src/Code/Converters/RtfReader.php @@ -9,7 +9,7 @@ class RtfReader implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return strpos($file_content, '{\rtf1') === 0; } diff --git a/src/Code/Converters/SbvConverter.php b/src/Code/Converters/SbvConverter.php index aeab954..6c63c13 100644 --- a/src/Code/Converters/SbvConverter.php +++ b/src/Code/Converters/SbvConverter.php @@ -4,7 +4,7 @@ class SbvConverter implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return preg_match('/^\d{1,2}:\d{2}:\d{2}\.\d{3},\d{1,2}:\d{2}:\d{2}\.\d{3}\R(.*)/m', $file_content) === 1; } diff --git a/src/Code/Converters/SccConverter.php b/src/Code/Converters/SccConverter.php index ce3b4f9..ab08bfb 100644 --- a/src/Code/Converters/SccConverter.php +++ b/src/Code/Converters/SccConverter.php @@ -29,7 +29,7 @@ class SccConverter implements ConverterContract 23.976, ]; - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return preg_match('/Scenarist_SCC V1.0/', $file_content) === 1; } diff --git a/src/Code/Converters/SmiConverter.php b/src/Code/Converters/SmiConverter.php index a7fab81..bbedd5f 100644 --- a/src/Code/Converters/SmiConverter.php +++ b/src/Code/Converters/SmiConverter.php @@ -4,7 +4,7 @@ class SmiConverter implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return preg_match('//m', $file_content) === 1; } diff --git a/src/Code/Converters/SrtConverter.php b/src/Code/Converters/SrtConverter.php index d9f6c5c..5eb77e7 100644 --- a/src/Code/Converters/SrtConverter.php +++ b/src/Code/Converters/SrtConverter.php @@ -7,9 +7,9 @@ class SrtConverter implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { - return preg_match('/^0*\d?\R(\d{1,2}:\d{2}:\d{2},\d{1,3}\s*-->\s*\d{1,2}:\d{2}:\d{2},\d{1,3})\R(.+)$/m', $file_content) === 1; + return preg_match('/^0*\d?\R(\d{1,2}:\d{2}:\d{2}[,\.]\d{1,3}\s*-->\s*\d{1,2}:\d{2}:\d{2}[,\.]\d{1,3})\R(.+)$/m', $file_content) === 1; } /** diff --git a/src/Code/Converters/StlConverter.php b/src/Code/Converters/StlConverter.php index dd5c2f6..1913ed6 100644 --- a/src/Code/Converters/StlConverter.php +++ b/src/Code/Converters/StlConverter.php @@ -4,7 +4,7 @@ class StlConverter implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return preg_match('/^\d{2}:\d{2}:\d{2}:\d{2}\s,\s\d{2}:\d{2}:\d{2}:\d{2}\s,.+/m', $file_content) === 1; } diff --git a/src/Code/Converters/SubMicroDvdConverter.php b/src/Code/Converters/SubMicroDvdConverter.php index 1d34971..1cc1b9f 100644 --- a/src/Code/Converters/SubMicroDvdConverter.php +++ b/src/Code/Converters/SubMicroDvdConverter.php @@ -10,7 +10,7 @@ class SubMicroDvdConverter implements ConverterContract static $pattern = '/(?:\{|\[)(?\d+)(?:\}|\])(?:\{|\[)(?\d+)(?:\}|\])(?.+)/'; - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return preg_match(self::$pattern, $file_content, $matches); } diff --git a/src/Code/Converters/SubViewerConverter.php b/src/Code/Converters/SubViewerConverter.php index 5461178..4f4a859 100644 --- a/src/Code/Converters/SubViewerConverter.php +++ b/src/Code/Converters/SubViewerConverter.php @@ -4,7 +4,7 @@ class SubViewerConverter implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return preg_match('/^(\d{2}:\d{2}:\d{2}\.\d{2}),(\d{2}:\d{2}:\d{2}\.\d{2})\R(.*)$/m', $file_content) === 1; } diff --git a/src/Code/Converters/TtmlConverter.php b/src/Code/Converters/TtmlConverter.php index be0a672..a28bdc3 100644 --- a/src/Code/Converters/TtmlConverter.php +++ b/src/Code/Converters/TtmlConverter.php @@ -7,7 +7,7 @@ class TtmlConverter implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { $first_line = explode("\n", $file_content)[0]; diff --git a/src/Code/Converters/TxtConverter.php b/src/Code/Converters/TxtConverter.php index 78b2faf..a08bc71 100644 --- a/src/Code/Converters/TxtConverter.php +++ b/src/Code/Converters/TxtConverter.php @@ -10,7 +10,7 @@ class TxtConverter implements ConverterContract public static $time_regexp = '/(?:\d{2}[:;])(?:\d{1,2}[:;])(?:\d{1,2}[:;])\d{1,3}|(?:\d{1,2}[:;])?(?:\d{1,2}[:;])\d{1,3}(?:[.,]\d+)?(?!\d)|\d{1,5}[.,]\d{1,3}/'; private static $any_letter_regex = '/\p{L}/u'; - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return self::hasText($file_content) && !Helpers::strContains($file_content, "\x00"); // not a binary file } diff --git a/src/Code/Converters/TxtQuickTimeConverter.php b/src/Code/Converters/TxtQuickTimeConverter.php index d97b429..bc7f7a7 100644 --- a/src/Code/Converters/TxtQuickTimeConverter.php +++ b/src/Code/Converters/TxtQuickTimeConverter.php @@ -5,7 +5,7 @@ // qt.txt class TxtQuickTimeConverter implements ConverterContract { - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { return preg_match('/{QTtext}/m', $file_content) === 1; } diff --git a/src/Code/Converters/VttConverter.php b/src/Code/Converters/VttConverter.php index 104025a..a64279f 100644 --- a/src/Code/Converters/VttConverter.php +++ b/src/Code/Converters/VttConverter.php @@ -9,7 +9,7 @@ class VttConverter implements ConverterContract { protected static $time_regexp = '((?:\d{2}:){1,2}\d{2}\.\d{3})\s+-->\s+((?:\d{2}:){1,2}\d{2}\.\d{3})'; - public function canParseFileContent($file_content) + public function canParseFileContent($file_content, $original_file_content) { $lines = explode("\n", $file_content); diff --git a/src/Code/Helpers.php b/src/Code/Helpers.php index 85b1df5..801386d 100644 --- a/src/Code/Helpers.php +++ b/src/Code/Helpers.php @@ -54,14 +54,14 @@ public static function getConverterByFormat($format) throw new \Exception("Can't find suitable converter, for format: $format"); } - public static function getConverterByFileContent($file_content) + public static function getConverterByFileContent($file_content, $original_file_content) { foreach (Subtitles::$formats as $row) { $class_name = $row['class']; $full_class_name = $class_name; /** @var ConverterContract $converter */ $converter = new $full_class_name(); - if ($converter->canParseFileContent($file_content)) { + if ($converter->canParseFileContent($file_content, $original_file_content)) { return $converter; } } diff --git a/src/Code/Other/DocxToText.php b/src/Code/Other/DocxToText.php index 40c0574..956197f 100644 --- a/src/Code/Other/DocxToText.php +++ b/src/Code/Other/DocxToText.php @@ -38,7 +38,8 @@ private function __construct($file_content) $zip = new \ZipArchive(); $opened = $zip->open($tmp_file, \ZipArchive::RDONLY); // zip archive can only open real file if ($opened !== true) { - throw new \Exception(); + unlink($tmp_file); + throw new \Exception("Can't open zip"); } $this->zip = $zip; $this->tmp_path = $tmp_file; diff --git a/src/Subtitles.php b/src/Subtitles.php index 67400cf..07676b8 100644 --- a/src/Subtitles.php +++ b/src/Subtitles.php @@ -225,7 +225,7 @@ public static function loadFromString($string, $strict = true) $modified_string = Helpers::normalizeNewLines($modified_string); $converter->input = $modified_string; - $input_converter = Helpers::getConverterByFileContent($converter->input); + $input_converter = Helpers::getConverterByFileContent($converter->input, $string); $internal_format = $input_converter->fileContentToInternalFormat($converter->input, $string); // remove empty lines diff --git a/tests/PublicInterfaceTest.php b/tests/PublicInterfaceTest.php index 04ac51b..eb89faa 100644 --- a/tests/PublicInterfaceTest.php +++ b/tests/PublicInterfaceTest.php @@ -31,7 +31,7 @@ public function testConvertUsingThirdParameter() @unlink($temporary_srt_path); Subtitles::convert($srt_path, $temporary_srt_path, ['output_format' => 'vtt']); - $converter = Helpers::getConverterByFileContent(file_get_contents($temporary_srt_path)); + $converter = Helpers::getConverterByFileContent(file_get_contents($temporary_srt_path), file_get_contents($temporary_srt_path)); unlink($temporary_srt_path); $this->assertEquals(VttConverter::class, get_class($converter)); diff --git a/tests/formats/AssTest.php b/tests/formats/AssTest.php index 6e65b69..0898817 100644 --- a/tests/formats/AssTest.php +++ b/tests/formats/AssTest.php @@ -16,14 +16,14 @@ class AssTest extends TestCase { public function testAss() { $content = file_get_contents('./tests/files/ass.ass'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === AssConverter::class); } public function testThisIsNotAssFormat() { $content = '[Script Info]'; - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) !== AssConverter::class); } diff --git a/tests/formats/CsvTest.php b/tests/formats/CsvTest.php index 1529eeb..aac348d 100644 --- a/tests/formats/CsvTest.php +++ b/tests/formats/CsvTest.php @@ -18,7 +18,7 @@ public function testRecognizesCsvFormat() $csv = 'Start,End,Text 137.44,140.375,"Senator, we\'re making our final approach into Coruscant." 3740.476,3742.501,"Very good, Lieutenant."'; - $converter = Helpers::getConverterByFileContent($csv); + $converter = Helpers::getConverterByFileContent($csv, $csv); $this->assertTrue(get_class($converter) === CsvConverter::class, get_class($converter)); } @@ -26,7 +26,7 @@ public function testDoesntSelectNonCsvFormat() { $csv = '0:00:15.1,0:00:17.4 Herkese merhaba. 0:00:17.4,0:00:20.7 Bu videoda Microsoft office ürünlerinin'; - $converter = Helpers::getConverterByFileContent($csv); + $converter = Helpers::getConverterByFileContent($csv, $csv); $this->assertTrue(get_class($converter) !== CsvConverter::class, get_class($converter)); } @@ -214,7 +214,7 @@ public function testDifferentElementCountShouldntBeInterpretedAsCsv() $csv = 'Start,End,Text hi 3740.476,3742.501,"Very good, Lieutenant."'; - $converter = Helpers::getConverterByFileContent($csv); + $converter = Helpers::getConverterByFileContent($csv, $csv); $this->assertTrue(get_class($converter) !== CsvConverter::class, get_class($converter)); } public function testShouldntThrowException() @@ -222,7 +222,7 @@ public function testShouldntThrowException() $csv = '1,a ' . ' ' . ' 2,b'; - $converter = Helpers::getConverterByFileContent($csv); + $converter = Helpers::getConverterByFileContent($csv, $csv); $this->assertTrue(get_class($converter) !== CsvConverter::class, get_class($converter)); } } \ No newline at end of file diff --git a/tests/formats/DfxpTest.php b/tests/formats/DfxpTest.php index 016e393..69e97e0 100644 --- a/tests/formats/DfxpTest.php +++ b/tests/formats/DfxpTest.php @@ -15,7 +15,7 @@ class DfxpTest extends TestCase { public function testRecognizesDfxp() { $content = file_get_contents('./tests/files/dfxp.dfxp'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === DfxpConverter::class); } diff --git a/tests/formats/DocxTest.php b/tests/formats/DocxTest.php index 2c1d7c8..ab09b10 100644 --- a/tests/formats/DocxTest.php +++ b/tests/formats/DocxTest.php @@ -2,15 +2,16 @@ namespace Formats; +use Done\Subtitles\Code\Converters\DocxReader; +use Done\Subtitles\Code\Helpers; +use Done\Subtitles\Code\UserException; use Done\Subtitles\Subtitles; use PHPUnit\Framework\TestCase; use Helpers\AdditionalAssertionsTrait; class DocxTest extends TestCase { - use AdditionalAssertionsTrait; - public function testParsesDocxFile() { $content = file_get_contents('./tests/files/docx.docx'); @@ -21,4 +22,12 @@ public function testParsesDocxFile() ->getInternalFormat(); $this->assertInternalFormatsEqual($expected, $actual); } + + public function testCorruptedZip() + { + $this->expectExceptionMessage("Can't find suitable converter for the file"); + + $content = file_get_contents('./tests/files/corrupted.zip'); + Helpers::getConverterByFileContent($content, $content); + } } \ No newline at end of file diff --git a/tests/formats/LrcTest.php b/tests/formats/LrcTest.php index f0cdce4..ad14796 100644 --- a/tests/formats/LrcTest.php +++ b/tests/formats/LrcTest.php @@ -16,7 +16,7 @@ class LrcTest extends TestCase public function testRecognizeLrc() { $content = file_get_contents('./tests/files/lrc.lrc'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === LrcConverter::class); } @@ -33,7 +33,7 @@ public function testNotLrc() // let other converter handle invalid lrc Main Chaand Launga Solah Satrah Sitaare Sang Baandh Launga'; - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) !== LrcConverter::class); } diff --git a/tests/formats/SbvTest.php b/tests/formats/SbvTest.php index bf624ee..7ce7524 100644 --- a/tests/formats/SbvTest.php +++ b/tests/formats/SbvTest.php @@ -19,7 +19,7 @@ public function testRecognizesSbv() Don’t think that you can just ignore them because they’re not your children or relatives. TEXT; - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === SbvConverter::class); $this->assertTrue(true); } diff --git a/tests/formats/SccTest.php b/tests/formats/SccTest.php index 2ac298c..351d40f 100644 --- a/tests/formats/SccTest.php +++ b/tests/formats/SccTest.php @@ -16,7 +16,7 @@ class SccTest extends TestCase { public function testRecognizesScc() { $content = file_get_contents('./tests/files/scc.scc'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === SccConverter::class); } diff --git a/tests/formats/SmiTest.php b/tests/formats/SmiTest.php index 0570466..e8c129f 100644 --- a/tests/formats/SmiTest.php +++ b/tests/formats/SmiTest.php @@ -15,7 +15,7 @@ class SmiTest extends TestCase { public function testRecognizesSmi() { $content = file_get_contents('./tests/files/smi.smi'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === SmiConverter::class); } diff --git a/tests/formats/SrtTest.php b/tests/formats/SrtTest.php index beefd98..6b2ebf2 100644 --- a/tests/formats/SrtTest.php +++ b/tests/formats/SrtTest.php @@ -16,10 +16,22 @@ class SrtTest extends TestCase { public function testRecognizesSrt() { $content = file_get_contents('./tests/files/srt.srt'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === SrtConverter::class); } + public function testRecognizesSrtWithDot() + { + $content = <<< TEXT +1 +00:00:00.000 --> 00:00:01.000 +a +TEXT; + $converter = Helpers::getConverterByFileContent($content, $content); + + $this->assertEquals(SrtConverter::class, get_class($converter)); + } + public function testConvertingFileFromSrtToSrtDoesNotChangeItContent() { $srt_path = './tests/files/srt.srt'; diff --git a/tests/formats/StlTest.php b/tests/formats/StlTest.php index f3c7489..a6d0ae4 100644 --- a/tests/formats/StlTest.php +++ b/tests/formats/StlTest.php @@ -15,7 +15,7 @@ class StlTest extends TestCase { public function testRecognizesStl() { $content = file_get_contents('./tests/files/stl.stl'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === StlConverter::class); } diff --git a/tests/formats/SubMicroDvdTest.php b/tests/formats/SubMicroDvdTest.php index cbe1686..7fe67da 100644 --- a/tests/formats/SubMicroDvdTest.php +++ b/tests/formats/SubMicroDvdTest.php @@ -15,7 +15,7 @@ class SubMicroDvdTest extends TestCase { public function testRecognizesSub() { $content = file_get_contents('./tests/files/sub_microdvd.sub'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === SubMicroDvdConverter::class); } diff --git a/tests/formats/SubViewerTest.php b/tests/formats/SubViewerTest.php index 227c8ec..ff8afae 100644 --- a/tests/formats/SubViewerTest.php +++ b/tests/formats/SubViewerTest.php @@ -15,7 +15,7 @@ class SubViewerTest extends TestCase { public function testRecognizesSub() { $content = file_get_contents('./tests/files/sub_viewer.sub'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === SubViewerConverter::class); } diff --git a/tests/formats/TtmlTest.php b/tests/formats/TtmlTest.php index d1c39ba..7ab6f52 100644 --- a/tests/formats/TtmlTest.php +++ b/tests/formats/TtmlTest.php @@ -16,7 +16,7 @@ class TtmlTest extends TestCase { public function testRecognizesTtml() { $content = file_get_contents('./tests/files/ttml.ttml'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertEquals(TtmlConverter::class, get_class($converter)); } diff --git a/tests/formats/TxtQuickTimeTest.php b/tests/formats/TxtQuickTimeTest.php index 928c9f8..ddaa00b 100644 --- a/tests/formats/TxtQuickTimeTest.php +++ b/tests/formats/TxtQuickTimeTest.php @@ -31,7 +31,7 @@ class TxtQuickTimeTest extends TestCase { public function testRecognizesTxtQuictime() { $content = $this->qttxt; - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertEquals(TxtQuickTimeConverter::class, get_class($converter)); } diff --git a/tests/formats/VttTest.php b/tests/formats/VttTest.php index b803ebb..520f73d 100644 --- a/tests/formats/VttTest.php +++ b/tests/formats/VttTest.php @@ -17,7 +17,7 @@ class VttTest extends TestCase { public function testRecognizesVtt() { $content = file_get_contents('./tests/files/vtt.vtt'); - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) === VttConverter::class); } @@ -25,7 +25,7 @@ public function testDoesntTakeFilesMentioningVtt() { $content = 'something about WEBVTT'; - $converter = Helpers::getConverterByFileContent($content); + $converter = Helpers::getConverterByFileContent($content, $content); $this->assertTrue(get_class($converter) !== VttConverter::class); }