buffet: Move privetd sources into buffet
No functional changes, only renaming, fixed include paths and include
guards to avoid resubmit warnings.
BUG=brillo:1161
CQ-DEPEND=CL:276521
TEST=none
Change-Id: Icacff92aef47fdd46542bc96eba3ffbb4df6241a
Reviewed-on: https://chromium-review.googlesource.com/276319
Reviewed-by: Vitaly Buka <vitalybuka@chromium.org>
Commit-Queue: Vitaly Buka <vitalybuka@chromium.org>
Tested-by: Vitaly Buka <vitalybuka@chromium.org>
diff --git a/buffet/privet/mock_delegates.h b/buffet/privet/mock_delegates.h
new file mode 100644
index 0000000..ff8c11b
--- /dev/null
+++ b/buffet/privet/mock_delegates.h
@@ -0,0 +1,229 @@
+// Copyright 2014 The Chromium OS Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef BUFFET_PRIVET_MOCK_DELEGATES_H_
+#define BUFFET_PRIVET_MOCK_DELEGATES_H_
+
+#include <set>
+#include <string>
+#include <utility>
+
+#include <base/values.h>
+#include <gmock/gmock.h>
+#include <gtest/gtest.h>
+
+#include "buffet/privet/cloud_delegate.h"
+#include "buffet/privet/device_delegate.h"
+#include "buffet/privet/identity_delegate.h"
+#include "buffet/privet/security_delegate.h"
+#include "buffet/privet/wifi_delegate.h"
+
+using testing::_;
+using testing::Return;
+using testing::ReturnRef;
+using testing::SetArgPointee;
+
+namespace privetd {
+
+ACTION_TEMPLATE(RunCallback,
+ HAS_1_TEMPLATE_PARAMS(int, k),
+ AND_0_VALUE_PARAMS()) {
+ return std::get<k>(args).Run();
+}
+
+ACTION_TEMPLATE(RunCallback,
+ HAS_1_TEMPLATE_PARAMS(int, k),
+ AND_1_VALUE_PARAMS(p0)) {
+ return std::get<k>(args).Run(p0);
+}
+
+class MockDeviceDelegate : public DeviceDelegate {
+ using IntPair = std::pair<uint16_t, uint16_t>;
+
+ public:
+ MOCK_CONST_METHOD0(GetHttpEnpoint, IntPair());
+ MOCK_CONST_METHOD0(GetHttpsEnpoint, IntPair());
+ MOCK_CONST_METHOD0(GetUptime, base::TimeDelta());
+ MOCK_METHOD1(SetHttpPort, void(uint16_t));
+ MOCK_METHOD1(SetHttpsPort, void(uint16_t));
+
+ MockDeviceDelegate() {
+ EXPECT_CALL(*this, GetHttpEnpoint())
+ .WillRepeatedly(Return(std::make_pair(0, 0)));
+ EXPECT_CALL(*this, GetHttpsEnpoint())
+ .WillRepeatedly(Return(std::make_pair(0, 0)));
+ EXPECT_CALL(*this, GetUptime())
+ .WillRepeatedly(Return(base::TimeDelta::FromHours(1)));
+ }
+};
+
+class MockSecurityDelegate : public SecurityDelegate {
+ public:
+ MOCK_METHOD2(CreateAccessToken,
+ std::string(const UserInfo&, const base::Time&));
+ MOCK_CONST_METHOD2(ParseAccessToken,
+ UserInfo(const std::string&, base::Time*));
+ MOCK_CONST_METHOD0(GetPairingTypes, std::set<PairingType>());
+ MOCK_CONST_METHOD0(GetCryptoTypes, std::set<CryptoType>());
+ MOCK_CONST_METHOD1(IsValidPairingCode, bool(const std::string&));
+ MOCK_METHOD5(StartPairing,
+ bool(PairingType,
+ CryptoType,
+ std::string*,
+ std::string*,
+ chromeos::ErrorPtr*));
+ MOCK_METHOD5(ConfirmPairing,
+ bool(const std::string&,
+ const std::string&,
+ std::string*,
+ std::string*,
+ chromeos::ErrorPtr*));
+ MOCK_METHOD2(CancelPairing, bool(const std::string&, chromeos::ErrorPtr*));
+
+ MockSecurityDelegate() {
+ EXPECT_CALL(*this, CreateAccessToken(_, _))
+ .WillRepeatedly(Return("GuestAccessToken"));
+
+ EXPECT_CALL(*this, ParseAccessToken(_, _))
+ .WillRepeatedly(DoAll(SetArgPointee<1>(base::Time::Now()),
+ Return(UserInfo{AuthScope::kViewer, 1234567})));
+
+ EXPECT_CALL(*this, GetPairingTypes())
+ .WillRepeatedly(Return(std::set<PairingType>{
+ PairingType::kPinCode,
+ PairingType::kEmbeddedCode,
+ PairingType::kUltrasound32,
+ PairingType::kAudible32,
+ }));
+
+ EXPECT_CALL(*this, GetCryptoTypes())
+ .WillRepeatedly(Return(std::set<CryptoType>{
+ CryptoType::kSpake_p224, CryptoType::kSpake_p256,
+ }));
+
+ EXPECT_CALL(*this, StartPairing(_, _, _, _, _))
+ .WillRepeatedly(DoAll(SetArgPointee<2>("testSession"),
+ SetArgPointee<3>("testCommitment"),
+ Return(true)));
+
+ EXPECT_CALL(*this, ConfirmPairing(_, _, _, _, _))
+ .WillRepeatedly(DoAll(SetArgPointee<2>("testFingerprint"),
+ SetArgPointee<3>("testSignature"), Return(true)));
+ EXPECT_CALL(*this, CancelPairing(_, _)).WillRepeatedly(Return(true));
+ }
+};
+
+class MockWifiDelegate : public WifiDelegate {
+ public:
+ MOCK_CONST_METHOD0(GetConnectionState, const ConnectionState&());
+ MOCK_CONST_METHOD0(GetSetupState, const SetupState&());
+ MOCK_METHOD3(ConfigureCredentials,
+ bool(const std::string&,
+ const std::string&,
+ chromeos::ErrorPtr*));
+ MOCK_CONST_METHOD0(GetCurrentlyConnectedSsid, std::string());
+ MOCK_CONST_METHOD0(GetHostedSsid, std::string());
+ MOCK_CONST_METHOD0(GetTypes, std::set<WifiType>());
+
+ MockWifiDelegate() {
+ EXPECT_CALL(*this, GetConnectionState())
+ .WillRepeatedly(ReturnRef(connection_state_));
+ EXPECT_CALL(*this, GetSetupState()).WillRepeatedly(ReturnRef(setup_state_));
+ EXPECT_CALL(*this, GetCurrentlyConnectedSsid())
+ .WillRepeatedly(Return("TestSsid"));
+ EXPECT_CALL(*this, GetHostedSsid()).WillRepeatedly(Return(""));
+ EXPECT_CALL(*this, GetTypes())
+ .WillRepeatedly(Return(std::set<WifiType>{WifiType::kWifi24}));
+ }
+
+ ConnectionState connection_state_{ConnectionState::kOffline};
+ SetupState setup_state_{SetupState::kNone};
+};
+
+class MockCloudDelegate : public CloudDelegate {
+ public:
+ MOCK_CONST_METHOD2(GetModelId, bool(std::string*, chromeos::ErrorPtr*));
+ MOCK_CONST_METHOD2(GetName, bool(std::string*, chromeos::ErrorPtr*));
+ MOCK_CONST_METHOD0(GetDescription, std::string());
+ MOCK_CONST_METHOD0(GetLocation, std::string());
+ MOCK_METHOD5(UpdateDeviceInfo,
+ void(const std::string&,
+ const std::string&,
+ const std::string&,
+ const base::Closure&,
+ const ErrorCallback&));
+ MOCK_CONST_METHOD0(GetOemName, std::string());
+ MOCK_CONST_METHOD0(GetModelName, std::string());
+ MOCK_CONST_METHOD0(GetServices, std::set<std::string>());
+ MOCK_CONST_METHOD0(GetAnonymousMaxScope, AuthScope());
+ MOCK_CONST_METHOD0(GetConnectionState, const ConnectionState&());
+ MOCK_CONST_METHOD0(GetSetupState, const SetupState&());
+ MOCK_METHOD3(Setup,
+ bool(const std::string&,
+ const std::string&,
+ chromeos::ErrorPtr*));
+ MOCK_CONST_METHOD0(GetCloudId, std::string());
+ MOCK_CONST_METHOD0(GetState, const base::DictionaryValue&());
+ MOCK_CONST_METHOD0(GetCommandDef, const base::DictionaryValue&());
+ MOCK_METHOD4(AddCommand,
+ void(const base::DictionaryValue&,
+ const UserInfo&,
+ const SuccessCallback&,
+ const ErrorCallback&));
+ MOCK_METHOD4(GetCommand,
+ void(const std::string&,
+ const UserInfo&,
+ const SuccessCallback&,
+ const ErrorCallback&));
+ MOCK_METHOD4(CancelCommand,
+ void(const std::string&,
+ const UserInfo&,
+ const SuccessCallback&,
+ const ErrorCallback&));
+ MOCK_METHOD3(ListCommands,
+ void(const UserInfo&,
+ const SuccessCallback&,
+ const ErrorCallback&));
+
+ MockCloudDelegate() {
+ EXPECT_CALL(*this, GetModelId(_, _))
+ .WillRepeatedly(DoAll(SetArgPointee<0>("ABMID"), Return(true)));
+ EXPECT_CALL(*this, GetName(_, _))
+ .WillRepeatedly(DoAll(SetArgPointee<0>("TestDevice"), Return(true)));
+ EXPECT_CALL(*this, GetDescription()).WillRepeatedly(Return(""));
+ EXPECT_CALL(*this, GetLocation()).WillRepeatedly(Return(""));
+ EXPECT_CALL(*this, UpdateDeviceInfo(_, _, _, _, _))
+ .WillRepeatedly(RunCallback<3>());
+ EXPECT_CALL(*this, GetOemName()).WillRepeatedly(Return("Chromium"));
+ EXPECT_CALL(*this, GetModelName()).WillRepeatedly(Return("Brillo"));
+ EXPECT_CALL(*this, GetServices())
+ .WillRepeatedly(Return(std::set<std::string>{}));
+ EXPECT_CALL(*this, GetAnonymousMaxScope())
+ .WillRepeatedly(Return(AuthScope::kUser));
+ EXPECT_CALL(*this, GetConnectionState())
+ .WillRepeatedly(ReturnRef(connection_state_));
+ EXPECT_CALL(*this, GetSetupState()).WillRepeatedly(ReturnRef(setup_state_));
+ EXPECT_CALL(*this, GetCloudId()).WillRepeatedly(Return("TestCloudId"));
+ test_dict_.Set("test", new base::DictionaryValue);
+ EXPECT_CALL(*this, GetCommandDef()).WillRepeatedly(ReturnRef(test_dict_));
+ EXPECT_CALL(*this, GetState()).WillRepeatedly(ReturnRef(test_dict_));
+ }
+
+ ConnectionState connection_state_{ConnectionState::kOnline};
+ SetupState setup_state_{SetupState::kNone};
+ base::DictionaryValue test_dict_;
+};
+
+class MockIdentityDelegate : public IdentityDelegate {
+ public:
+ MOCK_CONST_METHOD0(GetId, std::string());
+
+ MockIdentityDelegate() {
+ EXPECT_CALL(*this, GetId()).WillRepeatedly(Return("TestId"));
+ }
+};
+
+} // namespace privetd
+
+#endif // BUFFET_PRIVET_MOCK_DELEGATES_H_