libcryfs/test/fspp/fuse/readDir/FuseReadDirErrorTest.cpp
Sebastian Messmer 9ccb006f61 - Switch some CI jobs to clang 15
- Fix clang-tidy warnings from Clang 15
2023-07-08 14:48:59 -07:00

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);
}