parent
48e3575d6d
commit
d56bbcbd39
@ -0,0 +1,28 @@
|
||||
#include "webfuse/mocks/mock_fuse.hpp"
|
||||
#include "webfuse/utils/wrap.hpp"
|
||||
|
||||
extern "C"
|
||||
{
|
||||
static webfuse_test::FuseMock * webfuse_test_FuseMock = nullptr;
|
||||
|
||||
WF_WRAP_FUNC1(webfuse_test_FuseMock, void*, fuse_req_userdata, fuse_req_t);
|
||||
WF_WRAP_FUNC2(webfuse_test_FuseMock, int, fuse_reply_open, fuse_req_t, const struct fuse_file_info *);
|
||||
WF_WRAP_FUNC2(webfuse_test_FuseMock, int, fuse_reply_err, fuse_req_t, int);
|
||||
|
||||
}
|
||||
|
||||
namespace webfuse_test
|
||||
{
|
||||
|
||||
FuseMock::FuseMock()
|
||||
{
|
||||
webfuse_test_FuseMock = this;
|
||||
}
|
||||
|
||||
FuseMock::~FuseMock()
|
||||
{
|
||||
webfuse_test_FuseMock = nullptr;
|
||||
}
|
||||
|
||||
|
||||
}
|
@ -0,0 +1,19 @@
|
||||
#include "webfuse/adapter/impl/fuse_wrapper.h"
|
||||
#include <gmock/gmock.h>
|
||||
|
||||
namespace webfuse_test
|
||||
{
|
||||
|
||||
class FuseMock
|
||||
{
|
||||
public:
|
||||
FuseMock();
|
||||
virtual ~FuseMock();
|
||||
|
||||
MOCK_METHOD1(fuse_req_userdata, void *(fuse_req_t req));
|
||||
MOCK_METHOD2(fuse_reply_open, int (fuse_req_t req, const struct fuse_file_info *fi));
|
||||
MOCK_METHOD2(fuse_reply_err, int (fuse_req_t req, int err));
|
||||
};
|
||||
|
||||
|
||||
}
|
@ -0,0 +1,28 @@
|
||||
#include "webfuse/adapter/impl/operations.h"
|
||||
#include "webfuse/mocks/mock_fuse.hpp"
|
||||
#include "webfuse/adapter/impl/session.h"
|
||||
|
||||
#include <gtest/gtest.h>
|
||||
|
||||
using webfuse_test::FuseMock;
|
||||
using testing::_;
|
||||
using testing::Return;
|
||||
|
||||
TEST(wf_impl_operation_open, fail_rpc_null)
|
||||
{
|
||||
wf_impl_session session;
|
||||
memset(&session, 0, sizeof(session));
|
||||
wf_impl_operations_context context =
|
||||
{&session, 1.0f, nullptr };
|
||||
|
||||
FuseMock fuse;
|
||||
EXPECT_CALL(fuse, fuse_req_userdata(_)).Times(1)
|
||||
.WillOnce(Return(reinterpret_cast<void*>(&context)));
|
||||
EXPECT_CALL(fuse, fuse_reply_err(_, ENOENT)).Times(1)
|
||||
.WillOnce(Return(0));
|
||||
|
||||
fuse_req_t request = nullptr;
|
||||
fuse_ino_t inode = 1;
|
||||
fuse_file_info * file_info = nullptr;
|
||||
wf_impl_operation_open(request, inode, file_info);
|
||||
}
|
Loading…
Reference in new issue