diff options
author | Morris Jobke <hey@morrisjobke.de> | 2017-02-24 13:10:47 -0600 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-02-24 13:10:47 -0600 |
commit | 8a7b8f966e476173416cdd5fd7fc0e01de34aa1f (patch) | |
tree | 415e3add747e2bff7ea534d956c050dfddad2377 /core | |
parent | dd6d2893a66f68157c2fab4deb06f336642c6a02 (diff) | |
parent | cee8853658703358a8e564c414807c632ee0d5ea (diff) | |
download | nextcloud-server-8a7b8f966e476173416cdd5fd7fc0e01de34aa1f.tar.gz nextcloud-server-8a7b8f966e476173416cdd5fd7fc0e01de34aa1f.zip |
Merge pull request #3489 from nextcloud/give-hint-about-opcache
Show info in admin settings about PHP opcache if disabled
Diffstat (limited to 'core')
-rw-r--r-- | core/js/setupchecks.js | 12 | ||||
-rw-r--r-- | core/js/tests/specs/setupchecksSpec.js | 37 |
2 files changed, 49 insertions, 0 deletions
diff --git a/core/js/setupchecks.js b/core/js/setupchecks.js index 4d2097a5b5d..fcbbba6af62 100644 --- a/core/js/setupchecks.js +++ b/core/js/setupchecks.js @@ -148,6 +148,18 @@ type: OC.SetupChecks.MESSAGE_TYPE_ERROR }); } + if(!data.isOpcacheProperlySetup) { + messages.push({ + msg: t( + 'core', + 'The PHP Opcache is not properly configured. <a target="_blank" rel="noreferrer" href="{docLink}">For better performance we recommend ↗</a> to use following settings in the <code>php.ini</code>:', + { + docLink: data.phpOpcacheDocumentation, + } + ) + "<pre><code>opcache.enable=On\nopcache.enable_cli=1\nopcache.interned_strings_buffer=8\nopcache.max_accelerated_files=10000\nopcache.memory_consumption=128\nopcache.save_comments=1\nopcache.revalidate_freq=1</code></pre>", + type: OC.SetupChecks.MESSAGE_TYPE_INFO + }); + } } else { messages.push({ msg: t('core', 'Error occurred while checking server setup'), diff --git a/core/js/tests/specs/setupchecksSpec.js b/core/js/tests/specs/setupchecksSpec.js index faa8a2bf277..1ee16a7af81 100644 --- a/core/js/tests/specs/setupchecksSpec.js +++ b/core/js/tests/specs/setupchecksSpec.js @@ -155,6 +155,7 @@ describe('OC.SetupChecks tests', function() { forwardedForHeadersWorking: true, isCorrectMemcachedPHPModuleInstalled: true, hasPassedCodeIntegrityCheck: true, + isOpcacheProperlySetup: true, }) ); @@ -186,6 +187,7 @@ describe('OC.SetupChecks tests', function() { forwardedForHeadersWorking: true, isCorrectMemcachedPHPModuleInstalled: true, hasPassedCodeIntegrityCheck: true, + isOpcacheProperlySetup: true, }) ); @@ -218,6 +220,7 @@ describe('OC.SetupChecks tests', function() { forwardedForHeadersWorking: true, isCorrectMemcachedPHPModuleInstalled: true, hasPassedCodeIntegrityCheck: true, + isOpcacheProperlySetup: true, }) ); @@ -248,6 +251,7 @@ describe('OC.SetupChecks tests', function() { forwardedForHeadersWorking: true, isCorrectMemcachedPHPModuleInstalled: true, hasPassedCodeIntegrityCheck: true, + isOpcacheProperlySetup: true, }) ); @@ -276,6 +280,7 @@ describe('OC.SetupChecks tests', function() { forwardedForHeadersWorking: true, isCorrectMemcachedPHPModuleInstalled: false, hasPassedCodeIntegrityCheck: true, + isOpcacheProperlySetup: true, }) ); @@ -304,6 +309,7 @@ describe('OC.SetupChecks tests', function() { reverseProxyDocs: 'https://docs.owncloud.org/foo/bar.html', isCorrectMemcachedPHPModuleInstalled: true, hasPassedCodeIntegrityCheck: true, + isOpcacheProperlySetup: true, }) ); @@ -353,6 +359,7 @@ describe('OC.SetupChecks tests', function() { phpSupported: {eol: true, version: '5.4.0'}, isCorrectMemcachedPHPModuleInstalled: true, hasPassedCodeIntegrityCheck: true, + isOpcacheProperlySetup: true, }) ); @@ -364,6 +371,36 @@ describe('OC.SetupChecks tests', function() { done(); }); }); + + it('should return an info if server has no proper opcache', function(done) { + var async = OC.SetupChecks.checkSetup(); + + suite.server.requests[0].respond( + 200, + { + 'Content-Type': 'application/json' + }, + JSON.stringify({ + isUrandomAvailable: true, + securityDocs: 'https://docs.owncloud.org/myDocs.html', + serverHasInternetConnection: true, + isMemcacheConfigured: true, + forwardedForHeadersWorking: true, + isCorrectMemcachedPHPModuleInstalled: true, + hasPassedCodeIntegrityCheck: true, + isOpcacheProperlySetup: false, + phpOpcacheDocumentation: 'https://example.org/link/to/doc', + }) + ); + + async.done(function( data, s, x ){ + expect(data).toEqual([{ + msg: 'The PHP Opcache is not properly configured. <a target="_blank" rel="noreferrer" href="https://example.org/link/to/doc">For better performance we recommend ↗</a> to use following settings in the <code>php.ini</code>:' + "<pre><code>opcache.enable=On\nopcache.enable_cli=1\nopcache.interned_strings_buffer=8\nopcache.max_accelerated_files=10000\nopcache.memory_consumption=128\nopcache.save_comments=1\nopcache.revalidate_freq=1</code></pre>", + type: OC.SetupChecks.MESSAGE_TYPE_INFO + }]); + done(); + }); + }); }); describe('checkGeneric', function() { |