Ajout type contrat

This commit is contained in:
2026-04-29 11:52:03 +02:00
parent 375549cb30
commit 1c0e4c3048
10530 changed files with 1842149 additions and 158 deletions

View File

@@ -0,0 +1,86 @@
import numpy as np
import pytest
from pandas import (
DatetimeIndex,
Series,
Timestamp,
array,
date_range,
)
import pandas._testing as tm
from pandas.tests.copy_view.util import get_array
pytestmark = pytest.mark.filterwarnings(
"ignore:Setting a value on a view:FutureWarning"
)
@pytest.mark.parametrize("box", [lambda x: x, DatetimeIndex])
def test_datetimeindex(box):
dt = date_range("2019-12-31", periods=3, freq="D")
ser = Series(dt)
idx = box(DatetimeIndex(ser))
expected = idx.copy(deep=True)
ser.iloc[0] = Timestamp("2020-12-31")
tm.assert_index_equal(idx, expected)
def test_datetimeindex_tz_convert():
dt = date_range("2019-12-31", periods=3, freq="D", tz="Europe/Berlin")
ser = Series(dt)
idx = DatetimeIndex(ser).tz_convert("US/Eastern")
expected = idx.copy(deep=True)
ser.iloc[0] = Timestamp("2020-12-31", tz="Europe/Berlin")
tm.assert_index_equal(idx, expected)
def test_datetimeindex_tz_localize():
dt = date_range("2019-12-31", periods=3, freq="D")
ser = Series(dt)
idx = DatetimeIndex(ser).tz_localize("Europe/Berlin")
expected = idx.copy(deep=True)
ser.iloc[0] = Timestamp("2020-12-31")
tm.assert_index_equal(idx, expected)
def test_datetimeindex_isocalendar():
dt = date_range("2019-12-31", periods=3, freq="D")
ser = Series(dt)
df = DatetimeIndex(ser).isocalendar()
expected = df.index.copy(deep=True)
ser.iloc[0] = Timestamp("2020-12-31")
tm.assert_index_equal(df.index, expected)
def test_index_values():
idx = date_range("2019-12-31", periods=3, freq="D")
result = idx.values
assert result.flags.writeable is False
def test_constructor_copy_input_datetime_ndarray_default():
# GH 63388
arr = np.array(["2020-01-01", "2020-01-02"], dtype="datetime64[ns]")
idx = DatetimeIndex(arr)
assert not np.shares_memory(arr, get_array(idx))
def test_constructor_copy_input_datetime_ea_default():
# GH 63388
arr = array(["2020-01-01", "2020-01-02"], dtype="datetime64[ns]")
idx = DatetimeIndex(arr)
assert not tm.shares_memory(arr, idx.array)
def test_series_from_temporary_datetimeindex_readonly_data():
# GH 63388
arr = np.array(["2020-01-01", "2020-01-02"], dtype="datetime64[ns]")
arr.flags.writeable = False
ser = Series(DatetimeIndex(arr))
assert not np.shares_memory(arr, get_array(ser))
ser.iloc[0] = Timestamp("2020-01-01")
expected = Series(
[Timestamp("2020-01-01"), Timestamp("2020-01-02")], dtype="datetime64[ns]"
)
tm.assert_series_equal(ser, expected)

View File

