Skip to content

Commit b8f30ca

Browse files
authored
REF: test_insert, test_delete (#33350)
1 parent 49d1d75 commit b8f30ca

File tree

3 files changed

+287
-274
lines changed

3 files changed

+287
-274
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,134 @@
1+
import pytest
2+
3+
from pandas import DatetimeIndex, Series, date_range
4+
import pandas._testing as tm
5+
6+
7+
class TestDelete:
8+
def test_delete(self):
9+
idx = date_range(start="2000-01-01", periods=5, freq="M", name="idx")
10+
11+
# preserve freq
12+
expected_0 = date_range(start="2000-02-01", periods=4, freq="M", name="idx")
13+
expected_4 = date_range(start="2000-01-01", periods=4, freq="M", name="idx")
14+
15+
# reset freq to None
16+
expected_1 = DatetimeIndex(
17+
["2000-01-31", "2000-03-31", "2000-04-30", "2000-05-31"],
18+
freq=None,
19+
name="idx",
20+
)
21+
22+
cases = {
23+
0: expected_0,
24+
-5: expected_0,
25+
-1: expected_4,
26+
4: expected_4,
27+
1: expected_1,
28+
}
29+
for n, expected in cases.items():
30+
result = idx.delete(n)
31+
tm.assert_index_equal(result, expected)
32+
assert result.name == expected.name
33+
assert result.freq == expected.freq
34+
35+
with pytest.raises((IndexError, ValueError), match="out of bounds"):
36+
# either depending on numpy version
37+
idx.delete(5)
38+
39+
for tz in [None, "Asia/Tokyo", "US/Pacific"]:
40+
idx = date_range(
41+
start="2000-01-01 09:00", periods=10, freq="H", name="idx", tz=tz
42+
)
43+
44+
expected = date_range(
45+
start="2000-01-01 10:00", periods=9, freq="H", name="idx", tz=tz
46+
)
47+
result = idx.delete(0)
48+
tm.assert_index_equal(result, expected)
49+
assert result.name == expected.name
50+
assert result.freqstr == "H"
51+
assert result.tz == expected.tz
52+
53+
expected = date_range(
54+
start="2000-01-01 09:00", periods=9, freq="H", name="idx", tz=tz
55+
)
56+
result = idx.delete(-1)
57+
tm.assert_index_equal(result, expected)
58+
assert result.name == expected.name
59+
assert result.freqstr == "H"
60+
assert result.tz == expected.tz
61+
62+
def test_delete_slice(self):
63+
idx = date_range(start="2000-01-01", periods=10, freq="D", name="idx")
64+
65+
# preserve freq
66+
expected_0_2 = date_range(start="2000-01-04", periods=7, freq="D", name="idx")
67+
expected_7_9 = date_range(start="2000-01-01", periods=7, freq="D", name="idx")
68+
69+
# reset freq to None
70+
expected_3_5 = DatetimeIndex(
71+
[
72+
"2000-01-01",
73+
"2000-01-02",
74+
"2000-01-03",
75+
"2000-01-07",
76+
"2000-01-08",
77+
"2000-01-09",
78+
"2000-01-10",
79+
],
80+
freq=None,
81+
name="idx",
82+
)
83+
84+
cases = {
85+
(0, 1, 2): expected_0_2,
86+
(7, 8, 9): expected_7_9,
87+
(3, 4, 5): expected_3_5,
88+
}
89+
for n, expected in cases.items():
90+
result = idx.delete(n)
91+
tm.assert_index_equal(result, expected)
92+
assert result.name == expected.name
93+
assert result.freq == expected.freq
94+
95+
result = idx.delete(slice(n[0], n[-1] + 1))
96+
tm.assert_index_equal(result, expected)
97+
assert result.name == expected.name
98+
assert result.freq == expected.freq
99+
100+
for tz in [None, "Asia/Tokyo", "US/Pacific"]:
101+
ts = Series(
102+
1,
103+
index=date_range(
104+
"2000-01-01 09:00", periods=10, freq="H", name="idx", tz=tz
105+
),
106+
)
107+
# preserve freq
108+
result = ts.drop(ts.index[:5]).index
109+
expected = date_range(
110+
"2000-01-01 14:00", periods=5, freq="H", name="idx", tz=tz
111+
)
112+
tm.assert_index_equal(result, expected)
113+
assert result.name == expected.name
114+
assert result.freq == expected.freq
115+
assert result.tz == expected.tz
116+
117+
# reset freq to None
118+
result = ts.drop(ts.index[[1, 3, 5, 7, 9]]).index
119+
expected = DatetimeIndex(
120+
[
121+
"2000-01-01 09:00",
122+
"2000-01-01 11:00",
123+
"2000-01-01 13:00",
124+
"2000-01-01 15:00",
125+
"2000-01-01 17:00",
126+
],
127+
freq=None,
128+
name="idx",
129+
tz=tz,
130+
)
131+
tm.assert_index_equal(result, expected)
132+
assert result.name == expected.name
133+
assert result.freq == expected.freq
134+
assert result.tz == expected.tz

0 commit comments

Comments
 (0)