aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorAndy Scherzinger <info@andy-scherzinger.de>2024-09-20 19:14:17 +0200
committerGitHub <noreply@github.com>2024-09-20 19:14:17 +0200
commit3009da3722072fd7a37fd714197d175a02a74781 (patch)
tree8323732321ee467b58a58eb49140b5566a736b87 /tests
parent2ba3f7ed5ccc316b1367d31d6bedb8873253e3e5 (diff)
parentef7e857881b72b607f36a41c9f178c12db068b7a (diff)
downloadnextcloud-server-3009da3722072fd7a37fd714197d175a02a74781.tar.gz
nextcloud-server-3009da3722072fd7a37fd714197d175a02a74781.zip
Merge pull request #43968 from exi/custom-binary-search-paths
feat: make search path for BinaryFinder customizable.
Diffstat (limited to 'tests')
-rw-r--r--tests/lib/BinaryFinderTest.php84
1 files changed, 84 insertions, 0 deletions
diff --git a/tests/lib/BinaryFinderTest.php b/tests/lib/BinaryFinderTest.php
new file mode 100644
index 00000000000..42306e49eac
--- /dev/null
+++ b/tests/lib/BinaryFinderTest.php
@@ -0,0 +1,84 @@
+<?php
+
+declare(strict_types = 1);
+/**
+ * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
+ */
+
+namespace Test;
+
+use OC\BinaryFinder;
+use OC\Memcache\ArrayCache;
+use OCP\ICache;
+use OCP\ICacheFactory;
+use OCP\IConfig;
+
+class BinaryFinderTest extends TestCase {
+ private ICache $cache;
+ private ICacheFactory $cacheFactory;
+ private $oldEnv;
+
+ protected function setUp(): void {
+ $this->oldEnv = getenv('PATH');
+ // BinaryFinder always includes the "PATH" environment variable into the search path,
+ // which we want to avoid in this test because they are not usually found in webserver
+ // deployments.
+ putenv('PATH=""');
+ $this->cacheFactory = $this->createMock(ICacheFactory::class);
+ $this->cache = new ArrayCache();
+ $this->cacheFactory->method('createLocal')->with('findBinaryPath')->willReturn($this->cache);
+ }
+
+ protected function tearDown(): void {
+ putenv('PATH=' . $this->oldEnv);
+ }
+
+ public function testDefaultFindsCat() {
+ $config = $this->createMock(IConfig::class);
+ $config
+ ->method('getSystemValue')
+ ->with('binary_search_paths', $this->anything())
+ ->will($this->returnCallback(function ($key, $default) {
+ return $default;
+ }));
+ $finder = new BinaryFinder($this->cacheFactory, $config);
+ $this->assertEquals($finder->findBinaryPath('cat'), '/usr/bin/cat');
+ $this->assertEquals($this->cache->get('cat'), '/usr/bin/cat');
+ }
+
+ public function testDefaultDoesNotFindCata() {
+ $config = $this->createMock(IConfig::class);
+ $config
+ ->method('getSystemValue')
+ ->with('binary_search_paths', $this->anything())
+ ->will($this->returnCallback(function ($key, $default) {
+ return $default;
+ }));
+ $finder = new BinaryFinder($this->cacheFactory, $config);
+ $this->assertFalse($finder->findBinaryPath('cata'));
+ $this->assertFalse($this->cache->get('cata'));
+ }
+
+ public function testCustomPathFindsCat() {
+ $config = $this->createMock(IConfig::class);
+ $config
+ ->method('getSystemValue')
+ ->with('binary_search_paths', $this->anything())
+ ->willReturn(['/usr/bin']);
+ $finder = new BinaryFinder($this->cacheFactory, $config);
+ $this->assertEquals($finder->findBinaryPath('cat'), '/usr/bin/cat');
+ $this->assertEquals($this->cache->get('cat'), '/usr/bin/cat');
+ }
+
+ public function testWrongCustomPathDoesNotFindCat() {
+ $config = $this->createMock(IConfig::class);
+ $config
+ ->method('getSystemValue')
+ ->with('binary_search_paths')
+ ->willReturn(['/wrong']);
+ $finder = new BinaryFinder($this->cacheFactory, $config);
+ $this->assertFalse($finder->findBinaryPath('cat'));
+ $this->assertFalse($this->cache->get('cat'));
+ }
+}