summaryrefslogtreecommitdiff
path: root/git/test/db/py/test_pack.py
blob: 5043f446cdcbe3ac87c486620e130e00f14c319e (plain)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
# Copyright (C) 2010, 2011 Sebastian Thiel (byronimo@gmail.com) and contributors
#
# This module is part of GitDB and is released under
# the New BSD License: http://www.opensource.org/licenses/bsd-license.php
from git.test.db.lib import TestDBBase, with_packs_rw

from git.db.py.pack import PurePackedODB
from git.test.lib import fixture_path

from git.exc import BadObject, AmbiguousObjectName

import os
import random

class TestPackDB(TestDBBase):
	
	needs_ro_repo = False 
	
	@with_packs_rw
	def test_writing(self, path):
		pdb = PurePackedODB(path)
		
		# on demand, we init our pack cache
		num_packs = len(pdb.entities())
		assert num_packs
		assert pdb._st_mtime != 0
		
		# test pack directory changed: 
		# packs removed - rename a file, should affect the glob
		pack_path = pdb.entities()[0].pack().path()
		new_pack_path = pack_path + "renamed"
		os.rename(pack_path, new_pack_path)
		
		pdb.update_cache(force=True)
		assert len(pdb.entities()) == num_packs - 1
		
		# packs added
		os.rename(new_pack_path, pack_path)
		pdb.update_cache(force=True)
		assert len(pdb.entities()) == num_packs
	
		# bang on the cache
		# access the Entities directly, as there is no iteration interface
		# yet ( or required for now )
		sha_list = list(pdb.sha_iter())
		assert len(sha_list) == pdb.size()
		
		# hit all packs in random order
		random.shuffle(sha_list)
		
		for sha in sha_list:
			info = pdb.info(sha)
			stream = pdb.stream(sha)
		# END for each sha to query
		
		
		# test short finding - be a bit more brutal here
		max_bytes = 19
		min_bytes = 2
		num_ambiguous = 0
		for i, sha in enumerate(sha_list):
			short_sha = sha[:max((i % max_bytes), min_bytes)]
			try:
				assert pdb.partial_to_complete_sha(short_sha, len(short_sha)*2) == sha
			except AmbiguousObjectName:
				num_ambiguous += 1
				pass # valid, we can have short objects
			# END exception handling
		# END for each sha to find
		
		# we should have at least one ambiguous, considering the small sizes
		# but in our pack, there is no ambigious ... 
		# assert num_ambiguous
		
		# non-existing
		self.failUnlessRaises(BadObject, pdb.partial_to_complete_sha, "\0\0", 4)