<?php namespace SilverStripe\TextExtraction\Tests; use SilverStripe\Assets\File; use SilverStripe\Core\Config\Config; use SilverStripe\Dev\SapphireTest; use SilverStripe\TextExtraction\Cache\FileTextCache; use SilverStripe\TextExtraction\Extension\FileTextExtractable; class FileTextExtractableTest extends SapphireTest { protected $usesDatabase = true; protected static $required_extensions = [ File::class => [ FileTextExtractable::class, ], ]; protected function setUp(): void { parent::setUp(); // Ensure that html is a valid extension Config::modify()->merge(File::class, 'allowed_extensions', ['html']); // Create a copy of the file, as it may be clobbered by the test // ($file->extractFileAsText() calls $file->write) copy( dirname(__FILE__) . '/fixtures/test1.html', dirname(__FILE__) . '/fixtures/test1-copy.html' ); } protected function tearDown(): void { if (file_exists(dirname(__FILE__) . '/fixtures/test1-copy.html')) { unlink(dirname(__FILE__) . '/fixtures/test1-copy.html'); } parent::tearDown(); } public function testExtractFileAsText() { // Use HTML, since the extractor is always available /** @var File&FileTextExtractable $file */ $file = new File(['Name' => 'test1-copy.html']); $file->setTextCache(new FileTextCache\Database()); $file->setFromLocalFile(dirname(__FILE__) . '/fixtures/test1-copy.html'); $file->write(); $content = $file->extractFileAsText(); $this->assertNotNull($content); $this->assertStringContainsString('Test Headline', $content); $this->assertStringContainsString('Test Text', $content); $this->assertEquals($content, $file->FileContentCache); } }