|
| 1 | +# -*- coding: utf-8 -*- |
| 2 | + |
| 3 | +import numpy as np |
| 4 | +import pytest |
| 5 | + |
| 6 | +from pandas.core.dtypes.cast import maybe_upcast_putmask |
| 7 | + |
| 8 | +from pandas import Series |
| 9 | +from pandas.util import testing as tm |
| 10 | + |
| 11 | + |
| 12 | +@pytest.mark.parametrize("result", [ |
| 13 | + Series([10, 11, 12]), |
| 14 | + [10, 11, 12], |
| 15 | + (10, 11, 12) |
| 16 | +]) |
| 17 | +def test_upcast_error(result): |
| 18 | + # GH23823 |
| 19 | + mask = np.array([False, True, False]) |
| 20 | + other = np.array([61, 62, 63]) |
| 21 | + with pytest.raises(ValueError): |
| 22 | + result, _ = maybe_upcast_putmask(result, mask, other) |
| 23 | + |
| 24 | + |
| 25 | +@pytest.mark.parametrize("arr, other, exp_changed, expected", [ |
| 26 | + (np.arange(1, 6), np.array([61, 62, 63]), |
| 27 | + False, np.array([1, 61, 3, 62, 63])), |
| 28 | + (np.arange(1, 6), np.array([61.1, 62.2, 63.3]), |
| 29 | + True, np.array([1, 61.1, 3, 62.2, 63.3])), |
| 30 | + (np.arange(1, 6), np.nan, |
| 31 | + True, np.array([1, np.nan, 3, np.nan, np.nan])), |
| 32 | + (np.arange(10, 15), np.array([61, 62]), |
| 33 | + False, np.array([10, 61, 12, 62, 61])), |
| 34 | + (np.arange(10, 15), np.array([61, np.nan]), |
| 35 | + True, np.array([10, 61, 12, np.nan, 61])) |
| 36 | +]) |
| 37 | +def test_upcast(arr, other, exp_changed, expected): |
| 38 | + # GH23823 |
| 39 | + mask = np.array([False, True, False, True, True]) |
| 40 | + result, changed = maybe_upcast_putmask(arr, mask, other) |
| 41 | + |
| 42 | + assert changed == exp_changed |
| 43 | + tm.assert_numpy_array_equal(result, expected) |
| 44 | + |
| 45 | + |
| 46 | +@pytest.mark.parametrize("arr, other, exp_changed, expected", [ |
| 47 | + (np.arange('2019-01-01', '2019-01-06', dtype='datetime64[D]'), |
| 48 | + np.arange('2018-01-01', '2018-01-04', dtype='datetime64[D]'), |
| 49 | + False, np.array(['2019-01-01', '2018-01-01', '2019-01-03', |
| 50 | + '2018-01-02', '2018-01-03'], dtype='datetime64[D]')), |
| 51 | + (np.arange('2019-01-01', '2019-01-06', dtype='datetime64[D]'), np.nan, |
| 52 | + False, np.array(['2019-01-01', np.datetime64('NaT'), |
| 53 | + '2019-01-03', np.datetime64('NaT'), |
| 54 | + np.datetime64('NaT')], dtype='datetime64[D]')), |
| 55 | + (np.arange('2019-01-01', '2019-01-06', dtype='datetime64[D]'), |
| 56 | + np.arange('2018-01-01', '2018-01-03', dtype='datetime64[D]'), |
| 57 | + False, np.array(['2019-01-01', '2018-01-01', '2019-01-03', |
| 58 | + '2018-01-02', '2018-01-01'], dtype='datetime64[D]')) |
| 59 | +]) |
| 60 | +def test_upcast_datetime(arr, other, exp_changed, expected): |
| 61 | + # GH23823 |
| 62 | + mask = np.array([False, True, False, True, True]) |
| 63 | + result, changed = maybe_upcast_putmask(arr, mask, other) |
| 64 | + |
| 65 | + assert changed == exp_changed |
| 66 | + tm.assert_numpy_array_equal(result, expected) |
0 commit comments