# HG changeset patch # User Daniel Atallah # Date 1301368580 14400 # Node ID a916e8de43133d4abc9b46a00dee8c37cb9510ad # Parent c0ed76b5056d91db841992d9c9c77278005b3154 convert/mtn: Fix conversion of large files from mtn (broken in ed97955e0c04) "mtn automate stdio" will break output larger than 32kB into several packets. This ensures that we are processing all the output on the main stream and not only the last packet. diff -r c0ed76b5056d -r a916e8de4313 hgext/convert/monotone.py --- a/hgext/convert/monotone.py Mon Mar 28 21:36:29 2011 -0700 +++ b/hgext/convert/monotone.py Mon Mar 28 23:16:20 2011 -0400 @@ -138,7 +138,7 @@ return (commandnbr, stream, length, read) def mtnstdioreadcommandoutput(self, command): - retval = '' + retval = [] while True: commandnbr, stream, length, output = self.mtnstdioreadpacket() self.ui.debug('mtn: read packet %s:%s:%s\n' % @@ -159,9 +159,9 @@ self.ui.debug('mtn: ' + output) elif stream == 'm': # Main stream - command output - retval = output + retval.append(output) - return retval + return ''.join(retval) def mtnloadmanifest(self, rev): if self.manifest_rev == rev: diff -r c0ed76b5056d -r a916e8de4313 tests/test-convert-mtn.t --- a/tests/test-convert-mtn.t Mon Mar 28 21:36:29 2011 -0700 +++ b/tests/test-convert-mtn.t Mon Mar 28 23:16:20 2011 -0400 @@ -208,9 +208,20 @@ mtn: beginning commit on branch 'com.selenic.test' mtn: committed revision 4a736634505795f17786fffdf2c9cbf5b11df6f6 +test large file support (> 32kB) + + $ python -c 'for x in range(10000): print x' > large-file + $ $TESTDIR/md5sum.py large-file + 5d6de8a95c3b6bf9e0ffb808ba5299c1 large-file + $ mtn add large-file + mtn: adding large-file to workspace manifest + $ mtn ci -m largefile + mtn: beginning commit on branch 'com.selenic.test' + mtn: committed revision f0a20fecd10dc4392d18fe69a03f1f4919d3387b + test suspending (closing a branch) - $ mtn suspend 4a736634505795f17786fffdf2c9cbf5b11df6f6 2> /dev/null + $ mtn suspend f0a20fecd10dc4392d18fe69a03f1f4919d3387b 2> /dev/null $ cd .. convert incrementally @@ -220,27 +231,30 @@ scanning source... sorting... converting... - 11 update2 "with" quotes - 10 createdir1 - 9 movedir1 - 8 movedir - 7 emptydir - 6 dropdirectory - 5 dirfilemove - 4 dirfilemove2 - 3 dirdirmove - 2 dirdirmove2 - 1 divergentdirmove - 0 divergentdirmove2 + 12 update2 "with" quotes + 11 createdir1 + 10 movedir1 + 9 movedir + 8 emptydir + 7 dropdirectory + 6 dirfilemove + 5 dirfilemove2 + 4 dirdirmove + 3 dirdirmove2 + 2 divergentdirmove + 1 divergentdirmove2 + 0 largefile $ glog() > { > hg glog --template '{rev} "{desc|firstline}" files: {files}\n' "$@" > } $ cd repo.mtn-hg $ hg up -C - 11 files updated, 0 files merged, 0 files removed, 0 files unresolved + 12 files updated, 0 files merged, 0 files removed, 0 files unresolved $ glog - @ 13 "divergentdirmove2" files: dir7-2/c dir7/c dir7/dir9/b dir7/dir9/dir8/a dir8-2/a dir9-2/b + @ 14 "largefile" files: large-file + | + o 13 "divergentdirmove2" files: dir7-2/c dir7/c dir7/dir9/b dir7/dir9/dir8/a dir8-2/a dir9-2/b | o 12 "divergentdirmove" files: dir7/c dir7/dir9/b dir7/dir9/dir8/a | @@ -283,6 +297,7 @@ dir8-2/a dir9-2/b e + large-file contents @@ -360,9 +375,14 @@ dir9-2/b e +test large file support (> 32kB) + + $ $TESTDIR/md5sum.py large-file + 5d6de8a95c3b6bf9e0ffb808ba5299c1 large-file + check branch closing $ hg branches -a $ hg branches -c - com.selenic.test 13:* (closed) (glob) + com.selenic.test 14:* (closed) (glob)