mirror of
https://github.com/facebook/sapling.git
synced 2024-10-06 14:58:03 +03:00
44343769f8
Summary: We want to rename away from "mercurial". Rather than rename the "mercurial" Python package, we opted to just collapse it into the parent "edenscm" package. This is also a step towards further organizing we want to do around the new project name. To ease the transition wrt hotfixes, we now replace "edenscm.mercurial" with "mercurial" to fix imports within base64-python extensions. Reviewed By: sggutier Differential Revision: D38943169 fbshipit-source-id: 03fa18079c51e2f7fac05d65b127095da3ab7c99
65 lines
1.6 KiB
Python
Executable File
65 lines
1.6 KiB
Python
Executable File
#!/usr/bin/env python
|
|
"""
|
|
Tests the behavior of filelog w.r.t. data starting with '\1\n'
|
|
"""
|
|
from __future__ import absolute_import, print_function
|
|
|
|
from edenscm import hg, ui as uimod
|
|
from edenscm.node import hex, nullid
|
|
from hghave import require
|
|
|
|
|
|
myui = uimod.ui.load()
|
|
repo = hg.repository(myui, path=".", create=True)
|
|
|
|
fl = repo.file("foobar")
|
|
|
|
|
|
def addrev(text, renamed=False):
|
|
if renamed:
|
|
# data doesn't matter. Just make sure filelog.renamed() returns True
|
|
meta = {"copyrev": hex(nullid), "copy": "bar"}
|
|
else:
|
|
meta = {}
|
|
|
|
lock = t = None
|
|
try:
|
|
lock = repo.lock()
|
|
t = repo.transaction("commit")
|
|
node = fl.add(text, meta, t, 0, nullid, nullid)
|
|
return node
|
|
finally:
|
|
if t:
|
|
t.close()
|
|
if lock:
|
|
lock.release()
|
|
|
|
|
|
def error(text):
|
|
print("ERROR: " + text)
|
|
|
|
|
|
textwith = b"\1\nfoo"
|
|
without = b"foo"
|
|
|
|
node = addrev(textwith)
|
|
if not textwith == fl.read(node):
|
|
error("filelog.read for data starting with \\1\\n")
|
|
if fl.cmp(node, textwith) or not fl.cmp(node, without):
|
|
error("filelog.cmp for data starting with \\1\\n")
|
|
if fl.size(0) != len(textwith):
|
|
error(
|
|
"FIXME: This is a known failure of filelog.size for data starting "
|
|
"with \\1\\n"
|
|
)
|
|
|
|
node = addrev(textwith, renamed=True)
|
|
if not textwith == fl.read(node):
|
|
error("filelog.read for a renaming + data starting with \\1\\n")
|
|
if fl.cmp(node, textwith) or not fl.cmp(node, without):
|
|
error("filelog.cmp for a renaming + data starting with \\1\\n")
|
|
if fl.size(1) != len(textwith):
|
|
error("filelog.size for a renaming + data starting with \\1\\n")
|
|
|
|
print("OK.")
|