def test_process_time_point_str_calendar(self): """DateTimeOperator.process_time_point_str(...) Alternate calendars. """ self.assertEqual( 'gregorian', isodatetime.datetimeoper.DateTimeOperator.get_calendar_mode()) self.assertRaises( KeyError, isodatetime.datetimeoper.DateTimeOperator.set_calendar_mode, 'milkywaygalactic') for cal, str_in, offsets, str_out in [ # 360day ('360day', '20130301', ['-P1D'], '20130230'), ('360day', '20130230', ['P1D'], '20130301'), # 360_day ('360_day', '20130301', ['-P1D'], '20130230'), ('360_day', '20130230', ['P1D'], '20130301'), # 365day ('365day', '20130301', ['-P1D'], '20130228'), ('365day', '20130228', ['P1D'], '20130301'), # 365_day ('365_day', '20130301', ['-P1D'], '20130228'), ('365_day', '20130228', ['P1D'], '20130301'), # 366day ('366day', '20130301', ['-P1D'], '20130229'), ('366day', '20130229', ['P1D'], '20130301'), # 366_day ('366_day', '20130301', ['-P1D'], '20130229'), ('366_day', '20130229', ['P1D'], '20130301'), ]: # Calendar mode, is unfortunately, a global variable, # so needs to reset value on return. calendar_mode = ( isodatetime.datetimeoper.DateTimeOperator.get_calendar_mode()) # Calendar mode by constructor. try: datetimeoper = isodatetime.datetimeoper.DateTimeOperator( calendar_mode=cal) self.assertEqual( str_out, datetimeoper.process_time_point_str(str_in, offsets)) finally: isodatetime.datetimeoper.DateTimeOperator.set_calendar_mode( calendar_mode) # Calendar mode by environment variable try: environ = os.environ.copy() key = (isodatetime.datetimeoper.DateTimeOperator. ENV_CALENDAR_MODE) environ[key] = cal with patch.dict(os.environ, environ, clear=True): datetimeoper = isodatetime.datetimeoper.DateTimeOperator() self.assertEqual( str_out, datetimeoper.process_time_point_str(str_in, offsets)) finally: isodatetime.datetimeoper.DateTimeOperator.set_calendar_mode( calendar_mode)
def test_process_time_point_str_now_0(self, mock_now_func): """DateTimeOperator.process_time_point_str()""" # 2009-02-13T23:31:30Z mock_now = seconds2point(1234567890) mock_now_func.return_value = mock_now datetimeoper = isodatetime.datetimeoper.DateTimeOperator() self.assertEqual(str(mock_now), datetimeoper.process_time_point_str()) self.assertEqual( str(mock_now), datetimeoper.process_time_point_str(datetimeoper.STR_NOW))
def test_process_time_point_str_calendar(self): """DateTimeOperator.process_time_point_str(...) Alternate calendars. """ self.assertEqual( 'gregorian', isodatetime.datetimeoper.DateTimeOperator.get_calendar_mode()) self.assertRaises( KeyError, isodatetime.datetimeoper.DateTimeOperator.set_calendar_mode, 'milkywaygalactic') for cal, str_in, offsets, str_out in [ # 360day ('360day', '20130301', ['-P1D'], '20130230'), ('360day', '20130230', ['P1D'], '20130301'), # 365day ('365day', '20130301', ['-P1D'], '20130228'), ('365day', '20130228', ['P1D'], '20130301'), # 366day ('366day', '20130301', ['-P1D'], '20130229'), ('366day', '20130229', ['P1D'], '20130301'), ]: # Calendar mode, is unfortunately, a global variable, # so needs to reset value on return. calendar_mode = ( isodatetime.datetimeoper.DateTimeOperator.get_calendar_mode()) # Calendar mode by constructor. try: datetimeoper = isodatetime.datetimeoper.DateTimeOperator( calendar_mode=cal) self.assertEqual( str_out, datetimeoper.process_time_point_str(str_in, offsets)) finally: isodatetime.datetimeoper.DateTimeOperator.set_calendar_mode( calendar_mode) # Calendar mode by environment variable try: environ = os.environ.copy() key = ( isodatetime.datetimeoper.DateTimeOperator.ENV_CALENDAR_MODE ) environ[key] = cal with patch.dict(os.environ, environ, clear=True): datetimeoper = isodatetime.datetimeoper.DateTimeOperator() self.assertEqual( str_out, datetimeoper.process_time_point_str( str_in, offsets)) finally: isodatetime.datetimeoper.DateTimeOperator.set_calendar_mode( calendar_mode)
def test_process_time_point_str_ref_1(self): """DateTimeOperator.process_time_point_str('ref') With explicit reference time. """ # 2009-02-13T23:31:30Z ref_point_str = str(seconds2point(1234567890)) datetimeoper = isodatetime.datetimeoper.DateTimeOperator( ref_point_str=ref_point_str) self.assertEqual( ref_point_str, datetimeoper.process_time_point_str(datetimeoper.STR_REF))
def test_process_time_point_str_format(self): """DateTimeOperator.process_time_point_str(...) With parse_format and print_format. """ for parse_format, print_format, point_str_in, point_str_out in [ ('%d/%m/%Y %H:%M:%S', '%Y-%m-%dT%H:%M:%S', '24/12/2012 06:00:00', '2012-12-24T06:00:00'), ('%Y,%M,%d,%H', '%Y%M%d%H', '2014,01,02,05', '2014010205'), ('%Y%m%d', '%y%m%d', '20141231', '141231'), ('%Y%m%d%H%M%S', '%s', '20140402100000', '1396432800'), ('%s', '%Y%m%dT%H%M%S%z', '1396429200', '20140402T090000+0000'), ('%d/%m/%Y %H:%M:%S', 'CCYY-MM-DDThh:mm', '24/12/2012 06:00:00', '2012-12-24T06:00'), (None, 'CCYY-MM-DDThh:mm+01:00', '2014-091T15:14:03Z', '2014-04-01T16:14+01:00'), (None, '%m', '2014-02-01T04:05:06', '02'), (None, '%Y', '2014-02-01T04:05:06', '2014'), (None, '%H', '2014-02-01T04:05:06', '04'), (None, '%Y%m%d_%H%M%S', '2014-02-01T04:05:06', '20140201_040506'), (None, '%Y.file', '2014-02-01T04:05:06', '2014.file'), (None, 'y%Ym%md%d', '2014-02-01T04:05:06', 'y2014m02d01'), (None, '%F', '2014-02-01T04:05:06', '2014-02-01'), ]: datetimeoper = isodatetime.datetimeoper.DateTimeOperator( utc_mode=True, parse_format=parse_format) self.assertEqual( point_str_out, datetimeoper.process_time_point_str( point_str_in, print_format=print_format)) # Bad parse format datetimeoper = isodatetime.datetimeoper.DateTimeOperator( parse_format='%o') with self.assertRaises(ValueError) as ctxmgr: datetimeoper.process_time_point_str('0000') self.assertEqual( "'o' is a bad directive in format '%o'", str(ctxmgr.exception))
def test_process_time_point_str_format(self): """DateTimeOperator.process_time_point_str(...) With parse_format and print_format. """ for parse_format, print_format, point_str_in, point_str_out in [ ('%d/%m/%Y %H:%M:%S', '%Y-%m-%dT%H:%M:%S', '24/12/2012 06:00:00', '2012-12-24T06:00:00'), ('%Y,%M,%d,%H', '%Y%M%d%H', '2014,01,02,05', '2014010205'), ('%Y%m%d', '%y%m%d', '20141231', '141231'), ('%Y%m%d%H%M%S', '%s', '20140402100000', '1396432800'), ('%s', '%Y%m%dT%H%M%S%z', '1396429200', '20140402T090000+0000'), ('%d/%m/%Y %H:%M:%S', 'CCYY-MM-DDThh:mm', '24/12/2012 06:00:00', '2012-12-24T06:00'), (None, 'CCYY-MM-DDThh:mm+01:00', '2014-091T15:14:03Z', '2014-04-01T16:14+01:00'), (None, '%m', '2014-02-01T04:05:06', '02'), (None, '%Y', '2014-02-01T04:05:06', '2014'), (None, '%H', '2014-02-01T04:05:06', '04'), (None, '%Y%m%d_%H%M%S', '2014-02-01T04:05:06', '20140201_040506'), (None, '%Y.file', '2014-02-01T04:05:06', '2014.file'), (None, 'y%Ym%md%d', '2014-02-01T04:05:06', 'y2014m02d01'), (None, '%F', '2014-02-01T04:05:06', '2014-02-01'), ]: datetimeoper = isodatetime.datetimeoper.DateTimeOperator( utc_mode=True, parse_format=parse_format) self.assertEqual( point_str_out, datetimeoper.process_time_point_str(point_str_in, print_format=print_format)) # Bad parse format datetimeoper = isodatetime.datetimeoper.DateTimeOperator( parse_format='%o') with self.assertRaises(ValueError) as ctxmgr: datetimeoper.process_time_point_str('0000') self.assertEqual("'o' is a bad directive in format '%o'", str(ctxmgr.exception))
def test_process_time_point_str_ref_2(self): """DateTimeOperator.process_time_point_str('ref') With explicit reference time as ISODATETIMEREF environment variable. """ # 2009-02-13T23:31:30Z ref_point_str = str(seconds2point(1234567890)) # Set ISODATETIMEREF. # Or the test may not work. environ = os.environ.copy() environ[isodatetime.datetimeoper.DateTimeOperator.ENV_REF] = ( ref_point_str) with patch.dict(os.environ, environ): datetimeoper = isodatetime.datetimeoper.DateTimeOperator() self.assertEqual( ref_point_str, datetimeoper.process_time_point_str(datetimeoper.STR_REF))
def test_process_time_point_str_ref_0(self, mock_now_func): """DateTimeOperator.process_time_point_str('ref') But without explicit reference time, so default to now. """ # 2009-02-13T23:31:30Z mock_now = seconds2point(1234567890) mock_now_func.return_value = mock_now datetimeoper = isodatetime.datetimeoper.DateTimeOperator() # Ensure that the ISODATETIMEREF environment variable is not set # Or the test may not work. environ = os.environ.copy() if datetimeoper.ENV_REF in environ: del environ[datetimeoper.ENV_REF] with patch.dict(os.environ, environ, clear=True): self.assertEqual( str(mock_now), datetimeoper.process_time_point_str(datetimeoper.STR_REF))
def test_process_time_point_str_x(self): """DateTimeOperator.process_time_point_str(...) Basic parse and dump of a time point string. """ # 2009-02-13T23:31:30Z point_str = str(seconds2point(1234567890)) datetimeoper = isodatetime.datetimeoper.DateTimeOperator() # Unix time self.assertEqual( '2019-01-11T10:40:15Z', datetimeoper.process_time_point_str( 'Fri 11 Jan 10:40:15 UTC 2019', print_format=datetimeoper.CURRENT_TIME_DUMP_FORMAT_Z)) # Basic self.assertEqual(point_str, datetimeoper.process_time_point_str(point_str)) # +ve offset point_str_1 = str(seconds2point(1234567890 + 3600)) self.assertEqual( point_str_1, datetimeoper.process_time_point_str(point_str, ['PT1H'])) # +ve offset, time point like duration point_str_1 = str(seconds2point(1234567890 + 3600)) self.assertEqual( point_str_1, datetimeoper.process_time_point_str(point_str, ['P0000-00-00T01'])) # -ve offset point_str_2 = str(seconds2point(1234567890 - 86400)) self.assertEqual( point_str_2, datetimeoper.process_time_point_str(point_str, ['-P1D'])) # offsets that cancel out self.assertEqual( point_str, datetimeoper.process_time_point_str(point_str, ['PT1H', '-PT60M'])) # Multiple offsets in 1 string point_str_3 = str(seconds2point(1234567890 - 86400 - 3600)) self.assertEqual( point_str_3, datetimeoper.process_time_point_str(point_str, ['-P1DT1H'])) # Multiple offsets self.assertEqual( point_str_3, datetimeoper.process_time_point_str(point_str, ['-P1D', '-PT1H'])) # Bad time point string self.assertRaises(ValueError, datetimeoper.process_time_point_str, 'teatime') # Bad offset string with self.assertRaises( isodatetime.datetimeoper.OffsetValueError, ) as ctxmgr: datetimeoper.process_time_point_str(point_str, ['ages']) self.assertEqual('ages: bad offset value', str(ctxmgr.exception)) # Bad offset string, unsupported time point like duration with self.assertRaises( isodatetime.datetimeoper.OffsetValueError, ) as ctxmgr: datetimeoper.process_time_point_str(point_str, ['P0000-W01-1']) self.assertEqual('P0000-W01-1: bad offset value', str(ctxmgr.exception))
def test_process_time_point_str_x(self): """DateTimeOperator.process_time_point_str(...) Basic parse and dump of a time point string. """ # 2009-02-13T23:31:30Z point_str = str(seconds2point(1234567890)) datetimeoper = isodatetime.datetimeoper.DateTimeOperator() # Unix time self.assertEqual( '2019-01-11T10:40:15Z', datetimeoper.process_time_point_str( 'Fri 11 Jan 10:40:15 UTC 2019', print_format=datetimeoper.CURRENT_TIME_DUMP_FORMAT_Z)) # Basic self.assertEqual( point_str, datetimeoper.process_time_point_str(point_str)) # +ve offset point_str_1 = str(seconds2point(1234567890 + 3600)) self.assertEqual( point_str_1, datetimeoper.process_time_point_str(point_str, ['PT1H'])) # +ve offset, time point like duration point_str_1 = str(seconds2point(1234567890 + 3600)) self.assertEqual( point_str_1, datetimeoper.process_time_point_str(point_str, ['P0000-00-00T01'])) # -ve offset point_str_2 = str(seconds2point(1234567890 - 86400)) self.assertEqual( point_str_2, datetimeoper.process_time_point_str(point_str, ['-P1D'])) # offsets that cancel out self.assertEqual( point_str, datetimeoper.process_time_point_str(point_str, ['PT1H', '-PT60M'])) # Multiple offsets in 1 string point_str_3 = str(seconds2point(1234567890 - 86400 - 3600)) self.assertEqual( point_str_3, datetimeoper.process_time_point_str(point_str, ['-P1DT1H'])) # Multiple offsets self.assertEqual( point_str_3, datetimeoper.process_time_point_str(point_str, ['-P1D', '-PT1H'])) # Bad time point string self.assertRaises( ValueError, datetimeoper.process_time_point_str, 'teatime') # Bad offset string with self.assertRaises( isodatetime.datetimeoper.OffsetValueError, ) as ctxmgr: datetimeoper.process_time_point_str(point_str, ['ages']) self.assertEqual('ages: bad offset value', str(ctxmgr.exception)) # Bad offset string, unsupported time point like duration with self.assertRaises( isodatetime.datetimeoper.OffsetValueError, ) as ctxmgr: datetimeoper.process_time_point_str(point_str, ['P0000-W01-1']) self.assertEqual( 'P0000-W01-1: bad offset value', str(ctxmgr.exception))