summaryrefslogtreecommitdiff
path: root/cliff/tests/test_show.py
blob: 41df5e1c3ad796a28309388e8f02e8562a6f7b43 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#!/usr/bin/env python

from cliff.show import ShowOne

import mock


class FauxFormatter(object):

    def __init__(self):
        self.args = []

    def emit_list(self, columns, data, stdout, args):
        self.args.append((columns, data))


class ExerciseShowOne(ShowOne):

    def load_formatter_plugins(self):
        self.formatters = {
            'test': FauxFormatter(),
        }
        return

    def take_action(self, parsed_args):
        return (
            parsed_args.columns,
            [('a', 'A'), ('b', 'B')],
        )


# def test_formatter_args():
#     app = mock.Mock()
#     test_lister = ExerciseLister(app, [])

#     parsed_args = mock.Mock()
#     parsed_args.columns = ('Col1', 'Col2')
#     parsed_args.formatter = 'test'

#     test_lister.run(parsed_args)
#     f = test_lister.formatters['test']
#     assert len(f.args) == 1
#     args = f.args[0]
#     assert args[0] == list(parsed_args.columns)
#     data = list(args[1])
#     assert data == [['a', 'A'], ['b', 'B']]

def test_dict2columns():
    app = mock.Mock()
    test_show = ExerciseShowOne(app, [])
    d = {'a': 'A', 'b': 'B', 'c': 'C'}
    expected = [('a', 'b', 'c'), ('A', 'B', 'C')]
    actual = list(test_show.dict2columns(d))
    assert expected == actual