summaryrefslogtreecommitdiff
path: root/tests/widgets/test_globals.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/widgets/test_globals.py')
-rw-r--r--tests/widgets/test_globals.py51
1 files changed, 51 insertions, 0 deletions
diff --git a/tests/widgets/test_globals.py b/tests/widgets/test_globals.py
new file mode 100644
index 00000000..a52a721c
--- /dev/null
+++ b/tests/widgets/test_globals.py
@@ -0,0 +1,51 @@
+# encoding=utf-8
+# Copyright © 2017 Dylan Baker
+
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+"""Tests for the alot.widgets.globals module."""
+
+import unittest
+
+import mock
+
+from alot.widgets import globals as globals_
+
+
+class TestTagWidget(unittest.TestCase):
+
+ def test_sort(self):
+ """Test sorting."""
+ # There's an upstream bug about this
+ # pylint: disable=bad-continuation
+ with mock.patch(
+ 'alot.widgets.globals.settings.get_tagstring_representation',
+ lambda t, _, __: {'translated': t, 'normal': None,
+ 'focussed': None}):
+ expected = ['a', 'z', 'aa', 'bar', 'foo']
+ actual = [g.translated for g in
+ sorted(globals_.TagWidget(x) for x in expected)]
+ self.assertListEqual(actual, expected)
+
+ def test_hash_for_unicode_representation(self):
+ with mock.patch(
+ 'alot.widgets.globals.settings.get_tagstring_representation',
+ lambda _, __, ___: {'translated': u'✉', 'normal': None,
+ 'focussed': None}):
+ # We don't have to assert anything, we just want the hash to be
+ # computed without an exception. The implementation currently
+ # (2017-08-20) caches the hash value when __init__ is called. This
+ # test should even test the correct thing if this is changed and
+ # the hash is only computed in __hash__.
+ hash(globals_.TagWidget('unread'))