[tor-commits] [nyx/master] Test _draw_line()
atagar at torproject.org
atagar at torproject.org
Tue Jul 12 17:06:11 UTC 2016
commit b3b49f72e3073e4fb3176042c754b54ff73b6245
Author: Damian Johnson <atagar at torproject.org>
Date: Tue Jul 12 10:04:15 2016 -0700
Test _draw_line()
Don't care for how many attributes this little helper needs but oh well.
Shortens the draw() method and delegates it to mostly determine column
dimensions.
---
nyx/panel/config.py | 26 +++++++++++++++++---------
test/panel/config.py | 14 ++++++++++++++
2 files changed, 31 insertions(+), 9 deletions(-)
diff --git a/nyx/panel/config.py b/nyx/panel/config.py
index eea135d..f3e747a 100644
--- a/nyx/panel/config.py
+++ b/nyx/panel/config.py
@@ -272,15 +272,7 @@ class ConfigPanel(nyx.panel.Panel):
value_width = VALUE_WIDTH
for i, entry in enumerate(contents[scroll:]):
- attr = [CONFIG['attr.config.category_color'].get(entry.manual.category, WHITE)]
- attr.append(BOLD if entry.is_set() else NORMAL)
- attr.append(HIGHLIGHT if entry == selected else NORMAL)
-
- option_label = str_tools.crop(entry.name, NAME_WIDTH).ljust(NAME_WIDTH + 1)
- value_label = str_tools.crop(entry.value(), value_width).ljust(value_width + 1)
- summary_label = str_tools.crop(entry.manual.summary, description_width).ljust(description_width)
-
- subwindow.addstr(scroll_offset, DETAILS_HEIGHT + i, option_label + value_label + summary_label, *attr)
+ _draw_line(subwindow, scroll_offset, DETAILS_HEIGHT + i, entry, entry == selected, value_width, description_width)
if DETAILS_HEIGHT + i >= subwindow.height:
break
@@ -289,6 +281,22 @@ class ConfigPanel(nyx.panel.Panel):
return self._contents if self._show_all else filter(lambda entry: stem.manual.is_important(entry.name) or entry.is_set(), self._contents)
+def _draw_line(subwindow, x, y, entry, is_selected, value_width, description_width):
+ """
+ Show an individual configuration line.
+ """
+
+ attr = [CONFIG['attr.config.category_color'].get(entry.manual.category, WHITE)]
+ attr.append(BOLD if entry.is_set() else NORMAL)
+ attr.append(HIGHLIGHT if is_selected else NORMAL)
+
+ option_label = str_tools.crop(entry.name, NAME_WIDTH).ljust(NAME_WIDTH + 1)
+ value_label = str_tools.crop(entry.value(), value_width).ljust(value_width + 1)
+ summary_label = str_tools.crop(entry.manual.summary, description_width).ljust(description_width)
+
+ subwindow.addstr(x, y, option_label + value_label + summary_label, *attr)
+
+
def _draw_selection_details(subwindow, selected):
"""
Shows details of the currently selected option.
diff --git a/test/panel/config.py b/test/panel/config.py
index 19db206..0289406 100644
--- a/test/panel/config.py
+++ b/test/panel/config.py
@@ -11,6 +11,8 @@ import test
from test import require_curses
from mock import patch
+EXPECTED_LINE = 'ControlPort 9051 Port providing access to tor...'
+
EXPECTED_DETAIL_DIALOG = """
+------------------------------------------------------------------------------+
| ControlPort (General Option) |
@@ -26,6 +28,18 @@ EXPECTED_DETAIL_DIALOG = """
class TestConfigPanel(unittest.TestCase):
@require_curses
@patch('nyx.panel.config.tor_controller')
+ def test_draw_line(self, tor_controller_mock):
+ tor_controller_mock().get_info.return_value = True
+ tor_controller_mock().get_conf.return_value = ['9051']
+
+ manual = stem.manual.Manual.from_cache()
+ entry = nyx.panel.config.ConfigEntry('ControlPort', 'LineList', manual)
+
+ rendered = test.render(nyx.panel.config._draw_line, 0, 0, entry, False, 10, 35)
+ self.assertEqual(EXPECTED_LINE, rendered.content)
+
+ @require_curses
+ @patch('nyx.panel.config.tor_controller')
def test_draw_selection_details(self, tor_controller_mock):
tor_controller_mock().get_info.return_value = True
tor_controller_mock().get_conf.return_value = ['9051']
More information about the tor-commits
mailing list