aboutsummaryrefslogtreecommitdiffstats
path: root/tests/lib
diff options
context:
space:
mode:
authorJohn Molakvoæ <skjnldsv@users.noreply.github.com>2024-12-11 08:40:58 +0100
committerGitHub <noreply@github.com>2024-12-11 08:40:58 +0100
commit3baa91d8421286952cf1973a7d5d49066484b08a (patch)
treeee28e265e7553e5a11ec628fd93d7ea420fee8dd /tests/lib
parented54713e6abf1b2428f37ca322100bab6a6301be (diff)
parent37199779de89674790b36eb6b0a863b2e6eb567b (diff)
downloadnextcloud-server-3baa91d8421286952cf1973a7d5d49066484b08a.tar.gz
nextcloud-server-3baa91d8421286952cf1973a7d5d49066484b08a.zip
Merge pull request #40394 from nextcloud/updater-change-mimetype-objectstore
Diffstat (limited to 'tests/lib')
-rw-r--r--tests/lib/Files/Cache/UpdaterTest.php35
1 files changed, 35 insertions, 0 deletions
diff --git a/tests/lib/Files/Cache/UpdaterTest.php b/tests/lib/Files/Cache/UpdaterTest.php
index 8b8697fc139..ab46bdd4141 100644
--- a/tests/lib/Files/Cache/UpdaterTest.php
+++ b/tests/lib/Files/Cache/UpdaterTest.php
@@ -8,7 +8,10 @@
namespace Test\Files\Cache;
use OC\Files\Filesystem;
+use OC\Files\ObjectStore\ObjectStoreStorage;
+use OC\Files\ObjectStore\StorageObjectStore;
use OC\Files\Storage\Temporary;
+use OCP\Files\Storage\IStorage;
/**
* Class UpdaterTest
@@ -301,4 +304,36 @@ class UpdaterTest extends \Test\TestCase {
$this->assertEquals($old['mimetype'], $new['mimetype']);
}
}
+
+ public function changeExtensionProvider(): array {
+ return [
+ [new Temporary()],
+ [new ObjectStoreStorage(['objectstore' => new StorageObjectStore(new Temporary())])]
+ ];
+ }
+
+ /**
+ * @dataProvider changeExtensionProvider
+ */
+ public function testChangeExtension(IStorage $storage) {
+ $updater = $storage->getUpdater();
+ $cache = $storage->getCache();
+ $storage->file_put_contents('foo', 'qwerty');
+ $updater->update('foo');
+
+ $bareCached = $cache->get('foo');
+ $this->assertEquals('application/octet-stream', $bareCached->getMimeType());
+
+ $storage->rename('foo', 'foo.txt');
+ $updater->renameFromStorage($storage, 'foo', 'foo.txt');
+
+ $cached = $cache->get('foo.txt');
+ $this->assertEquals('text/plain', $cached->getMimeType());
+
+ $storage->rename('foo.txt', 'foo.md');
+ $updater->renameFromStorage($storage, 'foo.txt', 'foo.md');
+
+ $cachedTarget = $cache->get('foo.md');
+ $this->assertEquals('text/markdown', $cachedTarget->getMimeType());
+ }
}