test_libfrequencies.py 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. # -*- coding: utf-8 -*-
  2. import pytest
  3. from pandas._libs.tslibs.frequencies import (
  4. INVALID_FREQ_ERR_MSG, _period_str_to_code, get_rule_month, is_subperiod,
  5. is_superperiod)
  6. from pandas.tseries import offsets
  7. @pytest.mark.parametrize("obj,expected", [
  8. ("W", "DEC"),
  9. (offsets.Week(), "DEC"),
  10. ("D", "DEC"),
  11. (offsets.Day(), "DEC"),
  12. ("Q", "DEC"),
  13. (offsets.QuarterEnd(startingMonth=12), "DEC"),
  14. ("Q-JAN", "JAN"),
  15. (offsets.QuarterEnd(startingMonth=1), "JAN"),
  16. ("A-DEC", "DEC"),
  17. ("Y-DEC", "DEC"),
  18. (offsets.YearEnd(), "DEC"),
  19. ("A-MAY", "MAY"),
  20. ("Y-MAY", "MAY"),
  21. (offsets.YearEnd(month=5), "MAY")
  22. ])
  23. def test_get_rule_month(obj, expected):
  24. result = get_rule_month(obj)
  25. assert result == expected
  26. @pytest.mark.parametrize("obj,expected", [
  27. ("A", 1000),
  28. ("A-DEC", 1000),
  29. ("A-JAN", 1001),
  30. ("Y", 1000),
  31. ("Y-DEC", 1000),
  32. ("Y-JAN", 1001),
  33. ("Q", 2000),
  34. ("Q-DEC", 2000),
  35. ("Q-FEB", 2002),
  36. ("W", 4000),
  37. ("W-SUN", 4000),
  38. ("W-FRI", 4005),
  39. ("Min", 8000),
  40. ("ms", 10000),
  41. ("US", 11000),
  42. ("NS", 12000)
  43. ])
  44. def test_period_str_to_code(obj, expected):
  45. assert _period_str_to_code(obj) == expected
  46. @pytest.mark.parametrize("p1,p2,expected", [
  47. # Input validation.
  48. (offsets.MonthEnd(), None, False),
  49. (offsets.YearEnd(), None, False),
  50. (None, offsets.YearEnd(), False),
  51. (None, offsets.MonthEnd(), False),
  52. (None, None, False),
  53. (offsets.YearEnd(), offsets.MonthEnd(), True),
  54. (offsets.Hour(), offsets.Minute(), True),
  55. (offsets.Second(), offsets.Milli(), True),
  56. (offsets.Milli(), offsets.Micro(), True),
  57. (offsets.Micro(), offsets.Nano(), True)
  58. ])
  59. def test_super_sub_symmetry(p1, p2, expected):
  60. assert is_superperiod(p1, p2) is expected
  61. assert is_subperiod(p2, p1) is expected
  62. @pytest.mark.parametrize("freq,expected,aliases", [
  63. ("D", 6000, ["DAY", "DLY", "DAILY"]),
  64. ("M", 3000, ["MTH", "MONTH", "MONTHLY"]),
  65. ("N", 12000, ["NANOSECOND", "NANOSECONDLY"]),
  66. ("H", 7000, ["HR", "HOUR", "HRLY", "HOURLY"]),
  67. ("T", 8000, ["minute", "MINUTE", "MINUTELY"]),
  68. ("L", 10000, ["MILLISECOND", "MILLISECONDLY"]),
  69. ("U", 11000, ["MICROSECOND", "MICROSECONDLY"]),
  70. ("S", 9000, ["sec", "SEC", "SECOND", "SECONDLY"]),
  71. ("B", 5000, ["BUS", "BUSINESS", "BUSINESSLY", "WEEKDAY"]),
  72. ])
  73. def test_assert_aliases_deprecated(freq, expected, aliases):
  74. assert isinstance(aliases, list)
  75. assert _period_str_to_code(freq) == expected
  76. for alias in aliases:
  77. with pytest.raises(ValueError, match=INVALID_FREQ_ERR_MSG):
  78. _period_str_to_code(alias)