@@ -0,0 +1,177 @@
import numpy as np
import pytest
from pandas import (
DataFrame,
Index,
Series,
array,
)
import pandas._testing as tm
from pandas.tests.copy_view.util import get_array
def index_view(index_data):
df = DataFrame({"a": index_data, "b": 1.5})
view = df[:]
df = df.set_index("a", drop=True)
idx = df.index
# df = None
return idx, view
def test_set_index_update_column():
df = DataFrame({"a": [1, 2], "b": 1})
df = df.set_index("a", drop=False)
expected = df.index.copy(deep=True)
df.iloc[0, 0] = 100
tm.assert_index_equal(df.index, expected)
def test_set_index_drop_update_column():
df = DataFrame({"a": [1, 2], "b": 1.5})
view = df[:]
df = df.set_index("a", drop=True)
expected = df.index.copy(deep=True)
view.iloc[0, 0] = 100
tm.assert_index_equal(df.index, expected)
def test_set_index_series():
df = DataFrame({"a": [1, 2], "b": 1.5})
ser = Series([10, 11])
df = df.set_index(ser)
expected = df.index.copy(deep=True)
ser.iloc[0] = 100
tm.assert_index_equal(df.index, expected)
def test_assign_index_as_series():
df = DataFrame({"a": [1, 2], "b": 1.5})
ser = Series([10, 11])
df.index = ser
expected = df.index.copy(deep=True)
ser.iloc[0] = 100
tm.assert_index_equal(df.index, expected)
def test_assign_index_as_index():
df = DataFrame({"a": [1, 2], "b": 1.5})
ser = Series([10, 11])
rhs_index = Index(ser)
df.index = rhs_index
rhs_index = None # overwrite to clear reference
expected = df.index.copy(deep=True)
ser.iloc[0] = 100
tm.assert_index_equal(df.index, expected)
def test_index_from_series():
ser = Series([1, 2])
idx = Index(ser)
expected = idx.copy(deep=True)
ser.iloc[0] = 100
tm.assert_index_equal(idx, expected)
def test_index_from_series_copy():
ser = Series([1, 2])
idx = Index(ser, copy=True) # noqa: F841
arr = get_array(ser)
ser.iloc[0] = 100
assert np.shares_memory(get_array(ser), arr)
def test_index_from_index():
ser = Series([1, 2])
idx = Index(ser)
idx = Index(idx)
expected = idx.copy(deep=True)
ser.iloc[0] = 100
tm.assert_index_equal(idx, expected)
@pytest.mark.parametrize(
"func",
[
lambda x: x._shallow_copy(x._values),
lambda x: x.view(),
lambda x: x.take([0, 1]),
lambda x: x.repeat([1, 1]),
lambda x: x[slice(0, 2)],
lambda x: x[[0, 1]],
lambda x: x._getitem_slice(slice(0, 2)),
lambda x: x.delete([]),
lambda x: x.rename("b"),
lambda x: x.astype("Int64", copy=False),
],
ids=[
"_shallow_copy",
"view",
"take",
"repeat",
"getitem_slice",
"getitem_list",
"_getitem_slice",
"delete",
"rename",
"astype",
],
)
def test_index_ops(func, request):
idx, view_ = index_view([1, 2])
expected = idx.copy(deep=True)
if "astype" in request.node.callspec.id:
expected = expected.astype("Int64")
idx = func(idx)
view_.iloc[0, 0] = 100
tm.assert_index_equal(idx, expected, check_names=False)
def test_infer_objects():
idx, view_ = index_view(["a", "b"])
expected = idx.copy(deep=True)
idx = idx.infer_objects(copy=False)
view_.iloc[0, 0] = "aaaa"
tm.assert_index_equal(idx, expected, check_names=False)
def test_index_to_frame():
idx = Index([1, 2, 3], name="a")
expected = idx.copy(deep=True)
df = idx.to_frame()
assert np.shares_memory(get_array(df, "a"), idx._values)
assert not df._mgr._has_no_reference(0)
df.iloc[0, 0] = 100
tm.assert_index_equal(idx, expected)
def test_index_values():
idx = Index([1, 2, 3])
result = idx.values
assert result.flags.writeable is False
def test_constructor_copy_input_ndarray_default():
arr = np.array([0, 1])
idx = Index(arr)
assert not np.shares_memory(arr, get_array(idx))
def test_constructor_copy_input_ea_default():
arr = array([0, 1], dtype="Int64")
idx = Index(arr)
assert not tm.shares_memory(arr, idx.array)
def test_series_from_temporary_index_readonly_data():
# GH 63370
arr = np.array([0, 1], dtype=np.dtype(np.int8))
arr.flags.writeable = False
ser = Series(Index(arr))
assert not np.shares_memory(arr, get_array(ser))
assert ser._mgr._has_no_reference(0)
ser[[False, True]] = np.array([0, 2], dtype=np.dtype(np.int8))
expected = Series([0, 2], dtype=np.dtype(np.int8))
tm.assert_series_equal(ser, expected)

View File

