##// END OF EJS Templates
revlog: use radix tree also for matching keys shorter than 4 hex digits...
revlog: use radix tree also for matching keys shorter than 4 hex digits I don't know what the reason for the 4-digit limit was, and I can't think of any real disadvantages of using the radix tree also when the requested minimum length is short. This speeds up `hg log -T '{shortest(node,1)}\n'` from 2m16s to 4.5s by making that not fall back to pure code. Differential Revision: https://phab.mercurial-scm.org/D3453

File last commit:

r35097:66c5a8cf default
r37875:92ed344a @27 default
Show More
test-lfs-pointer.py
41 lines | 1.2 KiB | text/x-python | PythonLexer
/ tests / test-lfs-pointer.py
Matt Harbison
lfs: import the Facebook git-lfs client extension...
r35097 from __future__ import absolute_import, print_function
import os
import sys
# make it runnable using python directly without run-tests.py
sys.path[0:0] = [os.path.join(os.path.dirname(__file__), '..')]
from hgext.lfs import pointer
def tryparse(text):
r = {}
try:
r = pointer.deserialize(text)
print('ok')
except Exception as ex:
print(ex)
if r:
text2 = r.serialize()
if text2 != text:
print('reconstructed text differs')
return r
t = ('version https://git-lfs.github.com/spec/v1\n'
'oid sha256:4d7a214614ab2935c943f9e0ff69d22eadbb8f32b1'
'258daaa5e2ca24d17e2393\n'
'size 12345\n'
'x-foo extra-information\n')
tryparse('')
tryparse(t)
tryparse(t.replace('git-lfs', 'unknown'))
tryparse(t.replace('v1\n', 'v1\n\n'))
tryparse(t.replace('sha256', 'ahs256'))
tryparse(t.replace('sha256:', ''))
tryparse(t.replace('12345', '0x12345'))
tryparse(t.replace('extra-information', 'extra\0information'))
tryparse(t.replace('extra-information', 'extra\ninformation'))
tryparse(t.replace('x-foo', 'x_foo'))
tryparse(t.replace('oid', 'blobid'))
tryparse(t.replace('size', 'size-bytes').replace('oid', 'object-id'))