summaryrefslogtreecommitdiffstats
path: root/core/js
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2019-02-27 10:47:57 +0100
committerMorris Jobke <hey@morrisjobke.de>2019-02-28 16:46:23 +0100
commit6c7ccbecbf6af5037a6c7bf2046bbf4d3bf91e2f (patch)
tree790c1c6bed9c6bb01ecf08672a9564493f5e6786 /core/js
parent75deeb110dd3033078aebc656c929fecf492a324 (diff)
downloadnextcloud-server-6c7ccbecbf6af5037a6c7bf2046bbf4d3bf91e2f.tar.gz
nextcloud-server-6c7ccbecbf6af5037a6c7bf2046bbf4d3bf91e2f.zip
Add setup check for missing UTF8MB4 on mysql
Signed-off-by: Morris Jobke <hey@morrisjobke.de>
Diffstat (limited to 'core/js')
-rw-r--r--core/js/setupchecks.js12
-rw-r--r--core/js/tests/specs/setupchecksSpec.js87
2 files changed, 86 insertions, 13 deletions
diff --git a/core/js/setupchecks.js b/core/js/setupchecks.js
index 7582b062d52..3e82e077994 100644
--- a/core/js/setupchecks.js
+++ b/core/js/setupchecks.js
@@ -438,6 +438,18 @@
type: OC.SetupChecks.MESSAGE_TYPE_WARNING
});
}
+ if (data.isMysqlUsedWithoutUTF8MB4) {
+ messages.push({
+ msg: t(
+ 'core',
+ 'MySQL is used as database but does not support 4-byte characters. To be able to handle 4-byte characters (like emojis) without issues in filenames or comments for example it is recommended to enable the 4-byte support in MySQL. For further details read <a target="_blank" rel="noreferrer noopener" href="{docLink}">the documentation page about this</a>.',
+ {
+ docLink: oc_defaults.docPlaceholderUrl.replace('PLACEHOLDER', 'admin-mysql-utf8mb4'),
+ }
+ ),
+ type: OC.SetupChecks.MESSAGE_TYPE_WARNING
+ })
+ }
} else {
messages.push({
diff --git a/core/js/tests/specs/setupchecksSpec.js b/core/js/tests/specs/setupchecksSpec.js
index e2c0053aa71..aa9006d0ab5 100644
--- a/core/js/tests/specs/setupchecksSpec.js
+++ b/core/js/tests/specs/setupchecksSpec.js
@@ -247,7 +247,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -297,7 +298,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -348,7 +350,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -397,7 +400,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -444,7 +448,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -493,7 +498,8 @@ describe('OC.SetupChecks tests', function() {
'/some/path'
],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -540,7 +546,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -587,7 +594,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -634,7 +642,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: false,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -702,7 +711,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -750,7 +760,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -798,7 +809,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -846,7 +858,8 @@ describe('OC.SetupChecks tests', function() {
isMemoryLimitSufficient: true,
appDirsWithDifferentOwner: [],
recommendedPHPModules: [],
- pendingBigIntConversionColumns: []
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: false
})
);
@@ -858,6 +871,54 @@ describe('OC.SetupChecks tests', function() {
done();
});
});
+
+ it('should return an error if the php version is no longer supported', function(done) {
+ var async = OC.SetupChecks.checkSetup();
+
+ suite.server.requests[0].respond(
+ 200,
+ {
+ 'Content-Type': 'application/json',
+ },
+ JSON.stringify({
+ hasFileinfoInstalled: true,
+ isGetenvServerWorking: true,
+ isReadOnlyConfig: false,
+ hasWorkingFileLocking: true,
+ hasValidTransactionIsolationLevel: true,
+ suggestedOverwriteCliURL: '',
+ isRandomnessSecure: true,
+ securityDocs: 'https://docs.owncloud.org/myDocs.html',
+ serverHasInternetConnection: true,
+ isMemcacheConfigured: true,
+ forwardedForHeadersWorking: true,
+ isCorrectMemcachedPHPModuleInstalled: true,
+ hasPassedCodeIntegrityCheck: true,
+ isOpcacheProperlySetup: true,
+ hasOpcacheLoaded: true,
+ isSettimelimitAvailable: true,
+ hasFreeTypeSupport: true,
+ missingIndexes: [],
+ cronErrors: [],
+ cronInfo: {
+ diffInSeconds: 0
+ },
+ isMemoryLimitSufficient: true,
+ appDirsWithDifferentOwner: [],
+ recommendedPHPModules: [],
+ pendingBigIntConversionColumns: [],
+ isMysqlUsedWithoutUTF8MB4: true
+ })
+ );
+
+ async.done(function( data, s, x ){
+ expect(data).toEqual([{
+ msg: 'MySQL is used as database but does not support 4-byte characters. To be able to handle 4-byte characters (like emojis) without issues in filenames or comments for example it is recommended to enable the 4-byte support in MySQL. For further details read <a href="https://docs.example.org/admin-mysql-utf8mb4" rel="noreferrer noopener">the documentation page about this</a>.',
+ type: OC.SetupChecks.MESSAGE_TYPE_WARNING
+ }]);
+ done();
+ });
+ });
});
describe('checkGeneric', function() {