2020-01-19 12:29:34 +00:00
|
|
|
import json
|
2020-02-02 13:18:13 +00:00
|
|
|
import unittest
|
2020-01-01 20:22:31 +00:00
|
|
|
|
2020-03-23 14:40:53 +00:00
|
|
|
import core.config
|
2020-01-19 12:29:34 +00:00
|
|
|
import core.output
|
2020-02-02 13:18:13 +00:00
|
|
|
import core.module
|
|
|
|
|
|
|
|
class TestModule(core.module.Module):
|
|
|
|
pass
|
2020-01-01 20:22:31 +00:00
|
|
|
|
2020-01-19 12:29:34 +00:00
|
|
|
class i3(unittest.TestCase):
|
2020-01-01 20:22:31 +00:00
|
|
|
def setUp(self):
|
2020-01-19 12:29:34 +00:00
|
|
|
self.i3 = core.output.i3()
|
2020-02-02 13:18:13 +00:00
|
|
|
widget = unittest.mock.MagicMock()
|
|
|
|
widget.full_text.return_value = "test"
|
2020-03-23 14:40:53 +00:00
|
|
|
self.someModule = TestModule(config=core.config.Config([]),
|
|
|
|
widgets=[widget, widget, widget])
|
2020-03-01 13:08:16 +00:00
|
|
|
self.paddedTheme = core.theme.Theme(raw_data = {
|
|
|
|
'defaults': { 'padding': ' ' }
|
2020-04-07 18:59:26 +00:00
|
|
|
})
|
2020-03-31 18:57:09 +00:00
|
|
|
self.separator = '***';
|
|
|
|
self.separatorTheme = core.theme.Theme(raw_data = {
|
2020-04-05 11:58:59 +00:00
|
|
|
'defaults': { 'separator': self.separator, 'fg': 'red', 'bg': 'blue' }
|
2020-04-07 18:59:26 +00:00
|
|
|
})
|
|
|
|
self.someBlock = core.output.block(
|
|
|
|
theme=self.separatorTheme,
|
|
|
|
module=self.someModule,
|
|
|
|
widget=self.someModule.widget()
|
|
|
|
)
|
2020-01-19 12:29:34 +00:00
|
|
|
|
|
|
|
def test_start(self):
|
2020-02-22 12:42:44 +00:00
|
|
|
core.event.clear()
|
|
|
|
|
2020-02-01 20:37:38 +00:00
|
|
|
all_data = self.i3.start()
|
2020-04-05 11:58:59 +00:00
|
|
|
data = all_data['blocks']
|
2020-01-19 14:36:52 +00:00
|
|
|
self.assertEqual(1, data['version'], 'i3bar protocol version 1 expected')
|
2020-01-19 12:29:34 +00:00
|
|
|
self.assertTrue(data['click_events'], 'click events should be enabled')
|
2020-02-01 20:37:38 +00:00
|
|
|
self.assertEqual('\n[', all_data['suffix'])
|
2020-01-19 12:29:34 +00:00
|
|
|
|
|
|
|
def test_stop(self):
|
2020-02-02 13:18:13 +00:00
|
|
|
self.assertEqual('\n]', self.i3.stop()['suffix'], 'wrong i3bar protocol during stop')
|
|
|
|
|
|
|
|
def test_no_modules_by_default(self):
|
|
|
|
self.assertEqual(0, len(self.i3.modules()), 'module list should be empty by default')
|
|
|
|
|
|
|
|
def test_register_single_module(self):
|
|
|
|
self.i3.modules(self.someModule)
|
|
|
|
self.assertEqual(1, len(self.i3.modules()), 'setting single module does not work')
|
|
|
|
|
|
|
|
def test_register_multiple_modules(self):
|
|
|
|
self.i3.modules([ self.someModule, self.someModule, self.someModule ])
|
|
|
|
self.assertEqual(3, len(self.i3.modules()), 'setting module list does not work')
|
|
|
|
|
|
|
|
def test_draw_existing_module(self):
|
|
|
|
self.i3.test_draw = unittest.mock.MagicMock(return_value={
|
2020-04-05 11:58:59 +00:00
|
|
|
'blocks': { 'test': True }, 'suffix': 'end'
|
2020-02-02 13:18:13 +00:00
|
|
|
})
|
|
|
|
self.i3.draw('test_draw')
|
|
|
|
self.i3.test_draw.assert_called_once_with()
|
|
|
|
|
|
|
|
def test_empty_status_line(self):
|
|
|
|
data = self.i3.statusline()
|
2020-04-05 11:58:59 +00:00
|
|
|
self.assertEqual([], data['blocks'], 'expected empty list of status line entries')
|
2020-02-02 13:18:13 +00:00
|
|
|
self.assertEqual(',', data['suffix'], 'expected "," as suffix')
|
2020-02-01 20:37:38 +00:00
|
|
|
|
2020-02-02 13:18:13 +00:00
|
|
|
def test_statusline(self):
|
|
|
|
self.i3.modules([ self.someModule, self.someModule, self.someModule ])
|
2020-02-09 12:25:34 +00:00
|
|
|
self.i3.update()
|
2020-02-02 13:18:13 +00:00
|
|
|
data = self.i3.statusline()
|
2020-04-05 11:58:59 +00:00
|
|
|
self.assertEqual(len(self.someModule.widgets())*3, len(data['blocks']), 'wrong number of widgets')
|
2020-01-19 12:29:34 +00:00
|
|
|
|
2020-03-01 13:08:16 +00:00
|
|
|
def test_padding(self):
|
|
|
|
self.i3.theme(self.paddedTheme)
|
2020-04-05 11:58:59 +00:00
|
|
|
blk = core.output.block(self.i3.theme(), self.someModule, self.someModule.widget())
|
|
|
|
blk.set('full_text', 'abc')
|
|
|
|
result = blk.dict()['full_text']
|
2020-03-01 13:08:16 +00:00
|
|
|
self.assertEqual(' abc ', result)
|
|
|
|
|
2020-03-31 18:57:09 +00:00
|
|
|
def test_no_separator(self):
|
2020-04-05 11:58:59 +00:00
|
|
|
result = self.i3.__separator_block(self.someModule, self.someModule.widget())
|
2020-03-31 18:57:09 +00:00
|
|
|
self.assertEqual([], result)
|
|
|
|
|
|
|
|
def test_separator(self):
|
|
|
|
self.i3.theme(self.separatorTheme)
|
2020-04-05 11:58:59 +00:00
|
|
|
result = self.i3.__separator_block(self.someModule, self.someModule.widget())
|
2020-03-31 18:57:09 +00:00
|
|
|
self.assertEqual(1, len(result))
|
2020-04-05 11:58:59 +00:00
|
|
|
self.assertEqual('***', result[0].dict()['full_text'])
|
|
|
|
self.assertTrue(result[0].dict().get('_decorator', False))
|
2020-04-07 18:41:09 +00:00
|
|
|
self.assertEqual(self.separatorTheme.get('bg', self.someModule.widget()), result[0].dict()['color'])
|
|
|
|
|
|
|
|
def test_dump_json(self):
|
|
|
|
obj = unittest.mock.MagicMock()
|
|
|
|
obj.dict = unittest.mock.MagicMock()
|
|
|
|
core.output.dump_json(obj)
|
|
|
|
obj.dict_assert_called_once_with()
|
2020-03-31 18:57:09 +00:00
|
|
|
|
2020-04-07 18:59:26 +00:00
|
|
|
def test_assign(self):
|
|
|
|
src = {
|
|
|
|
'a': 'x', 'b': 'y', 'c': 'z'
|
|
|
|
}
|
|
|
|
dst = {}
|
|
|
|
|
|
|
|
core.output.assign(src, dst, 'a')
|
|
|
|
self.assertEqual(dst['a'], src['a'])
|
|
|
|
|
|
|
|
core.output.assign(src, dst, '123', 'b')
|
|
|
|
self.assertEqual(dst['123'], src['b'])
|
|
|
|
|
|
|
|
core.output.assign(src, dst, 'blub', default='def')
|
|
|
|
self.assertEqual('def', dst['blub'])
|
|
|
|
|
|
|
|
def test_pango_detection(self):
|
|
|
|
self.assertFalse(self.someBlock.is_pango({}))
|
|
|
|
self.assertTrue(self.someBlock.is_pango({ 'pango': {} }))
|
|
|
|
|
|
|
|
def test_pangoize(self):
|
|
|
|
self.assertEqual('test', self.someBlock.pangoize('test'))
|
|
|
|
self.assertFalse('markup' in self.someBlock.dict())
|
|
|
|
|
|
|
|
self.assertEqual('<span attr="blub" x="y">test</span>',
|
|
|
|
self.someBlock.pangoize({ 'pango': { 'attr': 'blub', 'x': 'y', 'full_text': 'test' } })
|
|
|
|
)
|
|
|
|
self.assertEqual('pango', self.someBlock.dict()['markup'])
|
|
|
|
|
|
|
|
def test_padding(self):
|
|
|
|
self.someBlock.set('padding', '***')
|
|
|
|
self.someBlock.set('full_text', 'test')
|
|
|
|
|
|
|
|
self.assertEqual('***test***', self.someBlock.dict()['full_text'])
|
|
|
|
|
|
|
|
def test_pre_suffix(self):
|
|
|
|
self.someBlock.set('padding', '*')
|
|
|
|
self.someBlock.set('prefix', 'pre')
|
|
|
|
self.someBlock.set('suffix', 'suf')
|
|
|
|
self.someBlock.set('full_text', 'test')
|
|
|
|
|
|
|
|
self.assertEqual('*pre*test*suf*', self.someBlock.dict()['full_text'])
|
|
|
|
|
2020-01-19 12:29:34 +00:00
|
|
|
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4
|