mirror of
https://github.com/borgbackup/borg.git
synced 2026-03-16 23:52:43 -04:00
Make timestamp helper timezone-aware
This commit is contained in:
parent
2c478f4ef1
commit
168b6985aa
2 changed files with 3 additions and 3 deletions
|
|
@ -606,7 +606,7 @@ def timestamp(s):
|
|||
try:
|
||||
# is it pointing to a file / directory?
|
||||
ts = safe_s(os.stat(s).st_mtime)
|
||||
return datetime.utcfromtimestamp(ts)
|
||||
return datetime.fromtimestamp(ts, tz=timezone.utc)
|
||||
except OSError:
|
||||
# didn't work, try parsing as timestamp. UTC, no TZ, no microsecs support.
|
||||
for format in ('%Y-%m-%dT%H:%M:%SZ', '%Y-%m-%dT%H:%M:%S+00:00',
|
||||
|
|
@ -615,7 +615,7 @@ def timestamp(s):
|
|||
'%Y-%m-%d', '%Y-%j',
|
||||
):
|
||||
try:
|
||||
return datetime.strptime(s, format)
|
||||
return datetime.strptime(s, format).replace(tzinfo=timezone.utc)
|
||||
except ValueError:
|
||||
continue
|
||||
raise ValueError
|
||||
|
|
|
|||
|
|
@ -190,7 +190,7 @@ class TestLocationWithoutEnv:
|
|||
"Location(proto='ssh', user=None, host='host', port=None, path='/path', archive='2016-12-31@23:59:59')"
|
||||
|
||||
def test_with_timestamp(self):
|
||||
assert repr(Location('path::archive-{utcnow}').with_timestamp(datetime(2002, 9, 19))) == \
|
||||
assert repr(Location('path::archive-{utcnow}').with_timestamp(datetime(2002, 9, 19, tzinfo=timezone.utc))) == \
|
||||
"Location(proto='file', user=None, host=None, port=None, path='path', archive='archive-2002-09-19T00:00:00')"
|
||||
|
||||
def test_underspecified(self, monkeypatch):
|
||||
|
|
|
|||
Loading…
Reference in a new issue