mirror of
https://github.com/caronc/apprise.git
synced 2024-11-29 03:24:18 +01:00
handles exception thrown when no localization is detected refs #118
This commit is contained in:
parent
cbd35c3b7e
commit
f373e41a91
@ -192,9 +192,17 @@ class AppriseLocale(object):
|
||||
|
||||
if hasattr(ctypes, 'windll'):
|
||||
windll = ctypes.windll.kernel32
|
||||
try:
|
||||
lang = locale.windows_locale[
|
||||
windll.GetUserDefaultUILanguage()]
|
||||
else:
|
||||
|
||||
# Our detected windows language
|
||||
return lang[0:2].lower()
|
||||
|
||||
except (TypeError, KeyError):
|
||||
# Fallback to posix detection
|
||||
pass
|
||||
|
||||
try:
|
||||
# Detect language
|
||||
lang = locale.getdefaultlocale()[0]
|
||||
@ -204,4 +212,4 @@ class AppriseLocale(object):
|
||||
# we're done in this case
|
||||
return None
|
||||
|
||||
return lang[0:2].lower()
|
||||
return None if not lang else lang[0:2].lower()
|
||||
|
@ -27,6 +27,7 @@ import mock
|
||||
import ctypes
|
||||
|
||||
from apprise import AppriseLocale
|
||||
from apprise.utils import environ
|
||||
|
||||
try:
|
||||
# Python v3.4+
|
||||
@ -133,8 +134,7 @@ def test_gettext_installs(mock_gettext_trans):
|
||||
pass
|
||||
|
||||
|
||||
@mock.patch('locale.getdefaultlocale')
|
||||
def test_detect_language(mock_getlocale):
|
||||
def test_detect_language_windows_users():
|
||||
"""
|
||||
API: Apprise() Detect language
|
||||
|
||||
@ -147,14 +147,40 @@ def test_detect_language(mock_getlocale):
|
||||
setattr(ctypes, 'windll', windll)
|
||||
|
||||
# The below accesses the windows fallback code
|
||||
with environ('LANG', 'LANGUAGE', 'LC_ALL', 'LC_CTYPE', LANG="en_CA"):
|
||||
assert AppriseLocale.AppriseLocale.detect_language() == 'en'
|
||||
|
||||
assert AppriseLocale.AppriseLocale\
|
||||
.detect_language(detect_fallback=False) is None
|
||||
|
||||
# 0 = IndexError
|
||||
windll.kernel32.GetUserDefaultUILanguage.return_value = 0
|
||||
setattr(ctypes, 'windll', windll)
|
||||
with environ('LANG', 'LC_ALL', 'LC_CTYPE', LANGUAGE="en_CA"):
|
||||
assert AppriseLocale.AppriseLocale.detect_language() == 'en'
|
||||
|
||||
# The below accesses the windows fallback code and fail
|
||||
# then it will resort to the environment variables
|
||||
with environ('LANG', 'LANGUAGE', 'LC_ALL', 'LC_CTYPE'):
|
||||
# Language can't be detected
|
||||
assert AppriseLocale.AppriseLocale.detect_language() is None
|
||||
|
||||
with environ('LANGUAGE', 'LC_ALL', 'LC_CTYPE', LANG="fr_CA"):
|
||||
# Detect french language
|
||||
assert AppriseLocale.AppriseLocale.detect_language() == 'fr'
|
||||
|
||||
# Tidy
|
||||
delattr(ctypes, 'windll')
|
||||
|
||||
|
||||
@mock.patch('locale.getdefaultlocale')
|
||||
def test_detect_language_defaultlocale(mock_getlocale):
|
||||
"""
|
||||
API: Apprise() Default locale detection
|
||||
|
||||
"""
|
||||
# Handle case where getdefaultlocale() can't be detected
|
||||
mock_getlocale.return_value = None
|
||||
delattr(ctypes, 'windll')
|
||||
assert AppriseLocale.AppriseLocale.detect_language() is None
|
||||
|
||||
# if detect_language and windows env fail us, then we don't
|
||||
|
Loading…
Reference in New Issue
Block a user