diff options
author | Dave Borowitz <dborowitz@google.com> | 2017-12-20 12:36:03 -0500 |
---|---|---|
committer | Dave Borowitz <dborowitz@google.com> | 2017-12-20 12:43:31 -0500 |
commit | 43ef5dabf12fee8877c6d8fa07b26be766dca1ee (patch) | |
tree | 00a5ca42a64d3b903b090717024a8525209c29ee /Documentation | |
parent | f63ee965d4f6990a25628c1aac452f4cbf8a69dd (diff) | |
download | jgit-43ef5dabf12fee8877c6d8fa07b26be766dca1ee.tar.gz jgit-43ef5dabf12fee8877c6d8fa07b26be766dca1ee.zip |
PackInserter: Ensure objects are written at the end of the pack
When interleaving reads and writes from an unflushed pack, we forgot to
reset the file pointer back to the end of the file before writing more
new objects. This had at least two unfortunate effects:
* The pack data was potentially corrupt, since we could overwrite
previous portions of the file willy-nilly.
* The CountingOutputStream would report more bytes read than the size
of the file, which stored the wrong PackedObjectInfo, which would
cause EOFs during reading.
We already had a test in PackInserterTest which was supposed to catch
bugs like this, by interleaving reads and writes. Unfortunately, it
didn't catch the bug, since as an implementation detail we always read a
full buffer's worth of data from the file when inflating during
readback. If the size of the file was less than the offset of the object
we were reading back plus one buffer (8192 bytes), we would completely
accidentally end up back in the right place in the file.
So, add another test for this case where we read back a small object
positioned before a large object. Before the fix, this test exhibited
exactly the "Unexpected EOF" error reported at crbug.com/gerrit/7668.
Change-Id: I74f08f3d5d9046781d59e5bd7c84916ff8225c3b
Diffstat (limited to 'Documentation')
0 files changed, 0 insertions, 0 deletions