mirror of
https://github.com/falk-werner/webfuse-provider
synced 2024-10-27 20:44:10 +00:00
07e32757f8
* removes unnecessary code * adds test of wf_status * adds tests of wf_message * adds tests of wf_message_queue * changed branch of coverage badge to display correct results * moves core tests into separate subdirectory * increases coverage of timer test * moves adapter specific tests into separate directory * moves provider specific tests into separate directory * adds tests of jsonrpc utilities * adds tests of jsonrpc request * adds test of jsonrpc response * adds tests of jsonrpc server * adds tests of jsonrpc proxy * adds integration test (found some issues) * disables problematic tests * fixes resource leak: pending timer after cleanup proxy * fixes order of cleanup to prevent processing pending requests after filesystem shut down * fixes some memcheck and helgrind errors: initialization of lws_log; setup of client and server * disabled a test * fixes error in msleep utility * fixes deadlock at IntegrationTest using valgrind * removes unit test code from coverage report * adds some integration tests * makes badge show coverage of master * fixes some coding style issues * fixes eary trigger of is_connected (provider) * fixes read error in 32 bit environments\n\ninode is always 64 bit, but variadic wf_impl_jsonrpc_proxy_invoke expects int
57 lines
1.7 KiB
C++
57 lines
1.7 KiB
C++
#include <gtest/gtest.h>
|
|
#include "webfuse/adapter/impl/jsonrpc/response.h"
|
|
|
|
TEST(json_response, init_result)
|
|
{
|
|
json_t * message = json_object();
|
|
json_object_set_new(message, "result", json_integer(47));
|
|
json_object_set_new(message, "id", json_integer(11));
|
|
|
|
struct wf_impl_jsonrpc_response response;
|
|
wf_impl_jsonrpc_response_init(&response, message);
|
|
|
|
ASSERT_EQ(WF_GOOD, response.status);
|
|
ASSERT_TRUE(json_is_integer(response.result));
|
|
ASSERT_EQ(47, json_integer_value(response.result));
|
|
ASSERT_EQ(11, response.id);
|
|
|
|
wf_impl_jsonrpc_response_cleanup(&response);
|
|
json_decref(message);
|
|
}
|
|
|
|
TEST(json_response, init_error)
|
|
{
|
|
json_t * message = json_object();
|
|
json_t * err = json_object();
|
|
json_object_set_new(err, "code", json_integer(WF_BAD_ACCESS_DENIED));
|
|
json_object_set_new(err, "message", json_string("access denied"));
|
|
json_object_set_new(message, "error", err);
|
|
json_object_set_new(message, "id", json_integer(23));
|
|
|
|
struct wf_impl_jsonrpc_response response;
|
|
wf_impl_jsonrpc_response_init(&response, message);
|
|
|
|
ASSERT_EQ(WF_BAD_ACCESS_DENIED, response.status);
|
|
ASSERT_EQ(nullptr, response.result);
|
|
ASSERT_EQ(23, response.id);
|
|
|
|
wf_impl_jsonrpc_response_cleanup(&response);
|
|
json_decref(message);
|
|
}
|
|
|
|
TEST(json_response, init_format_error)
|
|
{
|
|
json_t * message = json_object();
|
|
json_object_set_new(message, "id", json_integer(12));
|
|
|
|
struct wf_impl_jsonrpc_response response;
|
|
wf_impl_jsonrpc_response_init(&response, message);
|
|
|
|
ASSERT_EQ(WF_BAD_FORMAT, response.status);
|
|
ASSERT_EQ(nullptr, response.result);
|
|
ASSERT_EQ(12, response.id);
|
|
|
|
wf_impl_jsonrpc_response_cleanup(&response);
|
|
json_decref(message);
|
|
}
|