test_custom_business_day.py 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. """
  2. Tests for offsets.CustomBusinessDay / CDay
  3. """
  4. from datetime import (
  5. datetime,
  6. timedelta,
  7. )
  8. import numpy as np
  9. import pytest
  10. from pandas._libs.tslibs.offsets import CDay
  11. from pandas import (
  12. _testing as tm,
  13. read_pickle,
  14. )
  15. from pandas.tests.tseries.offsets.common import assert_offset_equal
  16. from pandas.tseries.holiday import USFederalHolidayCalendar
  17. @pytest.fixture
  18. def offset():
  19. return CDay()
  20. @pytest.fixture
  21. def offset2():
  22. return CDay(2)
  23. class TestCustomBusinessDay:
  24. def test_repr(self, offset, offset2):
  25. assert repr(offset) == "<CustomBusinessDay>"
  26. assert repr(offset2) == "<2 * CustomBusinessDays>"
  27. expected = "<BusinessDay: offset=datetime.timedelta(days=1)>"
  28. assert repr(offset + timedelta(1)) == expected
  29. def test_holidays(self):
  30. # Define a TradingDay offset
  31. holidays = ["2012-05-01", datetime(2013, 5, 1), np.datetime64("2014-05-01")]
  32. tday = CDay(holidays=holidays)
  33. for year in range(2012, 2015):
  34. dt = datetime(year, 4, 30)
  35. xp = datetime(year, 5, 2)
  36. rs = dt + tday
  37. assert rs == xp
  38. def test_weekmask(self):
  39. weekmask_saudi = "Sat Sun Mon Tue Wed" # Thu-Fri Weekend
  40. weekmask_uae = "1111001" # Fri-Sat Weekend
  41. weekmask_egypt = [1, 1, 1, 1, 0, 0, 1] # Fri-Sat Weekend
  42. bday_saudi = CDay(weekmask=weekmask_saudi)
  43. bday_uae = CDay(weekmask=weekmask_uae)
  44. bday_egypt = CDay(weekmask=weekmask_egypt)
  45. dt = datetime(2013, 5, 1)
  46. xp_saudi = datetime(2013, 5, 4)
  47. xp_uae = datetime(2013, 5, 2)
  48. xp_egypt = datetime(2013, 5, 2)
  49. assert xp_saudi == dt + bday_saudi
  50. assert xp_uae == dt + bday_uae
  51. assert xp_egypt == dt + bday_egypt
  52. xp2 = datetime(2013, 5, 5)
  53. assert xp2 == dt + 2 * bday_saudi
  54. assert xp2 == dt + 2 * bday_uae
  55. assert xp2 == dt + 2 * bday_egypt
  56. def test_weekmask_and_holidays(self):
  57. weekmask_egypt = "Sun Mon Tue Wed Thu" # Fri-Sat Weekend
  58. holidays = ["2012-05-01", datetime(2013, 5, 1), np.datetime64("2014-05-01")]
  59. bday_egypt = CDay(holidays=holidays, weekmask=weekmask_egypt)
  60. dt = datetime(2013, 4, 30)
  61. xp_egypt = datetime(2013, 5, 5)
  62. assert xp_egypt == dt + 2 * bday_egypt
  63. @pytest.mark.filterwarnings("ignore:Non:pandas.errors.PerformanceWarning")
  64. def test_calendar(self):
  65. calendar = USFederalHolidayCalendar()
  66. dt = datetime(2014, 1, 17)
  67. assert_offset_equal(CDay(calendar=calendar), dt, datetime(2014, 1, 21))
  68. def test_roundtrip_pickle(self, offset, offset2):
  69. def _check_roundtrip(obj):
  70. unpickled = tm.round_trip_pickle(obj)
  71. assert unpickled == obj
  72. _check_roundtrip(offset)
  73. _check_roundtrip(offset2)
  74. _check_roundtrip(offset * 2)
  75. def test_pickle_compat_0_14_1(self, datapath):
  76. hdays = [datetime(2013, 1, 1) for ele in range(4)]
  77. pth = datapath("tseries", "offsets", "data", "cday-0.14.1.pickle")
  78. cday0_14_1 = read_pickle(pth)
  79. cday = CDay(holidays=hdays)
  80. assert cday == cday0_14_1