|
8 | 8 | import pandas as pd |
9 | 9 | import pytest |
10 | 10 |
|
11 | | -from pandas_openscm.index_manipulation import ensure_index_is_multiindex |
12 | | -from pandas_openscm.testing import create_test_df |
| 11 | +from pandas_openscm.index_manipulation import ( |
| 12 | + ensure_index_is_multiindex, |
| 13 | + ensure_is_multiindex, |
| 14 | +) |
| 15 | +from pandas_openscm.testing import ( |
| 16 | + convert_to_desired_type, |
| 17 | + create_test_df, |
| 18 | +) |
13 | 19 |
|
14 | 20 |
|
15 | 21 | @pytest.mark.parametrize("copy, copy_exp", ((None, True), (True, True), (False, False))) |
@@ -71,12 +77,17 @@ def test_ensure_index_is_multiindex_no_op(copy, copy_exp): |
71 | 77 |
|
72 | 78 |
|
73 | 79 | @pytest.mark.parametrize("copy, copy_exp", ((None, True), (True, True), (False, False))) |
74 | | -def test_accessor(setup_pandas_accessors, copy, copy_exp): |
| 80 | +@pytest.mark.parametrize( |
| 81 | + "pobj_type", |
| 82 | + ("DataFrame", "Series"), |
| 83 | +) |
| 84 | +def test_accessor(setup_pandas_accessors, copy, copy_exp, pobj_type): |
75 | 85 | start = pd.DataFrame( |
76 | 86 | [[1, 2], [3, 4]], |
77 | 87 | columns=[10, 20], |
78 | 88 | index=pd.Index(["a", "b"], name="variable"), |
79 | 89 | ) |
| 90 | + start = convert_to_desired_type(start, pobj_type) |
80 | 91 |
|
81 | 92 | call_kwargs = {} |
82 | 93 | if copy is not None: |
@@ -106,3 +117,98 @@ def test_accessor(setup_pandas_accessors, copy, copy_exp): |
106 | 117 | else: |
107 | 118 | # Same object returned |
108 | 119 | assert id(start) == id(res_short) |
| 120 | + |
| 121 | + |
| 122 | +def test_ensure_is_multiindex_index(): |
| 123 | + start = pd.Index([1, 2, 3], name="id") |
| 124 | + |
| 125 | + res = ensure_is_multiindex(start) |
| 126 | + |
| 127 | + assert isinstance(res, pd.MultiIndex) |
| 128 | + |
| 129 | + exp = pd.MultiIndex.from_tuples( |
| 130 | + [ |
| 131 | + (1,), |
| 132 | + (2,), |
| 133 | + (3,), |
| 134 | + ], |
| 135 | + names=["id"], |
| 136 | + ) |
| 137 | + |
| 138 | + pd.testing.assert_index_equal(res, exp) |
| 139 | + |
| 140 | + |
| 141 | +def test_ensure_is_multiindex_index_no_name(): |
| 142 | + start = pd.Index([1, 2, 3]) |
| 143 | + |
| 144 | + res = ensure_is_multiindex(start) |
| 145 | + |
| 146 | + assert isinstance(res, pd.MultiIndex) |
| 147 | + |
| 148 | + exp = pd.MultiIndex.from_tuples( |
| 149 | + [ |
| 150 | + (1,), |
| 151 | + (2,), |
| 152 | + (3,), |
| 153 | + ], |
| 154 | + names=[None], |
| 155 | + ) |
| 156 | + |
| 157 | + pd.testing.assert_index_equal(res, exp) |
| 158 | + |
| 159 | + |
| 160 | +def test_ensure_is_multiindex(): |
| 161 | + start = pd.MultiIndex.from_tuples( |
| 162 | + [ |
| 163 | + ("a", "b"), |
| 164 | + ("c", "d"), |
| 165 | + ], |
| 166 | + names=["mod", "scen"], |
| 167 | + ) |
| 168 | + |
| 169 | + res = ensure_is_multiindex(start) |
| 170 | + |
| 171 | + # Same object returned |
| 172 | + assert id(start) == id(res) |
| 173 | + assert isinstance(res, pd.MultiIndex) |
| 174 | + pd.testing.assert_index_equal(res, start) |
| 175 | + |
| 176 | + |
| 177 | +def test_ensure_is_multiindex_accessor_index(setup_pandas_accessors): |
| 178 | + start = pd.Index([1, 2, 3], name="id") |
| 179 | + |
| 180 | + res = start.openscm.ensure_is_multiindex() |
| 181 | + res_short = start.openscm.eim() |
| 182 | + pd.testing.assert_index_equal(res, res_short) |
| 183 | + |
| 184 | + assert isinstance(res, pd.MultiIndex) |
| 185 | + |
| 186 | + exp = pd.MultiIndex.from_tuples( |
| 187 | + [ |
| 188 | + (1,), |
| 189 | + (2,), |
| 190 | + (3,), |
| 191 | + ], |
| 192 | + names=["id"], |
| 193 | + ) |
| 194 | + |
| 195 | + pd.testing.assert_index_equal(res, exp) |
| 196 | + |
| 197 | + |
| 198 | +def test_ensure_is_multiindex_accessor_multiindex(setup_pandas_accessors): |
| 199 | + start = pd.MultiIndex.from_tuples( |
| 200 | + [ |
| 201 | + ("a", "b"), |
| 202 | + ("c", "d"), |
| 203 | + ], |
| 204 | + names=["mod", "scen"], |
| 205 | + ) |
| 206 | + |
| 207 | + res = start.openscm.ensure_is_multiindex() |
| 208 | + res_short = start.openscm.eim() |
| 209 | + pd.testing.assert_index_equal(res, res_short) |
| 210 | + |
| 211 | + # Same object returned |
| 212 | + assert id(start) == id(res) |
| 213 | + assert isinstance(res, pd.MultiIndex) |
| 214 | + pd.testing.assert_index_equal(res, start) |
0 commit comments