Files
flipper/xplat/FlipperTests/FlipperResponderImplTests.cpp
Rain ⁣ aa649ff48f standardize C-like MIT copyright headers throughout fbsource
Summary:
`/*` is the standard throughout open source code. For example, Firefox uses single /*: https://hg.mozilla.org/mozilla-central/file/21d22b2f541258d3d1cf96c7ba5ad73e96e616b5/gfx/ipc/CompositorWidgetVsyncObserver.cpp#l3

In addition, Rust considers `/**` to be a doc comment (similar to Javadoc) and having such a comment at the beginning of the file causes `rustc` to barf.

Note that some JavaScript tooling requires `/**`. This is OK since JavaScript files were not covered by the linter in the first place, but it would be good to have that tooling fixed too.

Reviewed By: zertosh

Differential Revision: D15640366

fbshipit-source-id: b4ed4599071516364d6109720750d6a43304c089
2019-06-06 19:40:28 -07:00

86 lines
2.7 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 <Flipper/FlipperResponderImpl.h>
#include "yarpl/Flowable.h"
#include "yarpl/Single.h"
#include "yarpl/single/SingleTestObserver.h"
#include <folly/json.h>
#include <gtest/gtest.h>
namespace facebook {
namespace flipper {
namespace test {
using folly::dynamic;
void assertIsSuccess(folly::dynamic d);
void assertIsError(folly::dynamic d);
TEST(FlipperResponderImplTest, testSuccessWrapper) {
auto dynamicSingle =
yarpl::single::Single<folly::dynamic>::create([](auto observer) mutable {
observer->onSubscribe(yarpl::single::SingleSubscriptions::empty());
auto responder = std::make_shared<FlipperResponderImpl>(observer);
responder->success(folly::dynamic::object("my", "object"));
});
auto to = yarpl::single::SingleTestObserver<folly::dynamic>::create();
dynamicSingle->subscribe(to);
to->awaitTerminalEvent();
auto output = to->getOnSuccessValue();
assertIsSuccess(output);
EXPECT_EQ(output["success"]["my"], "object");
}
TEST(FlipperResponderImplTest, testErrorWrapper) {
auto dynamicSingle =
yarpl::single::Single<folly::dynamic>::create([](auto observer) mutable {
observer->onSubscribe(yarpl::single::SingleSubscriptions::empty());
auto responder = std::make_shared<FlipperResponderImpl>(observer);
responder->error(folly::dynamic::object("my", "object"));
});
auto to = yarpl::single::SingleTestObserver<folly::dynamic>::create();
dynamicSingle->subscribe(to);
to->awaitTerminalEvent();
auto output = to->getOnSuccessValue();
assertIsError(output);
EXPECT_EQ(output["error"]["my"], "object");
}
TEST(FlipperResponderImplTest, testNoExplicitResponseReturnsSuccess) {
auto to = yarpl::single::SingleTestObserver<folly::dynamic>::create();
{
auto dynamicSingle = yarpl::single::Single<folly::dynamic>::create(
[](auto observer) mutable {
observer->onSubscribe(yarpl::single::SingleSubscriptions::empty());
auto responder = std::make_shared<FlipperResponderImpl>(observer);
});
dynamicSingle->subscribe(to);
}
to->awaitTerminalEvent();
auto output = to->getOnSuccessValue();
assertIsSuccess(output);
EXPECT_TRUE(output["success"].empty());
}
void assertIsSuccess(folly::dynamic d) {
EXPECT_NE(d.find("success"), d.items().end());
EXPECT_EQ(d.find("error"), d.items().end());
}
void assertIsError(folly::dynamic d) {
EXPECT_NE(d.find("error"), d.items().end());
EXPECT_EQ(d.find("success"), d.items().end());
}
} // namespace test
} // namespace flipper
} // namespace facebook