mirror of
https://github.com/falk-werner/webfuse
synced 2024-10-27 20:34: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
55 lines
1.4 KiB
C++
55 lines
1.4 KiB
C++
#include <string>
|
|
#include <gtest/gtest.h>
|
|
|
|
#include "webfuse/adapter/impl/jsonrpc/response.h"
|
|
|
|
|
|
static void response_parse_str(
|
|
std::string const & buffer,
|
|
struct wf_impl_jsonrpc_response * response)
|
|
{
|
|
json_t * message = json_loadb(buffer.c_str(), buffer.size(), 0, nullptr);
|
|
if (nullptr != message)
|
|
{
|
|
wf_impl_jsonrpc_response_init(response, message);
|
|
json_decref(message);
|
|
}
|
|
}
|
|
|
|
TEST(response_parser, test)
|
|
{
|
|
struct wf_impl_jsonrpc_response response;
|
|
|
|
// no object
|
|
response_parse_str("[]", &response);
|
|
ASSERT_NE(WF_GOOD, response.status);
|
|
ASSERT_EQ(-1, response.id);
|
|
ASSERT_EQ(nullptr, response.result);
|
|
|
|
// empty
|
|
response_parse_str("{}", &response);
|
|
ASSERT_NE(WF_GOOD, response.status);
|
|
ASSERT_EQ(-1, response.id);
|
|
ASSERT_EQ(nullptr, response.result);
|
|
|
|
// no data
|
|
response_parse_str("{\"id\":42}", &response);
|
|
ASSERT_NE(WF_GOOD, response.status);
|
|
ASSERT_EQ(42, response.id);
|
|
ASSERT_EQ(nullptr, response.result);
|
|
|
|
// custom error code
|
|
response_parse_str("{\"error\":{\"code\": 42}, \"id\": 42}", &response);
|
|
ASSERT_NE(WF_GOOD, response.status);
|
|
ASSERT_EQ(42, response.status);
|
|
ASSERT_EQ(42, response.id);
|
|
ASSERT_EQ(nullptr, response.result);
|
|
|
|
// valid response
|
|
response_parse_str("{\"result\": true, \"id\": 42}", &response);
|
|
ASSERT_EQ(WF_GOOD, response.status);
|
|
ASSERT_EQ(42, response.id);
|
|
ASSERT_NE(nullptr, response.result);
|
|
json_decref(response.result);
|
|
}
|