forked from TrueCloudLab/restic
Merge pull request #447 from ckemper67/fix-442
Fix #442: set blocks and blocksize in fuse
This commit is contained in:
commit
517eff7e48
2 changed files with 6 additions and 0 deletions
|
@ -15,6 +15,9 @@ import (
|
||||||
"golang.org/x/net/context"
|
"golang.org/x/net/context"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// The default block size to report in stat
|
||||||
|
const blockSize = 512
|
||||||
|
|
||||||
// Statically ensure that *file implements the given interface
|
// Statically ensure that *file implements the given interface
|
||||||
var _ = fs.HandleReader(&file{})
|
var _ = fs.HandleReader(&file{})
|
||||||
var _ = fs.HandleReleaser(&file{})
|
var _ = fs.HandleReleaser(&file{})
|
||||||
|
@ -67,6 +70,8 @@ func (f *file) Attr(ctx context.Context, a *fuse.Attr) error {
|
||||||
a.Inode = f.node.Inode
|
a.Inode = f.node.Inode
|
||||||
a.Mode = f.node.Mode
|
a.Mode = f.node.Mode
|
||||||
a.Size = f.node.Size
|
a.Size = f.node.Size
|
||||||
|
a.Blocks = (f.node.Size / blockSize) + 1
|
||||||
|
a.BlockSize = blockSize
|
||||||
|
|
||||||
if !f.ownerIsRoot {
|
if !f.ownerIsRoot {
|
||||||
a.Uid = f.node.UID
|
a.Uid = f.node.UID
|
||||||
|
|
|
@ -132,6 +132,7 @@ func TestFuseFile(t *testing.T) {
|
||||||
Equals(t, node.Inode, attr.Inode)
|
Equals(t, node.Inode, attr.Inode)
|
||||||
Equals(t, node.Mode, attr.Mode)
|
Equals(t, node.Mode, attr.Mode)
|
||||||
Equals(t, node.Size, attr.Size)
|
Equals(t, node.Size, attr.Size)
|
||||||
|
Equals(t, (node.Size/uint64(attr.BlockSize))+1, attr.Blocks)
|
||||||
|
|
||||||
for i, test := range offsetReadsTests {
|
for i, test := range offsetReadsTests {
|
||||||
b := memfile[test.offset : test.offset+test.length]
|
b := memfile[test.offset : test.offset+test.length]
|
||||||
|
|
Loading…
Reference in a new issue