feat: modules moved and engine moved to submodule
This commit is contained in:
parent
dfb5e645cd
commit
c33d2130cc
5136 changed files with 225275 additions and 64485 deletions
|
|
@ -57,10 +57,6 @@ String TestClassJSONRPC::something(const String &p_in) {
|
|||
return p_in + ", please";
|
||||
}
|
||||
|
||||
void TestClassJSONRPC::_bind_methods() {
|
||||
ClassDB::bind_method(D_METHOD("something", "in"), &TestClassJSONRPC::something);
|
||||
}
|
||||
|
||||
void test_process_action(const Variant &p_in, const Variant &p_expected, bool p_process_array_elements) {
|
||||
TestClassJSONRPC json_rpc = TestClassJSONRPC();
|
||||
const Variant &observed = json_rpc.process_action(p_in, p_process_array_elements);
|
||||
|
|
@ -83,4 +79,10 @@ void test_process_action_bad_method(const Dictionary &p_in) {
|
|||
check_error_no_method(out_dict);
|
||||
}
|
||||
|
||||
void test_no_response(const Variant &p_in) {
|
||||
TestClassJSONRPC json_rpc = TestClassJSONRPC();
|
||||
const Variant &res = json_rpc.process_action(p_in, true);
|
||||
CHECK(res.get_type() == Variant::NIL);
|
||||
}
|
||||
|
||||
} // namespace TestJSONRPC
|
||||
|
|
|
|||
|
|
@ -28,8 +28,7 @@
|
|||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
/**************************************************************************/
|
||||
|
||||
#ifndef TEST_JSONRPC_H
|
||||
#define TEST_JSONRPC_H
|
||||
#pragma once
|
||||
|
||||
#include "tests/test_macros.h"
|
||||
#include "tests/test_utils.h"
|
||||
|
|
@ -47,6 +46,7 @@ TEST_CASE("[JSONRPC] process_action invalid") {
|
|||
check_invalid(json_rpc.process_action(1234));
|
||||
check_invalid(json_rpc.process_action(false));
|
||||
check_invalid(json_rpc.process_action(3.14159));
|
||||
check_invalid(json_rpc.process_action(Array()));
|
||||
}
|
||||
|
||||
void check_invalid_string(const String &p_str);
|
||||
|
|
@ -58,23 +58,21 @@ TEST_CASE("[JSONRPC] process_string invalid") {
|
|||
check_invalid_string(json_rpc.process_string("1234"));
|
||||
check_invalid_string(json_rpc.process_string("false"));
|
||||
check_invalid_string(json_rpc.process_string("3.14159"));
|
||||
check_invalid_string(json_rpc.process_string("[]"));
|
||||
}
|
||||
|
||||
class TestClassJSONRPC : public JSONRPC {
|
||||
GDCLASS(TestClassJSONRPC, JSONRPC)
|
||||
|
||||
public:
|
||||
String something(const String &p_in);
|
||||
TestClassJSONRPC() {
|
||||
set_method("something", callable_mp(this, &TestClassJSONRPC::something));
|
||||
}
|
||||
|
||||
protected:
|
||||
static void _bind_methods();
|
||||
String something(const String &p_in);
|
||||
};
|
||||
|
||||
void test_process_action(const Variant &p_in, const Variant &p_expected, bool p_process_array_elements = false);
|
||||
|
||||
TEST_CASE("[JSONRPC] process_action Dictionary") {
|
||||
ClassDB::register_class<TestClassJSONRPC>();
|
||||
|
||||
Dictionary in_dict = Dictionary();
|
||||
in_dict["method"] = "something";
|
||||
in_dict["id"] = "ID";
|
||||
|
|
@ -129,11 +127,73 @@ void test_process_action_bad_method(const Dictionary &p_in);
|
|||
|
||||
TEST_CASE("[JSONRPC] process_action bad method") {
|
||||
Dictionary in_dict;
|
||||
in_dict["id"] = 1;
|
||||
in_dict["method"] = "nothing";
|
||||
|
||||
test_process_action_bad_method(in_dict);
|
||||
}
|
||||
|
||||
} // namespace TestJSONRPC
|
||||
void test_no_response(const Variant &p_in);
|
||||
|
||||
#endif // TEST_JSONRPC_H
|
||||
TEST_CASE("[JSONRPC] process_action notification") {
|
||||
Dictionary in_dict = Dictionary();
|
||||
in_dict["method"] = "something";
|
||||
in_dict["params"] = "yes";
|
||||
|
||||
test_no_response(in_dict);
|
||||
}
|
||||
|
||||
TEST_CASE("[JSONRPC] process_action notification bad method") {
|
||||
Dictionary in_dict;
|
||||
in_dict["method"] = "nothing";
|
||||
|
||||
test_no_response(in_dict);
|
||||
}
|
||||
|
||||
TEST_CASE("[JSONRPC] process_action notification batch") {
|
||||
Array in;
|
||||
Dictionary in_1;
|
||||
in_1["method"] = "something";
|
||||
in_1["params"] = "more";
|
||||
in.push_back(in_1);
|
||||
Dictionary in_2;
|
||||
in_2["method"] = "something";
|
||||
in_2["params"] = "yes";
|
||||
in.push_back(in_2);
|
||||
|
||||
test_no_response(in);
|
||||
}
|
||||
|
||||
TEST_CASE("[JSONRPC] mixed batch") {
|
||||
Array in;
|
||||
Dictionary in_1;
|
||||
in_1["method"] = "something";
|
||||
in_1["id"] = 1;
|
||||
in_1["params"] = "more";
|
||||
in.push_back(in_1);
|
||||
Dictionary in_2;
|
||||
in_2["method"] = "something";
|
||||
in_2["id"] = 2;
|
||||
in_2["params"] = "yes";
|
||||
in.push_back(in_2);
|
||||
Dictionary in_3;
|
||||
in_3["method"] = "something";
|
||||
in_3["params"] = "yes";
|
||||
in.push_back(in_3);
|
||||
|
||||
Array expected;
|
||||
Dictionary expected_1;
|
||||
expected_1["jsonrpc"] = "2.0";
|
||||
expected_1["id"] = 1;
|
||||
expected_1["result"] = "more, please";
|
||||
expected.push_back(expected_1);
|
||||
Dictionary expected_2;
|
||||
expected_2["jsonrpc"] = "2.0";
|
||||
expected_2["id"] = 2;
|
||||
expected_2["result"] = "yes, please";
|
||||
expected.push_back(expected_2);
|
||||
|
||||
test_process_action(in, expected, true);
|
||||
}
|
||||
|
||||
} // namespace TestJSONRPC
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue