9ccb006f61
- Fix clang-tidy warnings from Clang 15
37 lines
1.1 KiB
C++
37 lines
1.1 KiB
C++
#include "testutils/FuseReadDirTest.h"
|
|
|
|
#include "fspp/fs_interface/FuseErrnoException.h"
|
|
|
|
using ::testing::Eq;
|
|
using ::testing::Throw;
|
|
using ::testing::WithParamInterface;
|
|
using ::testing::Values;
|
|
|
|
using std::string;
|
|
|
|
using namespace fspp::fuse;
|
|
|
|
class FuseReadDirErrorTest: public FuseReadDirTest, public WithParamInterface<int> {
|
|
};
|
|
INSTANTIATE_TEST_SUITE_P(FuseReadDirErrorTest, FuseReadDirErrorTest, Values(EACCES, EBADF, EMFILE, ENFILE, ENOMEM, ENOTDIR, EFAULT, EINVAL));
|
|
|
|
//TODO On ENOENT, libfuse doesn't return the ENOENT error, but returns a success response with an empty directory. Why?
|
|
|
|
TEST_F(FuseReadDirErrorTest, NoError) {
|
|
ReturnIsDirOnLstat(DIRNAME);
|
|
EXPECT_CALL(*fsimpl, readDir(Eq(DIRNAME)))
|
|
.Times(1).WillOnce(ReturnDirEntries({}));
|
|
|
|
const int error = ReadDirReturnError(DIRNAME);
|
|
EXPECT_EQ(0, error);
|
|
}
|
|
|
|
TEST_P(FuseReadDirErrorTest, ReturnedErrorCodeIsCorrect) {
|
|
ReturnIsDirOnLstat(DIRNAME);
|
|
EXPECT_CALL(*fsimpl, readDir(Eq(DIRNAME)))
|
|
.Times(1).WillOnce(Throw(FuseErrnoException(GetParam())));
|
|
|
|
const int error = ReadDirReturnError(DIRNAME);
|
|
EXPECT_EQ(GetParam(), error);
|
|
}
|