Files
flipper/xplat/FlipperTestLib/FlipperConnectionMock.h
Lorenzo Blasa d1c06c9c46 Do not overload send as this causes issues with folly::dynamic
Summary:
folly::dynamic, std::string, implicit constructors and method overloading is not a good combination.

This renames the send method to sendRaw as to avoid issues with existing plugins currently sending string params.

Reviewed By: mweststrate

Differential Revision: D38827539

fbshipit-source-id: 653f62e41ebfbe93d1af25f39c81f6b05bf84cb4
2022-08-18 09:39:42 -07:00

47 lines
1.2 KiB
C++

/*
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#pragma once
#include <Flipper/FlipperConnection.h>
#include <folly/json.h>
#include <map>
#include <queue>
#include <string>
namespace facebook {
namespace flipper {
class FlipperConnectionMock : public FlipperConnection {
public:
void send(const std::string& method, const folly::dynamic& params) override {
sent_[method] = params;
sent_message_history[method].push(params);
}
void sendRaw(const std::string& method, const std::string& params) override {
sent_[method] = folly::parseJson(params);
sent_message_history[method].push(params);
}
void receive(const std::string& method, const FlipperReceiver& receiver)
override {
receivers_[method] = receiver;
}
void error(const std::string& message, const std::string& stacktrace)
override {}
std::map<std::string, folly::dynamic> sent_;
std::map<std::string, FlipperReceiver> receivers_;
std::map<std::string, std::queue<folly::dynamic>> sent_message_history;
};
} // namespace flipper
} // namespace facebook