]> arthur.barton.de Git - bup.git/blob - t/ns-timestamp-resolutions
574fad5bb6979918e265742e08b7292f98c1b5ee
[bup.git] / t / ns-timestamp-resolutions
1 #!/bin/sh
2 """": # -*-python-*-
3 # https://sourceware.org/bugzilla/show_bug.cgi?id=26034
4 export "BUP_ARGV_0"="$0"
5 arg_i=1
6 for arg in "$@"; do
7     export "BUP_ARGV_${arg_i}"="$arg"
8     shift
9     arg_i=$((arg_i + 1))
10 done
11 bup_python="$(dirname "$0")/../lib/cmd/bup-python" || exit $?
12 exec "$bup_python" "$0"
13 """
14 # end of bup preamble
15
16 from __future__ import absolute_import
17 import os, sys
18
19 from bup.compat import argv_bytes
20 from bup.helpers import handle_ctrl_c, saved_errors
21 from bup.io import byte_stream
22 from bup import compat, metadata, options
23 import bup.xstat as xstat
24
25
26 optspec = """
27 ns-timestamp-resolutions TEST_FILE_NAME
28 --
29 """
30
31 handle_ctrl_c()
32
33 o = options.Options(optspec)
34 opt, flags, extra = o.parse(compat.argv[1:])
35
36 sys.stdout.flush()
37 out = byte_stream(sys.stdout)
38
39 if len(extra) != 1:
40     o.fatal('must specify a test file name')
41
42 target = argv_bytes(extra[0])
43
44 open(target, 'w').close()
45 xstat.utime(target, (123456789, 123456789))
46 meta = metadata.from_path(target)
47
48 def ns_resolution(x):
49     n = 1;
50     while n < 10**9 and x % 10 == 0:
51         x /= 10
52         n *= 10
53     return n
54
55 out.write(b'%d %d\n' % (ns_resolution(meta.atime),
56                         ns_resolution(meta.mtime)))
57
58 if saved_errors:
59     log('warning: %d errors encountered\n' % len(saved_errors))
60     sys.exit(1)