mirror of
https://github.com/status-im/react-native.git
synced 2025-01-14 19:44:13 +00:00
1151c096da
Summary: This change drops the year from the copyright headers and the LICENSE file. Reviewed By: yungsters Differential Revision: D9727774 fbshipit-source-id: df4fc1e4390733fe774b1a160dd41b4a3d83302a
156 lines
5.4 KiB
C++
156 lines
5.4 KiB
C++
// Copyright (c) Facebook, Inc. and its affiliates.
|
|
|
|
// This source code is licensed under the MIT license found in the
|
|
// LICENSE file in the root directory of this source tree.
|
|
|
|
#include <cxxreact/MethodCall.h>
|
|
|
|
#include <folly/json.h>
|
|
#pragma GCC diagnostic push
|
|
#pragma GCC diagnostic ignored "-Wsign-compare"
|
|
#include <gtest/gtest.h>
|
|
#pragma GCC diagnostic pop
|
|
|
|
using namespace facebook;
|
|
using namespace facebook::react;
|
|
using namespace folly;
|
|
|
|
TEST(parseMethodCalls, SingleReturnCallNoArgs) {
|
|
auto jsText = "[[7],[3],[[]]]";
|
|
auto returnedCalls = parseMethodCalls(folly::parseJson(jsText));
|
|
ASSERT_EQ(1, returnedCalls.size());
|
|
auto returnedCall = returnedCalls[0];
|
|
ASSERT_EQ(0, returnedCall.arguments.size());
|
|
ASSERT_EQ(7, returnedCall.moduleId);
|
|
ASSERT_EQ(3, returnedCall.methodId);
|
|
}
|
|
|
|
TEST(parseMethodCalls, InvalidReturnFormat) {
|
|
try {
|
|
auto input = dynamic::object("foo", 1);
|
|
parseMethodCalls(std::move(input));
|
|
ADD_FAILURE();
|
|
} catch (const std::invalid_argument&) {
|
|
// ignored
|
|
}
|
|
try {
|
|
auto input = dynamic::array(dynamic::object("foo", 1));
|
|
parseMethodCalls(std::move(input));
|
|
ADD_FAILURE();
|
|
} catch (const std::invalid_argument&) {
|
|
// ignored
|
|
}
|
|
try {
|
|
auto input = dynamic::array(1, 4, dynamic::object("foo", 2));
|
|
parseMethodCalls(std::move(input));
|
|
ADD_FAILURE();
|
|
} catch (const std::invalid_argument&) {
|
|
// ignored
|
|
}
|
|
try {
|
|
auto input = dynamic::array(dynamic::array(1),
|
|
dynamic::array(4),
|
|
dynamic::object("foo", 2));
|
|
parseMethodCalls(std::move(input));
|
|
ADD_FAILURE();
|
|
} catch (const std::invalid_argument&) {
|
|
// ignored
|
|
}
|
|
try {
|
|
auto input = dynamic::array(dynamic::array(1),
|
|
dynamic::array(4),
|
|
dynamic::array());
|
|
parseMethodCalls(std::move(input));
|
|
ADD_FAILURE();
|
|
} catch (const std::invalid_argument&) {
|
|
// ignored
|
|
}
|
|
}
|
|
|
|
TEST(parseMethodCalls, NumberReturn) {
|
|
auto jsText = "[[0],[0],[[\"foobar\"]]]";
|
|
auto returnedCalls = parseMethodCalls(folly::parseJson(jsText));
|
|
ASSERT_EQ(1, returnedCalls.size());
|
|
auto returnedCall = returnedCalls[0];
|
|
ASSERT_EQ(1, returnedCall.arguments.size());
|
|
ASSERT_EQ(folly::dynamic::STRING, returnedCall.arguments[0].type());
|
|
ASSERT_EQ("foobar", returnedCall.arguments[0].asString());
|
|
}
|
|
|
|
TEST(parseMethodCalls, StringReturn) {
|
|
auto jsText = "[[0],[0],[[42.16]]]";
|
|
auto returnedCalls = parseMethodCalls(folly::parseJson(jsText));
|
|
ASSERT_EQ(1, returnedCalls.size());
|
|
auto returnedCall = returnedCalls[0];
|
|
ASSERT_EQ(1, returnedCall.arguments.size());
|
|
ASSERT_EQ(folly::dynamic::DOUBLE, returnedCall.arguments[0].type());
|
|
ASSERT_EQ(42.16, returnedCall.arguments[0].asDouble());
|
|
}
|
|
|
|
TEST(parseMethodCalls, BooleanReturn) {
|
|
auto jsText = "[[0],[0],[[false]]]";
|
|
auto returnedCalls = parseMethodCalls(folly::parseJson(jsText));
|
|
ASSERT_EQ(1, returnedCalls.size());
|
|
auto returnedCall = returnedCalls[0];
|
|
ASSERT_EQ(1, returnedCall.arguments.size());
|
|
ASSERT_EQ(folly::dynamic::BOOL, returnedCall.arguments[0].type());
|
|
ASSERT_FALSE(returnedCall.arguments[0].asBool());
|
|
}
|
|
|
|
TEST(parseMethodCalls, NullReturn) {
|
|
auto jsText = "[[0],[0],[[null]]]";
|
|
auto returnedCalls = parseMethodCalls(folly::parseJson(jsText));
|
|
ASSERT_EQ(1, returnedCalls.size());
|
|
auto returnedCall = returnedCalls[0];
|
|
ASSERT_EQ(1, returnedCall.arguments.size());
|
|
ASSERT_EQ(folly::dynamic::NULLT, returnedCall.arguments[0].type());
|
|
}
|
|
|
|
TEST(parseMethodCalls, MapReturn) {
|
|
auto jsText = "[[0],[0],[[{\"foo\": \"hello\", \"bar\": 4.0, \"baz\": true}]]]";
|
|
auto returnedCalls = parseMethodCalls(folly::parseJson(jsText));
|
|
ASSERT_EQ(1, returnedCalls.size());
|
|
auto returnedCall = returnedCalls[0];
|
|
ASSERT_EQ(1, returnedCall.arguments.size());
|
|
ASSERT_EQ(folly::dynamic::OBJECT, returnedCall.arguments[0].type());
|
|
auto& returnedMap = returnedCall.arguments[0];
|
|
auto foo = returnedMap.at("foo");
|
|
EXPECT_EQ(folly::dynamic("hello"), foo);
|
|
auto bar = returnedMap.at("bar");
|
|
EXPECT_EQ(folly::dynamic(4.0), bar);
|
|
auto baz = returnedMap.at("baz");
|
|
EXPECT_EQ(folly::dynamic(true), baz);
|
|
}
|
|
|
|
TEST(parseMethodCalls, ArrayReturn) {
|
|
auto jsText = "[[0],[0],[[[\"foo\", 42.0, false]]]]";
|
|
auto returnedCalls = parseMethodCalls(folly::parseJson(jsText));
|
|
ASSERT_EQ(1, returnedCalls.size());
|
|
auto returnedCall = returnedCalls[0];
|
|
ASSERT_EQ(1, returnedCall.arguments.size());
|
|
ASSERT_EQ(folly::dynamic::ARRAY, returnedCall.arguments[0].type());
|
|
auto& returnedArray = returnedCall.arguments[0];
|
|
ASSERT_EQ(3, returnedArray.size());
|
|
ASSERT_EQ(folly::dynamic("foo"), returnedArray[0]);
|
|
ASSERT_EQ(folly::dynamic(42.0), returnedArray[1]);
|
|
ASSERT_EQ(folly::dynamic(false), returnedArray[2]);
|
|
}
|
|
|
|
TEST(parseMethodCalls, ReturnMultipleParams) {
|
|
auto jsText = "[[0],[0],[[\"foo\", 14, null, false]]]";
|
|
auto returnedCalls = parseMethodCalls(folly::parseJson(jsText));
|
|
ASSERT_EQ(1, returnedCalls.size());
|
|
auto returnedCall = returnedCalls[0];
|
|
ASSERT_EQ(4, returnedCall.arguments.size());
|
|
ASSERT_EQ(folly::dynamic::STRING, returnedCall.arguments[0].type());
|
|
ASSERT_EQ(folly::dynamic::INT64, returnedCall.arguments[1].type());
|
|
ASSERT_EQ(folly::dynamic::NULLT, returnedCall.arguments[2].type());
|
|
ASSERT_EQ(folly::dynamic::BOOL, returnedCall.arguments[3].type());
|
|
}
|
|
|
|
TEST(parseMethodCalls, ParseTwoCalls) {
|
|
auto jsText = "[[0,0],[1,1],[[],[]]]";
|
|
auto returnedCalls = parseMethodCalls(folly::parseJson(jsText));
|
|
ASSERT_EQ(2, returnedCalls.size());
|
|
}
|