blob: f76b6960cc19bef8db41349c905c73519d2ed015 [file] [log] [blame]
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chromeos/services/secure_channel/fake_secure_channel_connection.h"
#include <utility>
#include "base/logging.h"
namespace chromeos {
namespace secure_channel {
FakeSecureChannelConnection::SentMessage::SentMessage(
const std::string& feature,
const std::string& payload)
: feature(feature), payload(payload) {}
FakeSecureChannelConnection::FakeSecureChannelConnection(
std::unique_ptr<Connection> connection)
: SecureChannel(std::move(connection)) {}
FakeSecureChannelConnection::~FakeSecureChannelConnection() {
if (destructor_callback_)
std::move(destructor_callback_).Run();
}
void FakeSecureChannelConnection::ChangeStatus(const Status& new_status) {
Status old_status = status_;
status_ = new_status;
// Copy to prevent channel from being removed during handler.
std::vector<Observer*> observers_copy = observers_;
for (auto* observer : observers_copy) {
observer->OnSecureChannelStatusChanged(this, old_status, status_);
}
}
void FakeSecureChannelConnection::ReceiveMessage(const std::string& feature,
const std::string& payload) {
// Copy to prevent channel from being removed during handler.
std::vector<Observer*> observers_copy = observers_;
for (auto* observer : observers_copy)
observer->OnMessageReceived(this, feature, payload);
}
void FakeSecureChannelConnection::CompleteSendingMessage(int sequence_number) {
DCHECK(next_sequence_number_ > sequence_number);
// Copy to prevent channel from being removed during handler.
std::vector<Observer*> observers_copy = observers_;
for (auto* observer : observers_copy)
observer->OnMessageSent(this, sequence_number);
}
void FakeSecureChannelConnection::Initialize() {
was_initialized_ = true;
ChangeStatus(Status::CONNECTING);
}
int FakeSecureChannelConnection::SendMessage(const std::string& feature,
const std::string& payload) {
sent_messages_.push_back(SentMessage(feature, payload));
return next_sequence_number_++;
}
void FakeSecureChannelConnection::Disconnect() {
if (status() == Status::DISCONNECTING || status() == Status::DISCONNECTED)
return;
if (status() == Status::CONNECTING)
ChangeStatus(Status::DISCONNECTED);
else
ChangeStatus(Status::DISCONNECTING);
}
void FakeSecureChannelConnection::AddObserver(Observer* observer) {
observers_.push_back(observer);
}
void FakeSecureChannelConnection::RemoveObserver(Observer* observer) {
observers_.erase(std::find(observers_.begin(), observers_.end(), observer),
observers_.end());
}
void FakeSecureChannelConnection::GetConnectionRssi(
base::OnceCallback<void(base::Optional<int32_t>)> callback) {
std::move(callback).Run(rssi_to_return_);
}
base::Optional<std::string>
FakeSecureChannelConnection::GetChannelBindingData() {
return channel_binding_data_;
}
} // namespace secure_channel
} // namespace chromeos