11308: Fix bytes vs. str problems.
[arvados.git] / sdk / python / tests / test_cache.py
1 from __future__ import print_function
2 from __future__ import absolute_import
3
4 from builtins import str
5 from builtins import range
6 import md5
7 import mock
8 import os
9 import random
10 import shutil
11 import sys
12 import tempfile
13 import threading
14 import unittest
15
16 import arvados
17 import arvados.cache
18 from . import run_test_server
19
20
21 def _random(n):
22     return bytearray(random.getrandbits(8) for _ in range(n))
23
24
25 class CacheTestThread(threading.Thread):
26     def __init__(self, dir):
27         super(CacheTestThread, self).__init__()
28         self._dir = dir
29
30     def run(self):
31         c = arvados.cache.SafeHTTPCache(self._dir)
32         url = 'http://example.com/foo'
33         self.ok = True
34         for x in range(16):
35             try:
36                 data_in = _random(128)
37                 data_in = md5.new(data_in).hexdigest() + bytes("\n") + bytes(data_in)
38                 c.set(url, data_in)
39                 data_out = c.get(url)
40                 digest, _, content = data_out.partition("\n")
41                 if digest != md5.new(content).hexdigest():
42                     self.ok = False
43             except Exception as err:
44                 self.ok = False
45                 print("cache failed: {}".format(err), file=sys.stderr)
46
47
48 class CacheTest(unittest.TestCase):
49     def setUp(self):
50         self._dir = tempfile.mkdtemp()
51
52     def tearDown(self):
53         shutil.rmtree(self._dir)
54
55     def test_cache_create_error(self):
56         _, filename = tempfile.mkstemp()
57         home_was = os.environ['HOME']
58         os.environ['HOME'] = filename
59         try:
60             c = arvados.http_cache('test')
61             self.assertEqual(None, c)
62         finally:
63             os.environ['HOME'] = home_was
64             os.unlink(filename)
65
66     def test_cache_crud(self):
67         c = arvados.cache.SafeHTTPCache(self._dir, max_age=0)
68         url = 'https://example.com/foo?bar=baz'
69         data1 = _random(256)
70         data2 = _random(128)
71         self.assertEqual(None, c.get(url))
72         c.delete(url)
73         c.set(url, data1)
74         self.assertEqual(data1, c.get(url))
75         c.delete(url)
76         self.assertEqual(None, c.get(url))
77         c.set(url, data1)
78         c.set(url, data2)
79         self.assertEqual(data2, c.get(url))
80
81     def test_cache_threads(self):
82         threads = []
83         for _ in range(64):
84             t = CacheTestThread(dir=self._dir)
85             t.start()
86             threads.append(t)
87         for t in threads:
88             t.join()
89             self.assertTrue(t.ok)
90
91
92 class CacheIntegrationTest(run_test_server.TestCaseWithServers):
93     MAIN_SERVER = {}
94
95     def test_cache_used_by_default_client(self):
96         with mock.patch('arvados.cache.SafeHTTPCache.get') as getter:
97             arvados.api('v1')._rootDesc.get('foobar')
98             getter.assert_called()