@@ -0,0 +1,29 @@
import numpy as np
from pandas import (
Interval,
IntervalIndex,
Series,
array,
)
import pandas._testing as tm
from pandas.tests.copy_view.util import get_array
def test_constructor_copy_input_interval_ea_default():
# GH 63388
arr = array([Interval(0, 1), Interval(1, 2)])
idx = IntervalIndex(arr)
assert not tm.shares_memory(arr, idx.array)
def test_series_from_temporary_intervalindex_readonly_data():
# GH 63388
arr = array([Interval(0, 1), Interval(1, 2)])
arr._left.flags.writeable = False
arr._right.flags.writeable = False
ser = Series(IntervalIndex(arr))
assert not np.shares_memory(arr._left, get_array(ser)._left)
ser.iloc[0] = Interval(5, 6)
expected = Series([Interval(5, 6), Interval(1, 2)], dtype="interval[int64, right]")
tm.assert_series_equal(ser, expected)

View File

@@ -0,0 +1,47 @@
import numpy as np
import pytest
from pandas import (
Period,
PeriodIndex,
Series,
array,
period_range,
)
import pandas._testing as tm
from pandas.tests.copy_view.util import get_array
pytestmark = pytest.mark.filterwarnings(
"ignore:Setting a value on a view:FutureWarning"
)
@pytest.mark.parametrize("box", [lambda x: x, PeriodIndex])
def test_periodindex(box):
dt = period_range("2019-12-31", periods=3, freq="D")
ser = Series(dt)
idx = box(PeriodIndex(ser))
expected = idx.copy(deep=True)
ser.iloc[0] = Period("2020-12-31")
tm.assert_index_equal(idx, expected)
def test_constructor_copy_input_period_ea_default():
# GH 63388
arr = array(["2020-01-01", "2020-01-02"], dtype="period[D]")
idx = PeriodIndex(arr)
assert not tm.shares_memory(arr, idx.array)
def test_series_from_temporary_periodindex_readonly_data():
# GH 63388
arr = array(["2020-01-01", "2020-01-02"], dtype="period[D]")
arr._ndarray.flags.writeable = False
ser = Series(PeriodIndex(arr))
assert not np.shares_memory(arr._ndarray, get_array(ser))
ser.iloc[0] = Period("2022-01-01", freq="D")
expected = Series(
[Period("2022-01-01", freq="D"), Period("2020-01-02", freq="D")],
dtype="period[D]",
)
tm.assert_series_equal(ser, expected)

View File

@@ -0,0 +1,59 @@
import numpy as np
import pytest
from pandas import (
Series,
Timedelta,
TimedeltaIndex,
array,
timedelta_range,
)
import pandas._testing as tm
from pandas.tests.copy_view.util import get_array
pytestmark = pytest.mark.filterwarnings(
"ignore:Setting a value on a view:FutureWarning"
)
@pytest.mark.parametrize(
"cons",
[
lambda x: TimedeltaIndex(x),
lambda x: TimedeltaIndex(TimedeltaIndex(x)),
],
)
def test_timedeltaindex(cons):
dt = timedelta_range("1 day", periods=3)
ser = Series(dt)
idx = cons(ser)
expected = idx.copy(deep=True)
ser.iloc[0] = Timedelta("5 days")
tm.assert_index_equal(idx, expected)
def test_constructor_copy_input_timedelta_ndarray_default():
# GH 63388
arr = np.array([1, 2], dtype="timedelta64[ns]")
idx = TimedeltaIndex(arr)
assert not np.shares_memory(arr, get_array(idx))
def test_constructor_copy_input_timedelta_ea_default():
# GH 63388
arr = array([1, 2], dtype="timedelta64[ns]")
idx = TimedeltaIndex(arr)
assert not tm.shares_memory(arr, idx.array)
def test_series_from_temporary_timedeltaindex_readonly_data():
# GH 63388
arr = np.array([1, 2], dtype="timedelta64[ns]")
arr.flags.writeable = False
ser = Series(TimedeltaIndex(arr))
assert not np.shares_memory(arr, get_array(ser))
ser.iloc[0] = Timedelta(days=1)
expected = Series(
[Timedelta(days=1), Timedelta(nanoseconds=2)], dtype="timedelta64[ns]"
)
tm.assert_series_equal(ser, expected)