mirror of
https://github.com/falk-werner/webfuse
synced 2024-10-27 20:34:10 +00:00
add unit test for utimens ; fixed signature of utimens
This commit is contained in:
parent
61b97f19aa
commit
a5673b281c
@ -81,6 +81,7 @@ if(NOT(WITHOUT_TEST))
|
|||||||
test-src/integration/test_chown.cpp
|
test-src/integration/test_chown.cpp
|
||||||
test-src/integration/test_truncate.cpp
|
test-src/integration/test_truncate.cpp
|
||||||
test-src/integration/test_fsync.cpp
|
test-src/integration/test_fsync.cpp
|
||||||
|
test-src/integration/test_utimens.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
target_include_directories(integration_tests PRIVATE test-src/integration ${GTEST_INCLUDE_DIRS} ${GMOCK_INCLUDE_DIRS})
|
target_include_directories(integration_tests PRIVATE test-src/integration ${GTEST_INCLUDE_DIRS} ${GMOCK_INCLUDE_DIRS})
|
||||||
|
@ -90,7 +90,7 @@ public:
|
|||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
int utimens(std::string const &path, struct timespec tv[2], uint64_t handle) override
|
int utimens(std::string const &path, struct timespec const tv[2], uint64_t handle) override
|
||||||
{
|
{
|
||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
}
|
}
|
||||||
|
@ -190,7 +190,7 @@ int filesystem::fsync(std::string const & path, bool is_datasync, uint64_t handl
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int filesystem::utimens(std::string const &path, struct timespec tv[2], uint64_t handle)
|
int filesystem::utimens(std::string const &path, struct timespec const tv[2], uint64_t handle)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -30,7 +30,7 @@ public:
|
|||||||
int chown(std::string const & path, uid_t uid, gid_t gid) override;
|
int chown(std::string const & path, uid_t uid, gid_t gid) override;
|
||||||
int truncate(std::string const & path, uint64_t size, uint64_t handle) override;
|
int truncate(std::string const & path, uint64_t size, uint64_t handle) override;
|
||||||
int fsync(std::string const & path, bool is_datasync, uint64_t handle) override;
|
int fsync(std::string const & path, bool is_datasync, uint64_t handle) override;
|
||||||
int utimens(std::string const &path, struct timespec tv[2], uint64_t handle) override;
|
int utimens(std::string const &path, struct timespec const tv[2], uint64_t handle) override;
|
||||||
|
|
||||||
int open(std::string const & path, int flags, uint64_t & handle) override;
|
int open(std::string const & path, int flags, uint64_t & handle) override;
|
||||||
int mknod(std::string const & path, mode_t mode, dev_t rdev) override;
|
int mknod(std::string const & path, mode_t mode, dev_t rdev) override;
|
||||||
|
@ -71,7 +71,7 @@ int empty_filesystem::fsync(std::string const & path, bool is_datasync, uint64_t
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int empty_filesystem::utimens(std::string const &path, struct timespec tv[2], uint64_t handle)
|
int empty_filesystem::utimens(std::string const &path, struct timespec const tv[2], uint64_t handle)
|
||||||
{
|
{
|
||||||
return -ENOSYS;
|
return -ENOSYS;
|
||||||
}
|
}
|
||||||
|
@ -23,7 +23,7 @@ public:
|
|||||||
int chown(std::string const & path, uid_t uid, gid_t gid) override;
|
int chown(std::string const & path, uid_t uid, gid_t gid) override;
|
||||||
int truncate(std::string const & path, uint64_t size, uint64_t handle) override;
|
int truncate(std::string const & path, uint64_t size, uint64_t handle) override;
|
||||||
int fsync(std::string const & path, bool is_datasync, uint64_t handle) override;
|
int fsync(std::string const & path, bool is_datasync, uint64_t handle) override;
|
||||||
int utimens(std::string const &path, struct timespec tv[2], uint64_t handle) override;
|
int utimens(std::string const &path, struct timespec const tv[2], uint64_t handle) override;
|
||||||
|
|
||||||
int open(std::string const & path, int flags, uint64_t & handle) override;
|
int open(std::string const & path, int flags, uint64_t & handle) override;
|
||||||
int mknod(std::string const & path, mode_t mode, dev_t rdev) override;
|
int mknod(std::string const & path, mode_t mode, dev_t rdev) override;
|
||||||
|
@ -30,7 +30,7 @@ public:
|
|||||||
virtual int chown(std::string const & path, uid_t uid, gid_t gid) = 0;
|
virtual int chown(std::string const & path, uid_t uid, gid_t gid) = 0;
|
||||||
virtual int truncate(std::string const & path, uint64_t size, uint64_t handle) = 0;
|
virtual int truncate(std::string const & path, uint64_t size, uint64_t handle) = 0;
|
||||||
virtual int fsync(std::string const & path, bool is_datasync, uint64_t handle) = 0;
|
virtual int fsync(std::string const & path, bool is_datasync, uint64_t handle) = 0;
|
||||||
virtual int utimens(std::string const &path, struct timespec tv[2], uint64_t handle) = 0;
|
virtual int utimens(std::string const &path, struct timespec const tv[2], uint64_t handle) = 0;
|
||||||
|
|
||||||
virtual int open(std::string const & path, int flags, uint64_t & handle) = 0;
|
virtual int open(std::string const & path, int flags, uint64_t & handle) = 0;
|
||||||
virtual int mknod(std::string const & path, mode_t mode, dev_t rdev) = 0;
|
virtual int mknod(std::string const & path, mode_t mode, dev_t rdev) = 0;
|
||||||
|
@ -210,6 +210,13 @@ static int fs_statfs(char const * path, struct statvfs * buffer)
|
|||||||
return fs->statfs(path, buffer);
|
return fs->statfs(path, buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int fs_utimes(const char * path, const struct timespec tv[2], struct fuse_file_info * info)
|
||||||
|
{
|
||||||
|
auto * const fs = fs_get_filesystem();
|
||||||
|
auto handle = fs_get_handle(info);
|
||||||
|
return fs->utimens(path, tv, handle);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace webfuse
|
namespace webfuse
|
||||||
@ -277,6 +284,7 @@ int fuse::run(int argc, char * argv[])
|
|||||||
operations.readdir = fs_readdir;
|
operations.readdir = fs_readdir;
|
||||||
operations.rmdir = fs_rmdir;
|
operations.rmdir = fs_rmdir;
|
||||||
operations.statfs = fs_statfs;
|
operations.statfs = fs_statfs;
|
||||||
|
operations.utimens = fs_utimes;
|
||||||
|
|
||||||
return fuse_main(argc, argv, &operations, context);
|
return fuse_main(argc, argv, &operations, context);
|
||||||
}
|
}
|
||||||
|
@ -85,6 +85,9 @@ public:
|
|||||||
case request_type::fsync:
|
case request_type::fsync:
|
||||||
fs_fsync(reader, writer);
|
fs_fsync(reader, writer);
|
||||||
break;
|
break;
|
||||||
|
case request_type::utimens:
|
||||||
|
fs_utimens(reader, writer);
|
||||||
|
break;
|
||||||
case request_type::create:
|
case request_type::create:
|
||||||
fs_create(reader, writer);
|
fs_create(reader, writer);
|
||||||
break;
|
break;
|
||||||
@ -204,6 +207,18 @@ private:
|
|||||||
writer.write_i32(result);
|
writer.write_i32(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void fs_utimens(messagereader & reader, messagewriter & writer)
|
||||||
|
{
|
||||||
|
auto const path = reader.read_str();
|
||||||
|
struct timespec times[2];
|
||||||
|
reader.read_time(times[0]);
|
||||||
|
reader.read_time(times[1]);
|
||||||
|
auto const handle = reader.read_u64();
|
||||||
|
|
||||||
|
auto const result = fs_.utimens(path, times, handle);
|
||||||
|
writer.write_i32(result);
|
||||||
|
}
|
||||||
|
|
||||||
void fs_create(messagereader & reader, messagewriter & writer)
|
void fs_create(messagereader & reader, messagewriter & writer)
|
||||||
{
|
{
|
||||||
auto const path = reader.read_str();
|
auto const path = reader.read_str();
|
||||||
|
@ -180,5 +180,11 @@ void messagereader::read_strings(std::vector<std::string> &entries)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void messagereader::read_time(struct timespec &time)
|
||||||
|
{
|
||||||
|
time.tv_sec = static_cast<time_t>(read_u64());
|
||||||
|
time.tv_nsec = static_cast<long>(read_u32());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
@ -40,7 +40,7 @@ public:
|
|||||||
std::string read_bytes();
|
std::string read_bytes();
|
||||||
|
|
||||||
void read_strings(std::vector<std::string> &entries);
|
void read_strings(std::vector<std::string> &entries);
|
||||||
|
void read_time(struct timespec &time);
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
46
test-src/integration/test_utimens.cpp
Normal file
46
test-src/integration/test_utimens.cpp
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
#include "webfuse/webfuse.hpp"
|
||||||
|
#include "webfuse/test/fixture.hpp"
|
||||||
|
#include "webfuse/test/filesystem_mock.hpp"
|
||||||
|
|
||||||
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
|
||||||
|
using testing::_;
|
||||||
|
using testing::Return;
|
||||||
|
using testing::Invoke;
|
||||||
|
using testing::AnyNumber;
|
||||||
|
|
||||||
|
TEST(utimens, success)
|
||||||
|
{
|
||||||
|
webfuse::filesystem_mock fs;
|
||||||
|
EXPECT_CALL(fs, access("/",_)).Times(AnyNumber()).WillRepeatedly(Return(0));
|
||||||
|
EXPECT_CALL(fs, getattr(_,_)).WillRepeatedly(Invoke([](std::string const & path, struct stat * attr){
|
||||||
|
memset(reinterpret_cast<void*>(attr),0, sizeof(struct stat));
|
||||||
|
if (path == "/")
|
||||||
|
{
|
||||||
|
attr->st_nlink = 1;
|
||||||
|
attr->st_mode = S_IFDIR | 0755;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (path == "/some_file")
|
||||||
|
{
|
||||||
|
attr->st_nlink = 1;
|
||||||
|
attr->st_mode = S_IFREG | 0644;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
std::cout << "getattr: failed" << std::endl;
|
||||||
|
return -ENOENT;
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
EXPECT_CALL(fs, utimens("/some_file", _, _)).WillOnce(Return(0));
|
||||||
|
|
||||||
|
webfuse::fixture fixture(fs);
|
||||||
|
auto const path = fixture.get_path() + "/some_file";
|
||||||
|
|
||||||
|
timeval times[2] = {42,42};
|
||||||
|
ASSERT_EQ(0, ::utimes(path.c_str(), times));
|
||||||
|
}
|
@ -24,7 +24,7 @@ public:
|
|||||||
MOCK_METHOD(int, chown, (std::string const & path, uid_t uid, gid_t gid));
|
MOCK_METHOD(int, chown, (std::string const & path, uid_t uid, gid_t gid));
|
||||||
MOCK_METHOD(int, truncate, (std::string const & path, uint64_t size, uint64_t handle));
|
MOCK_METHOD(int, truncate, (std::string const & path, uint64_t size, uint64_t handle));
|
||||||
MOCK_METHOD(int, fsync, (std::string const & path, bool is_datasync, uint64_t handle));
|
MOCK_METHOD(int, fsync, (std::string const & path, bool is_datasync, uint64_t handle));
|
||||||
MOCK_METHOD(int, utimens, (std::string const &path, struct timespec tv[2], uint64_t handle));
|
MOCK_METHOD(int, utimens, (std::string const &path, struct timespec const tv[2], uint64_t handle));
|
||||||
|
|
||||||
MOCK_METHOD(int, open, (std::string const & path, int flags, uint64_t & handle));
|
MOCK_METHOD(int, open, (std::string const & path, int flags, uint64_t & handle));
|
||||||
MOCK_METHOD(int, mknod, (std::string const & path, mode_t mode, dev_t rdev));
|
MOCK_METHOD(int, mknod, (std::string const & path, mode_t mode, dev_t rdev));
|
||||||
|
Loading…
Reference in New Issue
Block a user