Skip to content

Commit

Permalink
Test that the fuse device can be opened
Browse files Browse the repository at this point in the history
  • Loading branch information
ridwanmsharif committed Jun 25, 2020
1 parent a63db7d commit 2828806
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 23 deletions.
5 changes: 3 additions & 2 deletions runsc/boot/vfs.go
Expand Up @@ -80,9 +80,10 @@ func registerFilesystems(ctx context.Context, vfsObj *vfs.VirtualFilesystem, cre
}
if err := ttydev.Register(vfsObj); err != nil {
return fmt.Errorf("registering ttydev: %w", err)
}

if err := fuse.Register(vfsObj); err != nil {
return fmt.Errorf("registering /dev/fuse: %w", err)
return fmt.Errorf("registering fusedev: %w", err)
}
if err := tundev.Register(vfsObj); err != nil {
return fmt.Errorf("registering tundev: %v", err)
Expand All @@ -106,7 +107,7 @@ func registerFilesystems(ctx context.Context, vfsObj *vfs.VirtualFilesystem, cre
return fmt.Errorf("creating tundev devtmpfs files: %v", err)
}
if err := fuse.CreateDevtmpfsFile(ctx, a); err != nil {
return fmt.Errorf("creating devtmpfs fuse device file: %w", err)
return fmt.Errorf("creating fusedev devtmpfs files: %w", err)
}
return nil
}
Expand Down
29 changes: 8 additions & 21 deletions test/syscalls/linux/dev.cc
Expand Up @@ -146,34 +146,21 @@ TEST(DevTest, WriteDevFull) {
EXPECT_THAT(WriteFd(fd.get(), "a", 1), SyscallFailsWithErrno(ENOSPC));
}

TEST(DevTest, ReadDevFuse) {
SKIP_IF(IsRunningWithVFS1());

const FileDescriptor fd =
ASSERT_NO_ERRNO_AND_VALUE(Open("/dev/fuse", O_RDONLY));
std::vector<char> buf(1);
EXPECT_THAT(ReadFd(fd.get(), buf.data(), sizeof(buf)), SyscallFailsWithErrno(ENOSYS));
}

TEST(DevTest, WriteDevFuse) {
SKIP_IF(IsRunningWithVFS1());

const FileDescriptor fd =
ASSERT_NO_ERRNO_AND_VALUE(Open("/dev/fuse", O_WRONLY));
const char* testStr = "test";
EXPECT_THAT(WriteFd(fd.get(), testStr, sizeof(testStr)), SyscallFailsWithErrno(ENOSYS));
}

TEST(DevTest, TTYExists) {
// Run test if running on VFS1 or on Linux.
SKIP_IF(!IsRunningWithVFS1() && IsRunningOnGvisor());

struct stat statbuf = {};
ASSERT_THAT(stat("/dev/tty", &statbuf), SyscallSucceeds());
// Check that it's a character device with rw-rw-rw- permissions.
EXPECT_EQ(statbuf.st_mode, S_IFCHR | 0666);
}

TEST(DevTest, OpenDevFuse) {
// Note(gvisor.dev/issue/3076) This won't work in the sentry until the new
// device registration is complete.
SKIP_IF(IsRunningWithVFS1() || IsRunningOnGvisor());

ASSERT_NO_ERRNO_AND_VALUE(Open("/dev/fuse", O_RDONLY));
}

} // namespace
} // namespace testing

Expand Down

0 comments on commit 2828806

Please sign in to comment.