mirror of
https://github.com/falk-werner/webfuse-provider
synced 2024-10-27 20:44:10 +00:00
refactor: simlify usage of wfp_json_doc in unit tests
This commit is contained in:
parent
2506873805
commit
2979904514
@ -1,26 +1,22 @@
|
|||||||
#include "webfuse_provider/impl/jsonrpc/request.h"
|
#include "webfuse_provider/impl/jsonrpc/request.h"
|
||||||
#include "webfuse_provider/impl/json/parser.h"
|
#include "webfuse_provider/test_util/json_doc.hpp"
|
||||||
|
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
using webfuse_test::JsonDoc;
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_request, request_with_object_params)
|
TEST(wfp_jsonrpc_is_request, request_with_object_params)
|
||||||
{
|
{
|
||||||
char text[] = "{\"method\": \"method\", \"params\": {}, \"id\": 42}";
|
JsonDoc doc("{\"method\": \"method\", \"params\": {}, \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_TRUE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_TRUE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_request, request_with_array_params)
|
TEST(wfp_jsonrpc_is_request, request_with_array_params)
|
||||||
{
|
{
|
||||||
char text[] = "{\"method\": \"method\", \"params\": [], \"id\": 42}";
|
JsonDoc doc("{\"method\": \"method\", \"params\": [], \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_TRUE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_TRUE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_request, null_request)
|
TEST(wfp_jsonrpc_is_request, null_request)
|
||||||
@ -30,70 +26,49 @@ TEST(wfp_jsonrpc_is_request, null_request)
|
|||||||
|
|
||||||
TEST(wfp_jsonrpc_is_request, invalid_request)
|
TEST(wfp_jsonrpc_is_request, invalid_request)
|
||||||
{
|
{
|
||||||
char text[] = "[\"method\", { }, 42]";
|
JsonDoc doc("[\"method\", { }, 42]");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_request, invalid_request_without_id)
|
TEST(wfp_jsonrpc_is_request, invalid_request_without_id)
|
||||||
{
|
{
|
||||||
char text[] = "{\"method\": \"method\", \"params\": { }}";
|
JsonDoc doc("{\"method\": \"method\", \"params\": { }}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_request, invalid_request_due_to_invalid_id)
|
TEST(wfp_jsonrpc_is_request, invalid_request_due_to_invalid_id)
|
||||||
{
|
{
|
||||||
char text[] = "{\"method\": \"method\", \"params\": { }, \"id\": \"42\"}";
|
JsonDoc doc("{\"method\": \"method\", \"params\": { }, \"id\": \"42\"}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_request, invalid_request_without_method)
|
TEST(wfp_jsonrpc_is_request, invalid_request_without_method)
|
||||||
{
|
{
|
||||||
char text[] = "{\"params\": { }, \"id\": 42}";
|
JsonDoc doc("{\"params\": { }, \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_request, invalid_request_due_to_invalid_method)
|
TEST(wfp_jsonrpc_is_request, invalid_request_due_to_invalid_method)
|
||||||
{
|
{
|
||||||
char text[] = "{\"method\": 42, \"params\": {}, \"id\": 42}";
|
JsonDoc doc("{\"method\": 42, \"params\": {}, \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_request, invalid_request_without_params)
|
TEST(wfp_jsonrpc_is_request, invalid_request_without_params)
|
||||||
{
|
{
|
||||||
char text[] = "{\"method\": \"method\", \"id\": 42}";
|
JsonDoc doc("{\"method\": \"method\", \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_request, invalid_request_due_to_invalid_params)
|
TEST(wfp_jsonrpc_is_request, invalid_request_due_to_invalid_params)
|
||||||
{
|
{
|
||||||
char text[] = "{\"method\": \"method\", \"params\": \"params\", \"id\": 42}";
|
JsonDoc doc("{\"method\": \"method\", \"params\": \"params\", \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
@ -1,35 +1,28 @@
|
|||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
#include "webfuse_provider/impl/jsonrpc/response.h"
|
#include "webfuse_provider/impl/jsonrpc/response.h"
|
||||||
#include "webfuse_provider/impl/json/parser.h"
|
#include "webfuse_provider/test_util/json_doc.hpp"
|
||||||
|
|
||||||
|
using webfuse_test::JsonDoc;
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_response, valid_result)
|
TEST(wfp_jsonrpc_is_response, valid_result)
|
||||||
{
|
{
|
||||||
char text[] = "{\"result\": {}, \"id\": 42}";
|
JsonDoc doc("{\"result\": {}, \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_TRUE(wfp_jsonrpc_is_response(wfp_impl_json_root(doc)));
|
ASSERT_TRUE(wfp_jsonrpc_is_response(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_response, valid_result_string)
|
TEST(wfp_jsonrpc_is_response, valid_result_string)
|
||||||
{
|
{
|
||||||
char text[] = "{\"result\": \"also valid\", \"id\": 42}";
|
JsonDoc doc("{\"result\": \"also valid\", \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_TRUE(wfp_jsonrpc_is_response(wfp_impl_json_root(doc)));
|
ASSERT_TRUE(wfp_jsonrpc_is_response(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_response, valid_error)
|
TEST(wfp_jsonrpc_is_response, valid_error)
|
||||||
{
|
{
|
||||||
char text[] = "{\"error\": { }, \"id\": 42}";
|
JsonDoc doc("{\"error\": { }, \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_TRUE(wfp_jsonrpc_is_response(wfp_impl_json_root(doc)));
|
ASSERT_TRUE(wfp_jsonrpc_is_response(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_response, invalid_null)
|
TEST(wfp_jsonrpc_is_response, invalid_null)
|
||||||
@ -39,51 +32,36 @@ TEST(wfp_jsonrpc_is_response, invalid_null)
|
|||||||
|
|
||||||
TEST(wfp_jsonrpc_is_response, invalid_message)
|
TEST(wfp_jsonrpc_is_response, invalid_message)
|
||||||
{
|
{
|
||||||
char text[] = "[{ }, 42]";
|
JsonDoc doc("[{ }, 42]");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_response(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_response(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_response, invalid_missing_id)
|
TEST(wfp_jsonrpc_is_response, invalid_missing_id)
|
||||||
{
|
{
|
||||||
char text[] = "{\"result\": { } }";
|
JsonDoc doc("{\"result\": { } }");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_response(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_response(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_response, invalid_id_wrong_type)
|
TEST(wfp_jsonrpc_is_response, invalid_id_wrong_type)
|
||||||
{
|
{
|
||||||
char text[] = "{\"result\": { }, \"id\": \"42\"}";
|
JsonDoc doc("{\"result\": { }, \"id\": \"42\"}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_response(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_response(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_response, invalid_missing_result_and_error)
|
TEST(wfp_jsonrpc_is_response, invalid_missing_result_and_error)
|
||||||
{
|
{
|
||||||
char text[] = "{\"id\": \"42\"}";
|
JsonDoc doc("{\"id\": \"42\"}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_response(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_response(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_is_response, invalid_error_wrong_type)
|
TEST(wfp_jsonrpc_is_response, invalid_error_wrong_type)
|
||||||
{
|
{
|
||||||
char text[] = "{\"error\": [], \"id\": \"42\"}";
|
JsonDoc doc("{\"error\": [], \"id\": \"42\"}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_response(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_response(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
#include "webfuse_provider/impl/jsonrpc/proxy.h"
|
#include "webfuse_provider/impl/jsonrpc/proxy.h"
|
||||||
#include "webfuse_provider/impl/jsonrpc/error.h"
|
#include "webfuse_provider/impl/jsonrpc/error.h"
|
||||||
#include "webfuse_provider/impl/json/parser.h"
|
|
||||||
#include "webfuse_provider/status.h"
|
#include "webfuse_provider/status.h"
|
||||||
#include "webfuse_provider/impl/timer/manager.h"
|
#include "webfuse_provider/impl/timer/manager.h"
|
||||||
|
|
||||||
#include "webfuse_provider/jsonrpc/mock_timer.hpp"
|
#include "webfuse_provider/jsonrpc/mock_timer.hpp"
|
||||||
|
#include "webfuse_provider/test_util/json_doc.hpp"
|
||||||
|
|
||||||
#include <libwebsockets.h>
|
#include <libwebsockets.h>
|
||||||
|
|
||||||
@ -14,6 +14,7 @@
|
|||||||
|
|
||||||
using namespace std::chrono_literals;
|
using namespace std::chrono_literals;
|
||||||
using wfp_jsonrpc_test::MockTimer;
|
using wfp_jsonrpc_test::MockTimer;
|
||||||
|
using webfuse_test::JsonDoc;
|
||||||
using testing::Return;
|
using testing::Return;
|
||||||
using testing::_;
|
using testing::_;
|
||||||
using testing::DoAll;
|
using testing::DoAll;
|
||||||
@ -188,11 +189,8 @@ TEST(wfp_jsonrpc_proxy, on_result)
|
|||||||
|
|
||||||
ASSERT_TRUE(send_context.is_called);
|
ASSERT_TRUE(send_context.is_called);
|
||||||
|
|
||||||
char response_text[] = "{\"result\": \"okay\", \"id\": 42}";
|
JsonDoc doc("{\"result\": \"okay\", \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(response_text);
|
wfp_jsonrpc_proxy_onresult(proxy, doc.root());
|
||||||
|
|
||||||
wfp_jsonrpc_proxy_onresult(proxy, wfp_impl_json_root(doc));
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
|
|
||||||
ASSERT_TRUE(finished_context.is_called);
|
ASSERT_TRUE(finished_context.is_called);
|
||||||
ASSERT_EQ(nullptr, finished_context.error);
|
ASSERT_EQ(nullptr, finished_context.error);
|
||||||
@ -216,11 +214,8 @@ TEST(wfp_jsonrpc_proxy, on_result_reject_response_with_unknown_id)
|
|||||||
|
|
||||||
ASSERT_TRUE(send_context.is_called);
|
ASSERT_TRUE(send_context.is_called);
|
||||||
|
|
||||||
char response_text[] = "{\"result\": \"okay\", \"id\": 1234}";
|
JsonDoc doc("{\"result\": \"okay\", \"id\": 1234}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(response_text);
|
wfp_jsonrpc_proxy_onresult(proxy, doc.root());
|
||||||
|
|
||||||
wfp_jsonrpc_proxy_onresult(proxy, wfp_impl_json_root(doc));
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
|
|
||||||
ASSERT_FALSE(finished_context.is_called);
|
ASSERT_FALSE(finished_context.is_called);
|
||||||
|
|
||||||
@ -340,11 +335,8 @@ TEST(wfp_jsonrpc_proxy, on_result_swallow_if_no_request_pending)
|
|||||||
void * send_data = reinterpret_cast<void*>(&send_context);
|
void * send_data = reinterpret_cast<void*>(&send_context);
|
||||||
struct wfp_jsonrpc_proxy * proxy = wfp_jsonrpc_proxy_create(timer_manager, WFP_DEFAULT_TIMEOUT, &jsonrpc_send, send_data);
|
struct wfp_jsonrpc_proxy * proxy = wfp_jsonrpc_proxy_create(timer_manager, WFP_DEFAULT_TIMEOUT, &jsonrpc_send, send_data);
|
||||||
|
|
||||||
char response_text[] = "{\"result\": \"okay\", \"id\": 42}";
|
JsonDoc doc("{\"result\": \"okay\", \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(response_text);
|
wfp_jsonrpc_proxy_onresult(proxy, doc.root());
|
||||||
|
|
||||||
wfp_jsonrpc_proxy_onresult(proxy, wfp_impl_json_root(doc));
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
|
|
||||||
wfp_jsonrpc_proxy_dispose(proxy);
|
wfp_jsonrpc_proxy_dispose(proxy);
|
||||||
wfp_timer_manager_dispose(timer_manager);
|
wfp_timer_manager_dispose(timer_manager);
|
||||||
|
@ -1,33 +1,26 @@
|
|||||||
#include "webfuse_provider/impl/jsonrpc/request.h"
|
#include "webfuse_provider/impl/jsonrpc/request.h"
|
||||||
#include "webfuse_provider/impl/json/parser.h"
|
#include "webfuse_provider/test_util/json_doc.hpp"
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
using webfuse_test::JsonDoc;
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_request, is_request_object_params)
|
TEST(wfp_jsonrpc_request, is_request_object_params)
|
||||||
{
|
{
|
||||||
char text[] = "{\"method\": \"some_method\", \"params\": { }, \"id\": 42}";
|
JsonDoc doc("{\"method\": \"some_method\", \"params\": { }, \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_TRUE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_TRUE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_request, is_request_fail_missing_params)
|
TEST(wfp_jsonrpc_request, is_request_fail_missing_params)
|
||||||
{
|
{
|
||||||
char text[] = "{\"method\": \"some_method\", \"id\": 42}";
|
JsonDoc doc("{\"method\": \"some_method\", \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_jsonrpc_request, is_request_fail_params_wrong_type)
|
TEST(wfp_jsonrpc_request, is_request_fail_params_wrong_type)
|
||||||
{
|
{
|
||||||
char text[] = "{\"method\": \"some_method\", \"params\": \"invalid_params\", \"id\": 42}";
|
JsonDoc doc("{\"method\": \"some_method\", \"params\": \"invalid_params\", \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
ASSERT_FALSE(wfp_jsonrpc_is_request(wfp_impl_json_root(doc)));
|
ASSERT_FALSE(wfp_jsonrpc_is_request(doc.root()));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
@ -1,17 +1,18 @@
|
|||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
#include "webfuse_provider/impl/jsonrpc/response_intern.h"
|
#include "webfuse_provider/impl/jsonrpc/response_intern.h"
|
||||||
#include "webfuse_provider/status.h"
|
#include "webfuse_provider/status.h"
|
||||||
#include "webfuse_provider/impl/json/parser.h"
|
#include "webfuse_provider/test_util/json_doc.hpp"
|
||||||
#include "webfuse_provider/impl/json/node.h"
|
#include "webfuse_provider/impl/json/node.h"
|
||||||
#include "webfuse_provider/impl/jsonrpc/error.h"
|
#include "webfuse_provider/impl/jsonrpc/error.h"
|
||||||
|
|
||||||
|
using webfuse_test::JsonDoc;
|
||||||
|
|
||||||
TEST(wfp_json_response, init_result)
|
TEST(wfp_json_response, init_result)
|
||||||
{
|
{
|
||||||
char text[] = "{\"result\": 47, \"id\": 11}";
|
JsonDoc doc("{\"result\": 47, \"id\": 11}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response,doc.root());
|
||||||
|
|
||||||
ASSERT_EQ(nullptr, response.error);
|
ASSERT_EQ(nullptr, response.error);
|
||||||
ASSERT_TRUE(wfp_impl_json_is_int(response.result));
|
ASSERT_TRUE(wfp_impl_json_is_int(response.result));
|
||||||
@ -19,16 +20,14 @@ TEST(wfp_json_response, init_result)
|
|||||||
ASSERT_EQ(11, response.id);
|
ASSERT_EQ(11, response.id);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_json_response, init_error)
|
TEST(wfp_json_response, init_error)
|
||||||
{
|
{
|
||||||
char text[] = "{\"error\": {\"code\": 42, \"message\": \"Don't Panic!\"}, \"id\": 23}";
|
JsonDoc doc("{\"error\": {\"code\": 42, \"message\": \"Don't Panic!\"}, \"id\": 23}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_EQ(42, response.error->code);
|
ASSERT_EQ(42, response.error->code);
|
||||||
ASSERT_STREQ("Don't Panic!", response.error->message);
|
ASSERT_STREQ("Don't Panic!", response.error->message);
|
||||||
@ -36,101 +35,88 @@ TEST(wfp_json_response, init_error)
|
|||||||
ASSERT_EQ(23, response.id);
|
ASSERT_EQ(23, response.id);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_json_response, init_fail_missing_result_and_error)
|
TEST(wfp_json_response, init_fail_missing_result_and_error)
|
||||||
{
|
{
|
||||||
char text[] = "{\"id\": 12}";
|
JsonDoc doc("{\"id\": 12}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_EQ(WFP_BAD_FORMAT, response.error->code);
|
ASSERT_EQ(WFP_BAD_FORMAT, response.error->code);
|
||||||
ASSERT_EQ(nullptr, response.result);
|
ASSERT_EQ(nullptr, response.result);
|
||||||
ASSERT_EQ(12, response.id);
|
ASSERT_EQ(12, response.id);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_json_response, init_fail_missing_id)
|
TEST(wfp_json_response, init_fail_missing_id)
|
||||||
{
|
{
|
||||||
char text[] = "{\"result\": 47}";
|
JsonDoc doc("{\"result\": 47}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_EQ(WFP_BAD_FORMAT, response.error->code);
|
ASSERT_EQ(WFP_BAD_FORMAT, response.error->code);
|
||||||
ASSERT_EQ(nullptr, response.result);
|
ASSERT_EQ(nullptr, response.result);
|
||||||
ASSERT_EQ(-1, response.id);
|
ASSERT_EQ(-1, response.id);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_json_response, init_fail_wrong_id_type)
|
TEST(wfp_json_response, init_fail_wrong_id_type)
|
||||||
{
|
{
|
||||||
char text[] = "{\"result\": 47, \"id\": \"42\"}";
|
JsonDoc doc("{\"result\": 47, \"id\": \"42\"}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_EQ(WFP_BAD_FORMAT, response.error->code);
|
ASSERT_EQ(WFP_BAD_FORMAT, response.error->code);
|
||||||
ASSERT_EQ(nullptr, response.result);
|
ASSERT_EQ(nullptr, response.result);
|
||||||
ASSERT_EQ(-1, response.id);
|
ASSERT_EQ(-1, response.id);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_json_response, init_fail_error_missing_code)
|
TEST(wfp_json_response, init_fail_error_missing_code)
|
||||||
{
|
{
|
||||||
char text[] = "{\"error\": {\"message\": \"Don't Panic!\"}, \"id\": 23}";
|
JsonDoc doc("{\"error\": {\"message\": \"Don't Panic!\"}, \"id\": 23}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_EQ(WFP_BAD_FORMAT,response.error->code);
|
ASSERT_EQ(WFP_BAD_FORMAT,response.error->code);
|
||||||
ASSERT_EQ(nullptr, response.result);
|
ASSERT_EQ(nullptr, response.result);
|
||||||
ASSERT_EQ(23, response.id);
|
ASSERT_EQ(23, response.id);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_json_response, init_fail_error_wrong_code_type)
|
TEST(wfp_json_response, init_fail_error_wrong_code_type)
|
||||||
{
|
{
|
||||||
char text[] = "{\"error\": {\"code\": \"42\", \"message\": \"Don't Panic!\"}, \"id\": 23}";
|
JsonDoc doc("{\"error\": {\"code\": \"42\", \"message\": \"Don't Panic!\"}, \"id\": 23}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_EQ(WFP_BAD_FORMAT, response.error->code);
|
ASSERT_EQ(WFP_BAD_FORMAT, response.error->code);
|
||||||
ASSERT_EQ(nullptr, response.result);
|
ASSERT_EQ(nullptr, response.result);
|
||||||
ASSERT_EQ(23, response.id);
|
ASSERT_EQ(23, response.id);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_json_response, init_fail_error_wrong_type)
|
TEST(wfp_json_response, init_fail_error_wrong_type)
|
||||||
{
|
{
|
||||||
char text[] = "{\"error\": \"invalid error type\", \"id\": 23}";
|
JsonDoc doc("{\"error\": \"invalid error type\", \"id\": 23}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_EQ(WFP_BAD_FORMAT, response.error->code);
|
ASSERT_EQ(WFP_BAD_FORMAT, response.error->code);
|
||||||
ASSERT_EQ(nullptr, response.result);
|
ASSERT_EQ(nullptr, response.result);
|
||||||
ASSERT_EQ(23, response.id);
|
ASSERT_EQ(23, response.id);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
@ -1,61 +1,55 @@
|
|||||||
#include "webfuse_provider/impl/jsonrpc/response_intern.h"
|
#include "webfuse_provider/impl/jsonrpc/response_intern.h"
|
||||||
#include "webfuse_provider/impl/jsonrpc/error.h"
|
#include "webfuse_provider/impl/jsonrpc/error.h"
|
||||||
#include "webfuse_provider/impl/json/parser.h"
|
#include "webfuse_provider/test_util/json_doc.hpp"
|
||||||
|
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
using webfuse_test::JsonDoc;
|
||||||
|
|
||||||
TEST(response_parser, fail_no_object)
|
TEST(response_parser, fail_no_object)
|
||||||
{
|
{
|
||||||
char text[] = "[]";
|
JsonDoc doc("[]");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_NE(nullptr, response.error);
|
ASSERT_NE(nullptr, response.error);
|
||||||
ASSERT_EQ(-1, response.id);
|
ASSERT_EQ(-1, response.id);
|
||||||
ASSERT_EQ(nullptr, response.result);
|
ASSERT_EQ(nullptr, response.result);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(response_error, fail_empty_object)
|
TEST(response_error, fail_empty_object)
|
||||||
{
|
{
|
||||||
char text[] = "{}";
|
JsonDoc doc("{}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_NE(nullptr, response.error);
|
ASSERT_NE(nullptr, response.error);
|
||||||
ASSERT_EQ(-1, response.id);
|
ASSERT_EQ(-1, response.id);
|
||||||
ASSERT_EQ(nullptr, response.result);
|
ASSERT_EQ(nullptr, response.result);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(response_error, fail_no_data)
|
TEST(response_error, fail_no_data)
|
||||||
{
|
{
|
||||||
char text[] = "{\"id\":42}";
|
JsonDoc doc("{\"id\":42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_NE(nullptr, response.error);
|
ASSERT_NE(nullptr, response.error);
|
||||||
ASSERT_EQ(42, response.id);
|
ASSERT_EQ(42, response.id);
|
||||||
ASSERT_EQ(nullptr, response.result);
|
ASSERT_EQ(nullptr, response.result);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(response_error, fail_with_custom_error_code)
|
TEST(response_error, fail_with_custom_error_code)
|
||||||
{
|
{
|
||||||
char text[] = "{\"error\":{\"code\": 42}, \"id\": 42}";
|
JsonDoc doc("{\"error\":{\"code\": 42}, \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_NE(nullptr, response.error);
|
ASSERT_NE(nullptr, response.error);
|
||||||
ASSERT_EQ(42, response.error->code);
|
ASSERT_EQ(42, response.error->code);
|
||||||
@ -63,20 +57,17 @@ TEST(response_error, fail_with_custom_error_code)
|
|||||||
ASSERT_EQ(nullptr, response.result);
|
ASSERT_EQ(nullptr, response.result);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(response_parser, fail_invalid_response)
|
TEST(response_parser, fail_invalid_response)
|
||||||
{
|
{
|
||||||
char text[] = "{\"result\": true, \"id\": 42}";
|
JsonDoc doc("{\"result\": true, \"id\": 42}");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(text);
|
|
||||||
struct wfp_jsonrpc_response response;
|
struct wfp_jsonrpc_response response;
|
||||||
wfp_jsonrpc_response_init(&response, wfp_impl_json_root(doc));
|
wfp_jsonrpc_response_init(&response, doc.root());
|
||||||
|
|
||||||
ASSERT_EQ(nullptr, response.error);
|
ASSERT_EQ(nullptr, response.error);
|
||||||
ASSERT_EQ(42, response.id);
|
ASSERT_EQ(42, response.id);
|
||||||
ASSERT_NE(nullptr, response.result);
|
ASSERT_NE(nullptr, response.result);
|
||||||
|
|
||||||
wfp_jsonrpc_response_cleanup(&response);
|
wfp_jsonrpc_response_cleanup(&response);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,13 @@
|
|||||||
#include "webfuse_provider/impl/operation/close.h"
|
#include "webfuse_provider/impl/operation/close.h"
|
||||||
#include "webfuse_provider/impl/json/parser.h"
|
|
||||||
#include "webfuse_provider/mocks/mock_provider.hpp"
|
#include "webfuse_provider/mocks/mock_provider.hpp"
|
||||||
#include "webfuse_provider/mocks/fake_invokation_context.hpp"
|
#include "webfuse_provider/mocks/fake_invokation_context.hpp"
|
||||||
|
#include "webfuse_provider/test_util/json_doc.hpp"
|
||||||
|
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
using ::webfuse_test::MockProvider;
|
using ::webfuse_test::MockProvider;
|
||||||
using ::webfuse_test::create_context;
|
using ::webfuse_test::create_context;
|
||||||
|
using ::webfuse_test::JsonDoc;
|
||||||
using ::testing::_;
|
using ::testing::_;
|
||||||
|
|
||||||
TEST(wfp_close, close)
|
TEST(wfp_close, close)
|
||||||
@ -16,11 +17,9 @@ TEST(wfp_close, close)
|
|||||||
|
|
||||||
wfp_impl_invokation_context context = create_context(provider);
|
wfp_impl_invokation_context context = create_context(provider);
|
||||||
|
|
||||||
char params[] = "[\"test.filesystem\", 42, 101, 23]";
|
JsonDoc doc("[\"test.filesystem\", 42, 101, 23]");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(params);
|
|
||||||
|
|
||||||
wfp_impl_close(&context, wfp_impl_json_root(doc), 42);
|
wfp_impl_close(&context, doc.root(), 42);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_close, close_fail_invalid_param_count)
|
TEST(wfp_close, close_fail_invalid_param_count)
|
||||||
@ -30,11 +29,9 @@ TEST(wfp_close, close_fail_invalid_param_count)
|
|||||||
|
|
||||||
wfp_impl_invokation_context context = create_context(provider);
|
wfp_impl_invokation_context context = create_context(provider);
|
||||||
|
|
||||||
char params[] = "[]";
|
JsonDoc doc("[]");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(params);
|
|
||||||
|
|
||||||
wfp_impl_close(&context, wfp_impl_json_root(doc), 42);
|
wfp_impl_close(&context, doc.root(), 42);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_close, close_fail_inode_invalid_type)
|
TEST(wfp_close, close_fail_inode_invalid_type)
|
||||||
@ -44,11 +41,9 @@ TEST(wfp_close, close_fail_inode_invalid_type)
|
|||||||
|
|
||||||
wfp_impl_invokation_context context = create_context(provider);
|
wfp_impl_invokation_context context = create_context(provider);
|
||||||
|
|
||||||
char params[] = "[\"test.filesystem\", \"42\", 0, 0]";
|
JsonDoc doc("[\"test.filesystem\", \"42\", 0, 0]");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(params);
|
|
||||||
|
|
||||||
wfp_impl_close(&context, wfp_impl_json_root(doc), 42);
|
wfp_impl_close(&context, doc.root(), 42);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_close, close_fail_handle_invalid_type)
|
TEST(wfp_close, close_fail_handle_invalid_type)
|
||||||
@ -58,11 +53,9 @@ TEST(wfp_close, close_fail_handle_invalid_type)
|
|||||||
|
|
||||||
wfp_impl_invokation_context context = create_context(provider);
|
wfp_impl_invokation_context context = create_context(provider);
|
||||||
|
|
||||||
char params[] = "[\"test.filesystem\", 0, \"42\", 0]";
|
JsonDoc doc("[\"test.filesystem\", 0, \"42\", 0]");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(params);
|
|
||||||
|
|
||||||
wfp_impl_close(&context, wfp_impl_json_root(doc), 42);
|
wfp_impl_close(&context, doc.root(), 42);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(wfp_close, close_fail_flags_invalid_type)
|
TEST(wfp_close, close_fail_flags_invalid_type)
|
||||||
@ -72,11 +65,9 @@ TEST(wfp_close, close_fail_flags_invalid_type)
|
|||||||
|
|
||||||
wfp_impl_invokation_context context = create_context(provider);
|
wfp_impl_invokation_context context = create_context(provider);
|
||||||
|
|
||||||
char params[] = "[\"test.filesystem\", 0, 0, \"42\"]";
|
JsonDoc doc("[\"test.filesystem\", 0, 0, \"42\"]");
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(params);
|
|
||||||
|
|
||||||
wfp_impl_close(&context, wfp_impl_json_root(doc), 42);
|
wfp_impl_close(&context, doc.root(), 42);
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#include "webfuse_provider/test_util/webfuse_server.hpp"
|
#include "webfuse_provider/test_util/webfuse_server.hpp"
|
||||||
#include "webfuse_provider/mocks/mock_provider_client.hpp"
|
#include "webfuse_provider/mocks/mock_provider_client.hpp"
|
||||||
#include "webfuse_provider/test_util/client.hpp"
|
#include "webfuse_provider/test_util/client.hpp"
|
||||||
#include "webfuse_provider/impl/json/parser.h"
|
#include "webfuse_provider/test_util/json_doc.hpp"
|
||||||
#include "webfuse_provider/impl/json/node.h"
|
#include "webfuse_provider/impl/json/node.h"
|
||||||
|
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
@ -12,6 +12,7 @@
|
|||||||
using webfuse_test::WebfuseServer;
|
using webfuse_test::WebfuseServer;
|
||||||
using webfuse_test::MockProviderClient;
|
using webfuse_test::MockProviderClient;
|
||||||
using webfuse_test::Client;
|
using webfuse_test::Client;
|
||||||
|
using webfuse_test::JsonDoc;
|
||||||
using testing::Invoke;
|
using testing::Invoke;
|
||||||
using testing::_;
|
using testing::_;
|
||||||
using testing::StrEq;
|
using testing::StrEq;
|
||||||
@ -148,9 +149,8 @@ TEST(Client, Lookup)
|
|||||||
|
|
||||||
ASSERT_EQ(std::future_status::ready, connected.get_future().wait_for(TIMEOUT));
|
ASSERT_EQ(std::future_status::ready, connected.get_future().wait_for(TIMEOUT));
|
||||||
|
|
||||||
std::string response_text = server.Lookup(1, "foo");
|
JsonDoc doc(server.Lookup(1, "foo"));
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(const_cast<char*>(response_text.data()));
|
wfp_json const * response = doc.root();
|
||||||
wfp_json const * response = wfp_impl_json_root(doc);
|
|
||||||
ASSERT_TRUE(wfp_impl_json_is_object(response));
|
ASSERT_TRUE(wfp_impl_json_is_object(response));
|
||||||
wfp_json const * result = wfp_impl_json_object_get(response, "result");
|
wfp_json const * result = wfp_impl_json_object_get(response, "result");
|
||||||
|
|
||||||
@ -163,8 +163,6 @@ TEST(Client, Lookup)
|
|||||||
wfp_json const * type = wfp_impl_json_object_get(result, "type");
|
wfp_json const * type = wfp_impl_json_object_get(result, "type");
|
||||||
ASSERT_STREQ("file", wfp_impl_json_get_string(type));
|
ASSERT_STREQ("file", wfp_impl_json_get_string(type));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
|
|
||||||
client.Disconnect();
|
client.Disconnect();
|
||||||
ASSERT_EQ(std::future_status::ready, disconnected.get_future().wait_for(TIMEOUT));
|
ASSERT_EQ(std::future_status::ready, disconnected.get_future().wait_for(TIMEOUT));
|
||||||
}
|
}
|
||||||
@ -198,9 +196,8 @@ TEST(Client, LookupFail)
|
|||||||
|
|
||||||
ASSERT_EQ(std::future_status::ready, connected.get_future().wait_for(TIMEOUT));
|
ASSERT_EQ(std::future_status::ready, connected.get_future().wait_for(TIMEOUT));
|
||||||
|
|
||||||
std::string response_text = server.Lookup(1, "foo");
|
JsonDoc doc(server.Lookup(1, "foo"));
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(const_cast<char*>(response_text.data()));
|
wfp_json const * response = doc.root();
|
||||||
wfp_json const * response = wfp_impl_json_root(doc);
|
|
||||||
|
|
||||||
ASSERT_TRUE(wfp_impl_json_is_object(response));
|
ASSERT_TRUE(wfp_impl_json_is_object(response));
|
||||||
wfp_json const * error = wfp_impl_json_object_get(response, "error");
|
wfp_json const * error = wfp_impl_json_object_get(response, "error");
|
||||||
@ -208,8 +205,6 @@ TEST(Client, LookupFail)
|
|||||||
wfp_json const * code = wfp_impl_json_object_get(error, "code");
|
wfp_json const * code = wfp_impl_json_object_get(error, "code");
|
||||||
ASSERT_NE(0, wfp_impl_json_get_int(code));
|
ASSERT_NE(0, wfp_impl_json_get_int(code));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
|
|
||||||
client.Disconnect();
|
client.Disconnect();
|
||||||
ASSERT_EQ(std::future_status::ready, disconnected.get_future().wait_for(TIMEOUT));
|
ASSERT_EQ(std::future_status::ready, disconnected.get_future().wait_for(TIMEOUT));
|
||||||
}
|
}
|
||||||
@ -243,9 +238,8 @@ TEST(Client, Open)
|
|||||||
|
|
||||||
ASSERT_EQ(std::future_status::ready, connected.get_future().wait_for(TIMEOUT));
|
ASSERT_EQ(std::future_status::ready, connected.get_future().wait_for(TIMEOUT));
|
||||||
|
|
||||||
std::string response_text = server.Open(1, 0);
|
JsonDoc doc(server.Open(1, 0));
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(const_cast<char*>(response_text.data()));
|
wfp_json const * response = doc.root();
|
||||||
wfp_json const * response = wfp_impl_json_root(doc);
|
|
||||||
|
|
||||||
ASSERT_TRUE(wfp_impl_json_is_object(response));
|
ASSERT_TRUE(wfp_impl_json_is_object(response));
|
||||||
wfp_json const * result = wfp_impl_json_object_get(response, "result");
|
wfp_json const * result = wfp_impl_json_object_get(response, "result");
|
||||||
@ -253,8 +247,6 @@ TEST(Client, Open)
|
|||||||
wfp_json const * handle = wfp_impl_json_object_get(result, "handle");
|
wfp_json const * handle = wfp_impl_json_object_get(result, "handle");
|
||||||
ASSERT_EQ(4711, wfp_impl_json_get_int(handle));
|
ASSERT_EQ(4711, wfp_impl_json_get_int(handle));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
|
|
||||||
client.Disconnect();
|
client.Disconnect();
|
||||||
ASSERT_EQ(std::future_status::ready, disconnected.get_future().wait_for(TIMEOUT));
|
ASSERT_EQ(std::future_status::ready, disconnected.get_future().wait_for(TIMEOUT));
|
||||||
}
|
}
|
||||||
@ -289,9 +281,8 @@ TEST(Client, Read)
|
|||||||
|
|
||||||
ASSERT_EQ(std::future_status::ready, connected.get_future().wait_for(TIMEOUT));
|
ASSERT_EQ(std::future_status::ready, connected.get_future().wait_for(TIMEOUT));
|
||||||
|
|
||||||
std::string response_text = server.Read(42, 5, 0, 1);
|
JsonDoc doc(server.Read(42, 5, 0, 1));
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(const_cast<char*>(response_text.data()));
|
wfp_json const * response = doc.root();
|
||||||
wfp_json const * response = wfp_impl_json_root(doc);
|
|
||||||
|
|
||||||
ASSERT_TRUE(wfp_impl_json_is_object(response));
|
ASSERT_TRUE(wfp_impl_json_is_object(response));
|
||||||
wfp_json const * result = wfp_impl_json_object_get(response, "result");
|
wfp_json const * result = wfp_impl_json_object_get(response, "result");
|
||||||
@ -305,8 +296,6 @@ TEST(Client, Read)
|
|||||||
wfp_json const * data = wfp_impl_json_object_get(result, "data");
|
wfp_json const * data = wfp_impl_json_object_get(result, "data");
|
||||||
ASSERT_STREQ("Kg==", wfp_impl_json_get_string(data));
|
ASSERT_STREQ("Kg==", wfp_impl_json_get_string(data));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
|
|
||||||
client.Disconnect();
|
client.Disconnect();
|
||||||
ASSERT_EQ(std::future_status::ready, disconnected.get_future().wait_for(TIMEOUT));
|
ASSERT_EQ(std::future_status::ready, disconnected.get_future().wait_for(TIMEOUT));
|
||||||
}
|
}
|
||||||
@ -342,9 +331,8 @@ TEST(Client, ReadDir)
|
|||||||
|
|
||||||
ASSERT_EQ(std::future_status::ready, connected.get_future().wait_for(TIMEOUT));
|
ASSERT_EQ(std::future_status::ready, connected.get_future().wait_for(TIMEOUT));
|
||||||
|
|
||||||
std::string response_text = server.ReadDir(42);
|
JsonDoc doc(server.ReadDir(42));
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(const_cast<char*>(response_text.data()));
|
wfp_json const * response = doc.root();
|
||||||
wfp_json const * response = wfp_impl_json_root(doc);
|
|
||||||
|
|
||||||
ASSERT_TRUE(wfp_impl_json_is_object(response));
|
ASSERT_TRUE(wfp_impl_json_is_object(response));
|
||||||
wfp_json const * result = wfp_impl_json_object_get(response, "result");
|
wfp_json const * result = wfp_impl_json_object_get(response, "result");
|
||||||
@ -352,8 +340,6 @@ TEST(Client, ReadDir)
|
|||||||
ASSERT_TRUE(wfp_impl_json_is_array(result));
|
ASSERT_TRUE(wfp_impl_json_is_array(result));
|
||||||
ASSERT_EQ(3, wfp_impl_json_array_size(result));
|
ASSERT_EQ(3, wfp_impl_json_array_size(result));
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
|
|
||||||
client.Disconnect();
|
client.Disconnect();
|
||||||
ASSERT_EQ(std::future_status::ready, disconnected.get_future().wait_for(TIMEOUT));
|
ASSERT_EQ(std::future_status::ready, disconnected.get_future().wait_for(TIMEOUT));
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include "webfuse_provider/mocks/mock_provider_client.hpp"
|
#include "webfuse_provider/mocks/mock_provider_client.hpp"
|
||||||
#include "webfuse_provider/protocol_names.h"
|
#include "webfuse_provider/protocol_names.h"
|
||||||
#include "webfuse_provider/test_util/timeout_watcher.hpp"
|
#include "webfuse_provider/test_util/timeout_watcher.hpp"
|
||||||
#include "webfuse_provider/impl/json/parser.h"
|
#include "webfuse_provider/test_util/json_doc.hpp"
|
||||||
#include "webfuse_provider/impl/json/node.h"
|
#include "webfuse_provider/impl/json/node.h"
|
||||||
|
|
||||||
#include <libwebsockets.h>
|
#include <libwebsockets.h>
|
||||||
@ -20,6 +20,7 @@ using webfuse_test::WsServer;
|
|||||||
using webfuse_test::MockProviderClient;
|
using webfuse_test::MockProviderClient;
|
||||||
using webfuse_test::IProviderClient;
|
using webfuse_test::IProviderClient;
|
||||||
using webfuse_test::TimeoutWatcher;
|
using webfuse_test::TimeoutWatcher;
|
||||||
|
using webfuse_test::JsonDoc;
|
||||||
using testing::_;
|
using testing::_;
|
||||||
using testing::AtMost;
|
using testing::AtMost;
|
||||||
using testing::Invoke;
|
using testing::Invoke;
|
||||||
@ -102,9 +103,8 @@ public:
|
|||||||
std::string const & expected_username,
|
std::string const & expected_username,
|
||||||
std::string const & expected_password)
|
std::string const & expected_password)
|
||||||
{
|
{
|
||||||
std::string request_text = ReceiveMessageFromClient();
|
JsonDoc doc(ReceiveMessageFromClient());
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(const_cast<char *>(request_text.data()));
|
wfp_json const * request = doc.root();
|
||||||
wfp_json const * request = wfp_impl_json_root(doc);
|
|
||||||
ASSERT_TRUE(wfp_impl_json_is_object(request));
|
ASSERT_TRUE(wfp_impl_json_is_object(request));
|
||||||
|
|
||||||
wfp_json const * method = wfp_impl_json_object_get(request, "method");
|
wfp_json const * method = wfp_impl_json_object_get(request, "method");
|
||||||
@ -136,15 +136,12 @@ public:
|
|||||||
std::ostringstream response;
|
std::ostringstream response;
|
||||||
response << "{\"result\": {}, \"id\": " << wfp_impl_json_get_int(id) << "}";
|
response << "{\"result\": {}, \"id\": " << wfp_impl_json_get_int(id) << "}";
|
||||||
SendToClient(response.str());
|
SendToClient(response.str());
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AwaitAddFilesystem(std::string& filesystemName)
|
void AwaitAddFilesystem(std::string& filesystemName)
|
||||||
{
|
{
|
||||||
std::string request_text = ReceiveMessageFromClient();
|
JsonDoc doc(ReceiveMessageFromClient());
|
||||||
wfp_json_doc * doc = wfp_impl_json_parse(const_cast<char *>(request_text.data()));
|
wfp_json const * request = doc.root();
|
||||||
wfp_json const * request = wfp_impl_json_root(doc);
|
|
||||||
ASSERT_TRUE(wfp_impl_json_is_object(request));
|
ASSERT_TRUE(wfp_impl_json_is_object(request));
|
||||||
|
|
||||||
wfp_json const * method = wfp_impl_json_object_get(request, "method");
|
wfp_json const * method = wfp_impl_json_object_get(request, "method");
|
||||||
@ -165,8 +162,6 @@ public:
|
|||||||
response << "{\"result\": {\"id\": \"" << wfp_impl_json_get_string(filesystem) << "\"}, \"id\": " << wfp_impl_json_get_int(id) << "}";
|
response << "{\"result\": {\"id\": \"" << wfp_impl_json_get_string(filesystem) << "\"}, \"id\": " << wfp_impl_json_get_int(id) << "}";
|
||||||
|
|
||||||
SendToClient(response.str());
|
SendToClient(response.str());
|
||||||
|
|
||||||
wfp_impl_json_dispose(doc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
Loading…
Reference in New Issue
Block a user