mirror of
https://github.com/falk-werner/webfuse-provider
synced 2024-10-27 20:44:10 +00:00
added tests for wfp_impl_close
This commit is contained in:
parent
39855a9995
commit
8d28da5e82
@ -28,6 +28,7 @@ add_executable(alltests
|
|||||||
test/webfuse/mocks/mock_authenticator.cc
|
test/webfuse/mocks/mock_authenticator.cc
|
||||||
test/webfuse/mocks/mock_request.cc
|
test/webfuse/mocks/mock_request.cc
|
||||||
test/webfuse/mocks/mock_provider_client.cc
|
test/webfuse/mocks/mock_provider_client.cc
|
||||||
|
test/webfuse/mocks/mock_provider.cc
|
||||||
test/webfuse//tests/core/test_util.cc
|
test/webfuse//tests/core/test_util.cc
|
||||||
test/webfuse/tests/core/test_container_of.cc
|
test/webfuse/tests/core/test_container_of.cc
|
||||||
test/webfuse/tests/core/test_string.cc
|
test/webfuse/tests/core/test_string.cc
|
||||||
@ -45,6 +46,7 @@ add_executable(alltests
|
|||||||
test/webfuse/tests/adapter/test_fuse_req.cc
|
test/webfuse/tests/adapter/test_fuse_req.cc
|
||||||
test/webfuse/tests/provider/test_url.cc
|
test/webfuse/tests/provider/test_url.cc
|
||||||
test/webfuse/tests/provider/test_client_protocol.cc
|
test/webfuse/tests/provider/test_client_protocol.cc
|
||||||
|
test/webfuse/tests/provider/operation/test_close.cc
|
||||||
test/webfuse/tests/integration/test_integration.cc
|
test/webfuse/tests/integration/test_integration.cc
|
||||||
test/webfuse/tests/integration/server.cc
|
test/webfuse/tests/integration/server.cc
|
||||||
test/webfuse/tests/integration/provider.cc
|
test/webfuse/tests/integration/provider.cc
|
||||||
|
138
test/webfuse/mocks/mock_provider.cc
Normal file
138
test/webfuse/mocks/mock_provider.cc
Normal file
@ -0,0 +1,138 @@
|
|||||||
|
#include "webfuse/mocks/mock_provider.hpp"
|
||||||
|
|
||||||
|
extern "C"
|
||||||
|
{
|
||||||
|
using webfuse_test::MockProvider;
|
||||||
|
|
||||||
|
static void webfuse_test_MockProvider_connected(
|
||||||
|
void * user_data)
|
||||||
|
{
|
||||||
|
auto * provider = reinterpret_cast<MockProvider*>(user_data);
|
||||||
|
provider->connected();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void webfuse_test_MockProvider_disconnected(
|
||||||
|
void * user_data)
|
||||||
|
{
|
||||||
|
auto * provider = reinterpret_cast<MockProvider*>(user_data);
|
||||||
|
provider->disconnected();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void webfuse_test_MockProvider_on_timer(
|
||||||
|
void * user_data)
|
||||||
|
{
|
||||||
|
auto * provider = reinterpret_cast<MockProvider*>(user_data);
|
||||||
|
provider->on_timer();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void webfuse_test_MockProvider_lookup(
|
||||||
|
wfp_request * request,
|
||||||
|
ino_t parent,
|
||||||
|
char const * name,
|
||||||
|
void * user_data)
|
||||||
|
{
|
||||||
|
auto * provider = reinterpret_cast<MockProvider*>(user_data);
|
||||||
|
provider->lookup(request, parent, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void webfuse_test_MockProvider_getattr(
|
||||||
|
wfp_request * request,
|
||||||
|
ino_t inode,
|
||||||
|
void * user_data)
|
||||||
|
{
|
||||||
|
auto * provider = reinterpret_cast<MockProvider*>(user_data);
|
||||||
|
provider->getattr(request, inode);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void webfuse_test_MockProvider_readdir(
|
||||||
|
wfp_request * request,
|
||||||
|
ino_t directory,
|
||||||
|
void * user_data)
|
||||||
|
{
|
||||||
|
auto * provider = reinterpret_cast<MockProvider*>(user_data);
|
||||||
|
provider->readdir(request, directory);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void webfuse_test_MockProvider_open(
|
||||||
|
wfp_request * request,
|
||||||
|
ino_t inode,
|
||||||
|
int flags,
|
||||||
|
void * user_data)
|
||||||
|
{
|
||||||
|
auto * provider = reinterpret_cast<MockProvider*>(user_data);
|
||||||
|
provider->open(request, inode, flags);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static void webfuse_test_MockProvider_close(
|
||||||
|
ino_t inode,
|
||||||
|
uint32_t handle,
|
||||||
|
int flags,
|
||||||
|
void * user_data)
|
||||||
|
{
|
||||||
|
auto * provider = reinterpret_cast<MockProvider*>(user_data);
|
||||||
|
provider->close(inode, handle, flags);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static void webfuse_test_MockProvider_read(
|
||||||
|
wfp_request * request,
|
||||||
|
ino_t inode,
|
||||||
|
uint32_t handle,
|
||||||
|
size_t offset,
|
||||||
|
size_t length,
|
||||||
|
void * user_data)
|
||||||
|
{
|
||||||
|
auto * provider = reinterpret_cast<MockProvider*>(user_data);
|
||||||
|
provider->read(request, inode, handle, offset, length);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void webfuse_test_MockProvider_get_credentials(
|
||||||
|
wfp_credentials * credentials,
|
||||||
|
void * user_data)
|
||||||
|
{
|
||||||
|
auto * provider = reinterpret_cast<MockProvider*>(user_data);
|
||||||
|
provider->get_credentials(credentials);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static wfp_provider const webfuse_test_MockProvider =
|
||||||
|
{
|
||||||
|
&webfuse_test_MockProvider_connected,
|
||||||
|
&webfuse_test_MockProvider_disconnected,
|
||||||
|
&webfuse_test_MockProvider_on_timer,
|
||||||
|
&webfuse_test_MockProvider_lookup,
|
||||||
|
&webfuse_test_MockProvider_getattr,
|
||||||
|
&webfuse_test_MockProvider_readdir,
|
||||||
|
&webfuse_test_MockProvider_open,
|
||||||
|
&webfuse_test_MockProvider_close,
|
||||||
|
&webfuse_test_MockProvider_read,
|
||||||
|
&webfuse_test_MockProvider_get_credentials,
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace webfuse_test
|
||||||
|
{
|
||||||
|
|
||||||
|
MockProvider::MockProvider()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
MockProvider::~MockProvider()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
wfp_provider const * MockProvider::get_provider()
|
||||||
|
{
|
||||||
|
return &webfuse_test_MockProvider;
|
||||||
|
}
|
||||||
|
|
||||||
|
void * MockProvider::get_userdata()
|
||||||
|
{
|
||||||
|
return reinterpret_cast<void*>(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
31
test/webfuse/mocks/mock_provider.hpp
Normal file
31
test/webfuse/mocks/mock_provider.hpp
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
#ifndef WF_MOCK_PROVIDER_HPP
|
||||||
|
#define WF_MOCK_PROVIDER_HPP
|
||||||
|
|
||||||
|
#include "webfuse/provider/impl/provider.h"
|
||||||
|
#include <gmock/gmock.h>
|
||||||
|
|
||||||
|
namespace webfuse_test
|
||||||
|
{
|
||||||
|
|
||||||
|
class MockProvider
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
MockProvider();
|
||||||
|
~MockProvider();
|
||||||
|
wfp_provider const * get_provider();
|
||||||
|
void * get_userdata();
|
||||||
|
MOCK_METHOD0(connected, void ());
|
||||||
|
MOCK_METHOD0(disconnected, void ());
|
||||||
|
MOCK_METHOD0(on_timer, void());
|
||||||
|
MOCK_METHOD3(lookup, void(wfp_request * request, ino_t parent, char const * name));
|
||||||
|
MOCK_METHOD2(getattr, void(wfp_request * request, ino_t inode));
|
||||||
|
MOCK_METHOD2(readdir, void(wfp_request * request, ino_t directory));
|
||||||
|
MOCK_METHOD3(open, void(wfp_request * request, ino_t inode, int flags));
|
||||||
|
MOCK_METHOD3(close, void(ino_t inode, uint32_t handle, int flags));
|
||||||
|
MOCK_METHOD5(read, void(wfp_request * request, ino_t inode, uint32_t handle, size_t offset, size_t length));
|
||||||
|
MOCK_METHOD1(get_credentials, void(wfp_credentials * credentials));
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
111
test/webfuse/tests/provider/operation/test_close.cc
Normal file
111
test/webfuse/tests/provider/operation/test_close.cc
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
#include "webfuse/provider/impl/operation/close.h"
|
||||||
|
#include "webfuse/mocks/mock_provider.hpp"
|
||||||
|
|
||||||
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
using ::webfuse_test::MockProvider;
|
||||||
|
using ::testing::_;
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
wfp_impl_invokation_context create_context(MockProvider& provider)
|
||||||
|
{
|
||||||
|
wfp_impl_invokation_context context =
|
||||||
|
{
|
||||||
|
provider.get_provider(),
|
||||||
|
provider.get_userdata(),
|
||||||
|
nullptr
|
||||||
|
};
|
||||||
|
return context;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(wfp_close, close)
|
||||||
|
{
|
||||||
|
int inode = 42;
|
||||||
|
int handle = 0xdeadbeef;
|
||||||
|
int flags = 23;
|
||||||
|
|
||||||
|
MockProvider provider;
|
||||||
|
EXPECT_CALL(provider, close(inode, handle, flags)).Times(1);
|
||||||
|
|
||||||
|
wfp_impl_invokation_context context = create_context(provider);
|
||||||
|
|
||||||
|
json_t * params = json_array();
|
||||||
|
json_array_append_new(params, json_string("test.filesystem"));
|
||||||
|
json_array_append_new(params, json_integer(inode));
|
||||||
|
json_array_append_new(params, json_integer(handle));
|
||||||
|
json_array_append_new(params, json_integer(flags));
|
||||||
|
|
||||||
|
wfp_impl_close(&context, params, 42);
|
||||||
|
json_decref(params);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(wfp_close, close_fail_invalid_param_count)
|
||||||
|
{
|
||||||
|
MockProvider provider;
|
||||||
|
EXPECT_CALL(provider, close(_,_,_)).Times(0);
|
||||||
|
|
||||||
|
wfp_impl_invokation_context context = create_context(provider);
|
||||||
|
|
||||||
|
json_t * params = json_array();
|
||||||
|
wfp_impl_close(&context, params, 42);
|
||||||
|
json_decref(params);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(wfp_close, close_fail_inode_invalid_type)
|
||||||
|
{
|
||||||
|
MockProvider provider;
|
||||||
|
EXPECT_CALL(provider, close(_,_,_)).Times(0);
|
||||||
|
|
||||||
|
wfp_impl_invokation_context context = create_context(provider);
|
||||||
|
|
||||||
|
json_t * params = json_array();
|
||||||
|
json_array_append_new(params, json_string("test.filesystem"));
|
||||||
|
json_array_append_new(params, json_string("42"));
|
||||||
|
json_array_append_new(params, json_integer(0));
|
||||||
|
json_array_append_new(params, json_integer(0));
|
||||||
|
|
||||||
|
wfp_impl_close(&context, params, 42);
|
||||||
|
json_decref(params);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(wfp_close, close_fail_handle_invalid_type)
|
||||||
|
{
|
||||||
|
MockProvider provider;
|
||||||
|
EXPECT_CALL(provider, close(_,_,_)).Times(0);
|
||||||
|
|
||||||
|
wfp_impl_invokation_context context = create_context(provider);
|
||||||
|
|
||||||
|
json_t * params = json_array();
|
||||||
|
json_array_append_new(params, json_string("test.filesystem"));
|
||||||
|
json_array_append_new(params, json_integer(0));
|
||||||
|
json_array_append_new(params, json_string("42"));
|
||||||
|
json_array_append_new(params, json_integer(0));
|
||||||
|
|
||||||
|
wfp_impl_close(&context, params, 42);
|
||||||
|
json_decref(params);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(wfp_close, close_fail_flags_invalid_type)
|
||||||
|
{
|
||||||
|
MockProvider provider;
|
||||||
|
EXPECT_CALL(provider, close(_,_,_)).Times(0);
|
||||||
|
|
||||||
|
wfp_impl_invokation_context context = create_context(provider);
|
||||||
|
|
||||||
|
json_t * params = json_array();
|
||||||
|
json_array_append_new(params, json_string("test.filesystem"));
|
||||||
|
json_array_append_new(params, json_integer(0));
|
||||||
|
json_array_append_new(params, json_integer(0));
|
||||||
|
json_array_append_new(params, json_string("42"));
|
||||||
|
|
||||||
|
wfp_impl_close(&context, params, 42);
|
||||||
|
json_decref(params);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
TEST(wfp_close, default_nop)
|
||||||
|
{
|
||||||
|
wfp_impl_close_default(0, 0, 0, nullptr);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user