File: conftest.py

package info (click to toggle)
prettytable 3.16.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 468 kB
  • sloc: python: 5,124; makefile: 5
file content (89 lines) | stat: -rw-r--r-- 2,632 bytes parent folder | download | duplicates (2)
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
from __future__ import annotations

import io

import pytest
from test_prettytable import CITY_DATA, CITY_DATA_HEADER

from prettytable import PrettyTable, from_csv, from_mediawiki


@pytest.fixture(scope="function")
def col_prettytable() -> PrettyTable:
    # Column by column...
    table = PrettyTable()
    for idx, colname in enumerate(CITY_DATA_HEADER):
        table.add_column(colname, [row[idx] for row in CITY_DATA])
    return table


@pytest.fixture(scope="function")
def city_data() -> PrettyTable:
    """Just build the Australian capital city data example table."""
    table = PrettyTable(CITY_DATA_HEADER)
    for row in CITY_DATA:
        table.add_row(row)
    return table


@pytest.fixture(scope="function")
def city_data_from_csv() -> PrettyTable:
    csv_string = ", ".join(CITY_DATA_HEADER)
    for row in CITY_DATA:
        csv_string += "\n" + ",".join(str(fld) for fld in row)
    csv_fp = io.StringIO(csv_string)
    return from_csv(csv_fp)


@pytest.fixture(scope="function")
def city_data_from_mediawiki() -> PrettyTable:
    wiki_text = '{| class="wikitable"\n'
    wiki_text += "|-\n"
    wiki_text += "! " + " !! ".join(CITY_DATA_HEADER) + "\n"
    for row in CITY_DATA:
        wiki_text += "|-\n"
        wiki_text += "| " + " || ".join(str(item) for item in row) + "\n"
    wiki_text += "|}"
    return from_mediawiki(wiki_text)


@pytest.fixture
def mix_prettytable() -> PrettyTable:
    # A mix of both!
    table = PrettyTable()
    table.field_names = [CITY_DATA_HEADER[0], CITY_DATA_HEADER[1]]
    for row in CITY_DATA:
        table.add_row([row[0], row[1]])
    for idx, colname in enumerate(CITY_DATA_HEADER[2:]):
        table.add_column(colname, [row[idx + 2] for row in CITY_DATA])
    return table


@pytest.fixture(scope="function")
def field_name_less_table() -> PrettyTable:
    table = PrettyTable()
    for row in CITY_DATA:
        table.add_row(row)
    return table


@pytest.fixture(scope="function")
def row_prettytable(field_name_less_table: PrettyTable) -> PrettyTable:
    # Row by row...
    field_name_less_table.field_names = CITY_DATA_HEADER
    return field_name_less_table


@pytest.fixture(scope="function")
def empty_helper_table() -> PrettyTable:
    return PrettyTable(["", "Field 1", "Field 2", "Field 3"])


@pytest.fixture(scope="function")
def helper_table(empty_helper_table: PrettyTable) -> PrettyTable:
    v = 1
    for row in range(3):
        # Some have spaces, some not, to help test padding columns of different widths
        empty_helper_table.add_row([v, f"value {v}", f"value{v+1}", f"value{v+2}"])
        v += 3
    return empty_helper_table