From 587dd2fe51767ceb362cfb326921775e4b5d8315 Mon Sep 17 00:00:00 2001 From: Charlie Hess Date: Wed, 1 Jun 2016 18:56:25 -0700 Subject: [PATCH] Expose the method to JS and write a simple test. --- .../api/atom_api_system_preferences.cc | 1 + spec/api-system-preferences-spec.js | 25 +++++++++++++++++++ 2 files changed, 26 insertions(+) create mode 100644 spec/api-system-preferences-spec.js diff --git a/atom/browser/api/atom_api_system_preferences.cc b/atom/browser/api/atom_api_system_preferences.cc index 2b11aad25278..8a02859f2970 100644 --- a/atom/browser/api/atom_api_system_preferences.cc +++ b/atom/browser/api/atom_api_system_preferences.cc @@ -54,6 +54,7 @@ void SystemPreferences::BuildPrototype( .SetMethod("unsubscribeNotification", &SystemPreferences::UnsubscribeNotification) .SetMethod("getUserDefault", &SystemPreferences::GetUserDefault) + .SetMethod("getGlobalDefault", &SystemPreferences::GetGlobalDefault) #endif .SetMethod("isDarkMode", &SystemPreferences::IsDarkMode); } diff --git a/spec/api-system-preferences-spec.js b/spec/api-system-preferences-spec.js new file mode 100644 index 000000000000..3cb0cd406660 --- /dev/null +++ b/spec/api-system-preferences-spec.js @@ -0,0 +1,25 @@ +const assert = require('assert') +const {remote} = require('electron') +const {systemPreferences} = remote + +describe('systemPreferences module', function () { + if (process.platform !== 'darwin') { + return + } + + it('returns user defaults', function () { + assert.notEqual(systemPreferences.getUserDefault('AppleInterfaceStyle', 'string'), null) + assert.notEqual(systemPreferences.getUserDefault('AppleAquaColorVariant', 'integer'), null) + }) + + it('returns defaults under the global domain', function () { + let locale = systemPreferences.getGlobalDefault('AppleLocale') + assert.notEqual(locale, null) + assert(locale.length > 0) + + let languages = systemPreferences.getGlobalDefault('AppleLanguages') + assert.notEqual(languages, null) + assert(languages.length > 0) + }) + +})