-
-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathsimulate.py
executable file
·47 lines (34 loc) · 1.09 KB
/
simulate.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#!/usr/bin/env python
import sys
from os import path
sys.path.insert(0, path.join(path.dirname(__file__), 'src'))
from datetime import timedelta
from tarsnapper.test import BackupSimulator
from tarsnapper.config import parse_deltas
def main(argv):
if '-h' in argv:
print("./simulate.py [backup-timestamps]")
return 1
# Do some default simulation
if not argv:
s = BackupSimulator(parse_deltas('1d 7d 30d'))
until = s.now + timedelta(days=17)
while s.now <= until:
s.go_by(timedelta(days=1))
s.backup()
for name, date in s.backups.items():
print(name)
# Simulate a backup with the timestamps given
else:
s = BackupSimulator(parse_deltas('1d 7d 30d'))
s.add([d for d in argv])
deleted, _ = s.expire()
print("Deleted backups:")
for name in deleted:
print(name)
print("")
print("Remaining backups:")
for name, date in s.backups.items():
print(name)
if __name__ == '__main__':
sys.exit(main(sys.argv[1:]) or 0)