Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go-fuse
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Levin Zimmermann
go-fuse
Commits
dfd827ce
Commit
dfd827ce
authored
Feb 08, 2012
by
Han-Wen Nienhuys
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixes for weekly 2012.02.07: stop using os.FileInfo.
parent
76c6deb5
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
35 additions
and
38 deletions
+35
-38
fuse/attr.go
fuse/attr.go
+2
-8
fuse/loopback_test.go
fuse/loopback_test.go
+17
-20
fuse/misc_test.go
fuse/misc_test.go
+3
-4
fuse/owner_test.go
fuse/owner_test.go
+13
-6
No files found.
fuse/attr.go
View file @
dfd827ce
...
@@ -134,12 +134,6 @@ func (a *Attr) FromStat(s *syscall.Stat_t) {
...
@@ -134,12 +134,6 @@ func (a *Attr) FromStat(s *syscall.Stat_t) {
a
.
Blksize
=
uint32
(
s
.
Blksize
)
a
.
Blksize
=
uint32
(
s
.
Blksize
)
}
}
func
(
a
*
Attr
)
FromFileInfo
(
fi
os
.
FileInfo
)
{
stat
:=
fi
.
(
*
os
.
FileStat
)
sys
:=
stat
.
Sys
.
(
*
syscall
.
Stat_t
)
a
.
FromStat
(
sys
)
}
func
(
a
*
Attr
)
ChangeTime
()
time
.
Time
{
func
(
a
*
Attr
)
ChangeTime
()
time
.
Time
{
return
time
.
Unix
(
int64
(
a
.
Ctime
),
int64
(
a
.
Ctimensec
))
return
time
.
Unix
(
int64
(
a
.
Ctime
),
int64
(
a
.
Ctimensec
))
}
}
...
@@ -153,9 +147,9 @@ func (a *Attr) ModTime() time.Time {
...
@@ -153,9 +147,9 @@ func (a *Attr) ModTime() time.Time {
}
}
func
ToStatT
(
f
os
.
FileInfo
)
*
syscall
.
Stat_t
{
func
ToStatT
(
f
os
.
FileInfo
)
*
syscall
.
Stat_t
{
s
:=
f
.
(
*
os
.
FileStat
)
.
Sys
s
,
_
:=
f
.
Sys
()
.
(
*
syscall
.
Stat_t
)
if
s
!=
nil
{
if
s
!=
nil
{
return
s
.
(
*
syscall
.
Stat_t
)
return
s
}
}
return
nil
return
nil
}
}
...
...
fuse/loopback_test.go
View file @
dfd827ce
...
@@ -126,11 +126,12 @@ func TestTouch(t *testing.T) {
...
@@ -126,11 +126,12 @@ func TestTouch(t *testing.T) {
CheckSuccess
(
err
)
CheckSuccess
(
err
)
err
=
os
.
Chtimes
(
ts
.
mountFile
,
time
.
Unix
(
42
,
0
),
time
.
Unix
(
43
,
0
))
err
=
os
.
Chtimes
(
ts
.
mountFile
,
time
.
Unix
(
42
,
0
),
time
.
Unix
(
43
,
0
))
CheckSuccess
(
err
)
CheckSuccess
(
err
)
fi
,
err
:=
os
.
Lstat
(
ts
.
mountFile
)
var
stat
syscall
.
Stat_t
err
=
syscall
.
Lstat
(
ts
.
mountFile
,
&
stat
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
stat
:=
fi
.
(
*
os
.
FileStat
)
.
Sys
.
(
*
syscall
.
Stat_t
)
if
stat
.
Atim
.
Sec
!=
42
||
stat
.
Mtim
.
Sec
!=
43
{
if
stat
.
Atim
.
Sec
!=
42
||
stat
.
Mtim
.
Sec
!=
43
{
t
.
Errorf
(
"Got wrong timestamps %v"
,
fi
)
t
.
Errorf
(
"Got wrong timestamps %v"
,
stat
)
}
}
}
}
...
@@ -242,18 +243,17 @@ func TestLinkCreate(t *testing.T) {
...
@@ -242,18 +243,17 @@ func TestLinkCreate(t *testing.T) {
err
=
os
.
Link
(
me
.
mountFile
,
mountSubfile
)
err
=
os
.
Link
(
me
.
mountFile
,
mountSubfile
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
subStat
,
err
:=
os
.
Lstat
(
mountSubfile
)
var
subStat
,
stat
syscall
.
Stat_t
err
=
syscall
.
Lstat
(
mountSubfile
,
&
subStat
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
stat
,
err
:=
os
.
Lstat
(
me
.
mountFile
)
err
=
syscall
.
Lstat
(
me
.
mountFile
,
&
stat
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
subfi
:=
ToStatT
(
subStat
)
if
stat
.
Nlink
!=
2
{
fi
:=
ToStatT
(
stat
)
t
.
Errorf
(
"Expect 2 links: %v"
,
stat
)
if
fi
.
Nlink
!=
2
{
t
.
Errorf
(
"Expect 2 links: %v"
,
fi
)
}
}
if
fi
.
Ino
!=
subfi
.
Ino
{
if
stat
.
Ino
!=
subStat
.
Ino
{
t
.
Errorf
(
"Link succeeded, but inode numbers different: %v %v"
,
fi
.
Ino
,
subfi
.
Ino
)
t
.
Errorf
(
"Link succeeded, but inode numbers different: %v %v"
,
stat
.
Ino
,
subStat
.
Ino
)
}
}
readback
,
err
:=
ioutil
.
ReadFile
(
mountSubfile
)
readback
,
err
:=
ioutil
.
ReadFile
(
mountSubfile
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
...
@@ -282,13 +282,12 @@ func TestLinkExisting(t *testing.T) {
...
@@ -282,13 +282,12 @@ func TestLinkExisting(t *testing.T) {
err
=
os
.
Link
(
me
.
orig
+
"/file1"
,
me
.
orig
+
"/file2"
)
err
=
os
.
Link
(
me
.
orig
+
"/file1"
,
me
.
orig
+
"/file2"
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
f1
,
err
:=
os
.
Lstat
(
me
.
mnt
+
"/file1"
)
var
s1
,
s2
syscall
.
Stat_t
err
=
syscall
.
Lstat
(
me
.
mnt
+
"/file1"
,
&
s1
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
f2
,
err
:=
os
.
Lstat
(
me
.
mnt
+
"/file2"
)
err
=
syscall
.
Lstat
(
me
.
mnt
+
"/file2"
,
&
s2
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
s1
:=
ToStatT
(
f1
)
s2
:=
ToStatT
(
f2
)
if
s1
.
Ino
!=
s2
.
Ino
{
if
s1
.
Ino
!=
s2
.
Ino
{
t
.
Errorf
(
"linked files should have identical inodes %v %v"
,
s1
.
Ino
,
s2
.
Ino
)
t
.
Errorf
(
"linked files should have identical inodes %v %v"
,
s1
.
Ino
,
s2
.
Ino
)
}
}
...
@@ -313,16 +312,14 @@ func TestLinkForget(t *testing.T) {
...
@@ -313,16 +312,14 @@ func TestLinkForget(t *testing.T) {
err
=
os
.
Link
(
me
.
orig
+
"/file1"
,
me
.
orig
+
"/file2"
)
err
=
os
.
Link
(
me
.
orig
+
"/file1"
,
me
.
orig
+
"/file2"
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
f1
,
err
:=
os
.
Lstat
(
me
.
mnt
+
"/file1"
)
var
s1
,
s2
syscall
.
Stat_t
err
=
syscall
.
Lstat
(
me
.
mnt
+
"/file1"
,
&
s1
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
me
.
pathFs
.
ForgetClientInodes
()
me
.
pathFs
.
ForgetClientInodes
()
f2
,
err
:=
os
.
Lstat
(
me
.
mnt
+
"/file2"
)
err
=
syscall
.
Lstat
(
me
.
mnt
+
"/file2"
,
&
s2
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
s1
:=
ToStatT
(
f1
)
s2
:=
ToStatT
(
f2
)
if
s1
.
Ino
==
s2
.
Ino
{
if
s1
.
Ino
==
s2
.
Ino
{
t
.
Error
(
"After forget, we should not export links"
)
t
.
Error
(
"After forget, we should not export links"
)
}
}
...
...
fuse/misc_test.go
View file @
dfd827ce
...
@@ -35,17 +35,16 @@ func TestLinkAt(t *testing.T) {
...
@@ -35,17 +35,16 @@ func TestLinkAt(t *testing.T) {
t
.
Fatalf
(
"Linkat %d"
,
e
)
t
.
Fatalf
(
"Linkat %d"
,
e
)
}
}
f1
,
err
:=
os
.
Lstat
(
dir
+
"/a"
)
var
s1
,
s2
syscall
.
Stat_t
err
:=
syscall
.
Lstat
(
dir
+
"/a"
,
&
s1
)
if
err
!=
nil
{
if
err
!=
nil
{
t
.
Fatalf
(
"Lstat a: %v"
,
err
)
t
.
Fatalf
(
"Lstat a: %v"
,
err
)
}
}
f2
,
err
:=
os
.
Lstat
(
dir
+
"/b"
)
err
=
syscall
.
Lstat
(
dir
+
"/b"
,
&
s2
)
if
err
!=
nil
{
if
err
!=
nil
{
t
.
Fatalf
(
"Lstat b: %v"
,
err
)
t
.
Fatalf
(
"Lstat b: %v"
,
err
)
}
}
s1
:=
ToStatT
(
f1
)
s2
:=
ToStatT
(
f2
)
if
s1
.
Ino
!=
s2
.
Ino
{
if
s1
.
Ino
!=
s2
.
Ino
{
t
.
Fatal
(
"Ino mismatch"
,
s1
,
s2
)
t
.
Fatal
(
"Ino mismatch"
,
s1
,
s2
)
}
}
...
...
fuse/owner_test.go
View file @
dfd827ce
...
@@ -3,6 +3,7 @@ package fuse
...
@@ -3,6 +3,7 @@ package fuse
import
(
import
(
"io/ioutil"
"io/ioutil"
"os"
"os"
"syscall"
"testing"
"testing"
)
)
...
@@ -43,10 +44,12 @@ func setupOwnerTest(opts *FileSystemOptions) (workdir string, cleanup func()) {
...
@@ -43,10 +44,12 @@ func setupOwnerTest(opts *FileSystemOptions) (workdir string, cleanup func()) {
func
TestOwnerDefault
(
t
*
testing
.
T
)
{
func
TestOwnerDefault
(
t
*
testing
.
T
)
{
wd
,
cleanup
:=
setupOwnerTest
(
NewFileSystemOptions
())
wd
,
cleanup
:=
setupOwnerTest
(
NewFileSystemOptions
())
defer
cleanup
()
defer
cleanup
()
fi
,
err
:=
os
.
Lstat
(
wd
+
"/foo"
)
var
stat
syscall
.
Stat_t
err
:=
syscall
.
Lstat
(
wd
+
"/foo"
,
&
stat
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
if
int
(
ToStatT
(
fi
)
.
Uid
)
!=
os
.
Getuid
()
||
int
(
ToStatT
(
fi
)
.
Gid
)
!=
os
.
Getgid
()
{
if
int
(
stat
.
Uid
)
!=
os
.
Getuid
()
||
int
(
stat
.
Gid
)
!=
os
.
Getgid
()
{
t
.
Fatal
(
"Should use current uid for mount"
)
t
.
Fatal
(
"Should use current uid for mount"
)
}
}
}
}
...
@@ -54,10 +57,12 @@ func TestOwnerDefault(t *testing.T) {
...
@@ -54,10 +57,12 @@ func TestOwnerDefault(t *testing.T) {
func
TestOwnerRoot
(
t
*
testing
.
T
)
{
func
TestOwnerRoot
(
t
*
testing
.
T
)
{
wd
,
cleanup
:=
setupOwnerTest
(
&
FileSystemOptions
{})
wd
,
cleanup
:=
setupOwnerTest
(
&
FileSystemOptions
{})
defer
cleanup
()
defer
cleanup
()
fi
,
err
:=
os
.
Lstat
(
wd
+
"/foo"
)
var
st
syscall
.
Stat_t
err
:=
syscall
.
Lstat
(
wd
+
"/foo"
,
&
st
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
if
ToStatT
(
fi
)
.
Uid
!=
_RANDOM_OWNER
||
ToStatT
(
fi
)
.
Gid
!=
_RANDOM_OWNER
{
if
st
.
Uid
!=
_RANDOM_OWNER
||
st
.
Gid
!=
_RANDOM_OWNER
{
t
.
Fatal
(
"Should use FS owner uid"
)
t
.
Fatal
(
"Should use FS owner uid"
)
}
}
}
}
...
@@ -65,10 +70,12 @@ func TestOwnerRoot(t *testing.T) {
...
@@ -65,10 +70,12 @@ func TestOwnerRoot(t *testing.T) {
func
TestOwnerOverride
(
t
*
testing
.
T
)
{
func
TestOwnerOverride
(
t
*
testing
.
T
)
{
wd
,
cleanup
:=
setupOwnerTest
(
&
FileSystemOptions
{
Owner
:
&
Owner
{
42
,
43
}})
wd
,
cleanup
:=
setupOwnerTest
(
&
FileSystemOptions
{
Owner
:
&
Owner
{
42
,
43
}})
defer
cleanup
()
defer
cleanup
()
fi
,
err
:=
os
.
Lstat
(
wd
+
"/foo"
)
var
stat
syscall
.
Stat_t
err
:=
syscall
.
Lstat
(
wd
+
"/foo"
,
&
stat
)
CheckSuccess
(
err
)
CheckSuccess
(
err
)
if
ToStatT
(
fi
)
.
Uid
!=
42
||
ToStatT
(
fi
)
.
Gid
!=
43
{
if
stat
.
Uid
!=
42
||
stat
.
Gid
!=
43
{
t
.
Fatal
(
"Should use current uid for mount"
)
t
.
Fatal
(
"Should use current uid for mount"
)
}
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment