From 5c8e7feabd61a7db852728c9faee0ed913501b61 Mon Sep 17 00:00:00 2001 From: Jakob Unterwurzacher Date: Sun, 6 Jan 2019 20:43:24 +0100 Subject: tests: check that fallocate does not over-allocate space We currently allocate 18 bytes too much: https://github.com/rfjakob/gocryptfs/issues/311 --- tests/matrix/fallocate_test.go | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'tests') diff --git a/tests/matrix/fallocate_test.go b/tests/matrix/fallocate_test.go index 6928b4a..dde0685 100644 --- a/tests/matrix/fallocate_test.go +++ b/tests/matrix/fallocate_test.go @@ -148,6 +148,23 @@ func TestFallocate(t *testing.T) { } } } + // We used to allocate 18 bytes too much: + // https://github.com/rfjakob/gocryptfs/issues/311 + // + // 8110 bytes of plaintext should get us exactly 8192 bytes of ciphertext. + err = file.Truncate(0) + if err != nil { + t.Fatal(err) + } + err = syscallcompat.Fallocate(fd, FALLOC_DEFAULT, 0, 8110) + if err != nil { + t.Fatal(err) + } + nBytes = test_helpers.Du(t, fd) + want = 8192 + if nBytes != want { + t.Errorf("Expected %d allocated bytes, have %d", want, nBytes) + } // Cleanup syscall.Unlink(fn) if !wellKnown { -- cgit v1.2.3