Uh oh!
There was an error while loading.Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork966
Expand file tree
/
Copy pathtest_base.py
More file actions
153 lines (130 loc) · 5.59 KB
/
test_base.py
File metadata and controls
153 lines (130 loc) · 5.59 KB
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
# -*- coding: utf-8 -*-
# test_base.py
# Copyright (C) 2008, 2009 Michael Trier (mtrier@gmail.com) and contributors
#
# This module is part of GitPython and is released under
# the BSD License: http://www.opensource.org/licenses/bsd-license.php
importos
importsys
importtempfile
try:
fromunittestimportSkipTest,skipIf
exceptImportError:
fromunittest2importSkipTest,skipIf
fromgitimport (
Blob,
Tree,
Commit,
TagObject
)
fromgit.compatimportis_win
fromgit.objects.utilimportget_object_type_by_name
fromgit.test.libimport (
TestBase,
assert_raises,
with_rw_repo,
with_rw_and_rw_remote_repo
)
fromgit.utilimporthex_to_bin
importgit.objects.baseasbase
importos.pathasosp
classTestBase(TestBase):
deftearDown(self):
importgc
gc.collect()
type_tuples= (("blob","8741fc1d09d61f02ffd8cded15ff603eff1ec070","blob.py"),
("tree","3a6a5e3eeed3723c09f1ef0399f81ed6b8d82e79","directory"),
("commit","4251bd59fb8e11e40c40548cba38180a9536118c",None),
("tag","e56a60e8e9cd333cfba0140a77cd12b0d9398f10",None))
deftest_base_object(self):
# test interface of base object classes
types= (Blob,Tree,Commit,TagObject)
self.assertEqual(len(types),len(self.type_tuples))
s=set()
num_objs=0
num_index_objs=0
forobj_type, (typename,hexsha,path)inzip(types,self.type_tuples):
binsha=hex_to_bin(hexsha)
item=None
ifpathisNone:
item=obj_type(self.rorepo,binsha)
else:
item=obj_type(self.rorepo,binsha,0,path)
# END handle index objects
num_objs+=1
self.assertEqual(item.hexsha,hexsha)
self.assertEqual(item.type,typename)
assertitem.size
self.assertEqual(item,item)
self.assertNotEqual(notitem,item)
self.assertEqual(str(item),item.hexsha)
assertrepr(item)
s.add(item)
ifisinstance(item,base.IndexObject):
num_index_objs+=1
ifhasattr(item,'path'):# never runs here
assertnotitem.path.startswith("/")# must be relative
assertisinstance(item.mode,int)
# END index object check
# read from stream
data_stream=item.data_stream
data=data_stream.read()
assertdata
tmpfilename=tempfile.mktemp(suffix='test-stream')
withopen(tmpfilename,'wb+')astmpfile:
self.assertEqual(item,item.stream_data(tmpfile))
tmpfile.seek(0)
self.assertEqual(tmpfile.read(),data)
os.remove(tmpfilename)
# END for each object type to create
# each has a unique sha
self.assertEqual(len(s),num_objs)
self.assertEqual(len(s|s),num_objs)
self.assertEqual(num_index_objs,2)
deftest_get_object_type_by_name(self):
fortnameinbase.Object.TYPES:
assertbase.Objectinget_object_type_by_name(tname).mro()
# END for each known type
assert_raises(ValueError,get_object_type_by_name,b"doesntexist")
deftest_object_resolution(self):
# objects must be resolved to shas so they compare equal
self.assertEqual(self.rorepo.head.reference.object,self.rorepo.active_branch.object)
@with_rw_repo('HEAD',bare=True)
deftest_with_bare_rw_repo(self,bare_rw_repo):
assertbare_rw_repo.config_reader("repository").getboolean("core","bare")
assertosp.isfile(osp.join(bare_rw_repo.git_dir,'HEAD'))
@with_rw_repo('0.1.6')
deftest_with_rw_repo(self,rw_repo):
assertnotrw_repo.config_reader("repository").getboolean("core","bare")
assertosp.isdir(osp.join(rw_repo.working_tree_dir,'lib'))
#@skipIf(HIDE_WINDOWS_FREEZE_ERRORS, "FIXME: Freezes! sometimes...")
@with_rw_and_rw_remote_repo('0.1.6')
deftest_with_rw_remote_and_rw_repo(self,rw_repo,rw_remote_repo):
assertnotrw_repo.config_reader("repository").getboolean("core","bare")
assertrw_remote_repo.config_reader("repository").getboolean("core","bare")
assertosp.isdir(osp.join(rw_repo.working_tree_dir,'lib'))
@skipIf(sys.version_info< (3,)andis_win,
"Unicode woes, see https://github.com/gitpython-developers/GitPython/pull/519")
@with_rw_repo('0.1.6')
deftest_add_unicode(self,rw_repo):
filename=u"שלום.txt"
file_path=osp.join(rw_repo.working_dir,filename)
# verify first that we could encode file name in this environment
try:
file_path.encode(sys.getfilesystemencoding())
exceptUnicodeEncodeError:
raiseSkipTest("Environment doesn't support unicode filenames")
withopen(file_path,"wb")asfp:
fp.write(b'something')
ifis_win:
# on windows, there is no way this works, see images on
# https://github.com/gitpython-developers/GitPython/issues/147#issuecomment-68881897
# Therefore, it must be added using the python implementation
rw_repo.index.add([file_path])
# However, when the test winds down, rmtree fails to delete this file, which is recognized
# as ??? only.
else:
# on posix, we can just add unicode files without problems
rw_repo.git.add(rw_repo.working_dir)
# end
rw_repo.index.commit('message')