diff options
author | sergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-08-04 23:04:05 +0000 |
---|---|---|
committer | sergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-08-04 23:04:05 +0000 |
commit | cdf8c57cbf1d997346e650fb5d0b301f7abc4dd4 (patch) | |
tree | 81a7bfd30b29dfaea9cd2644daf06f39d11b17a0 /remoting/host/host_key_pair_unittest.cc | |
parent | c0035fff490b71ff952b97b6a3d22b1041689979 (diff) | |
download | chromium_src-cdf8c57cbf1d997346e650fb5d0b301f7abc4dd4.zip chromium_src-cdf8c57cbf1d997346e650fb5d0b301f7abc4dd4.tar.gz chromium_src-cdf8c57cbf1d997346e650fb5d0b301f7abc4dd4.tar.bz2 |
Added HostKeyPair class, signatures for heartbeat messages.
BUG=None
TEST=unittests
Review URL: http://codereview.chromium.org/3087003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@54991 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'remoting/host/host_key_pair_unittest.cc')
-rw-r--r-- | remoting/host/host_key_pair_unittest.cc | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/remoting/host/host_key_pair_unittest.cc b/remoting/host/host_key_pair_unittest.cc new file mode 100644 index 0000000..e5af756 --- /dev/null +++ b/remoting/host/host_key_pair_unittest.cc @@ -0,0 +1,71 @@ +// Copyright (c) 2010 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 <string> + +#include "base/base64.h" +#include "base/message_loop.h" +#include "base/message_loop_proxy.h" +#include "base/ref_counted.h" +#include "base/scoped_temp_dir.h" +#include "base/string_util.h" +#include "remoting/host/host_key_pair.h" +#include "remoting/host/json_host_config.h" +#include "remoting/host/test_key_pair.h" +#include "testing/gmock/include/gmock/gmock.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace remoting { + +namespace { +const char kTestMessage[] = "Test Message"; + +// |kTestMessage| signed with the key from |kTestHostKeyPair|. +const char kExpectedSignature[] = +"LfUyXU2AiKM4rpWivUR3bLiQiRt1W3iIenNfJEB8RWyoEfnvSBoD52x8q9yFvtLFDEMPWyIrwM+N2" +"LuaWBKG1c0R7h+twBgvpExzZneJl+lbGMRx9ba8m/KAFrUWA/NRzOen2NHCuPybOEasgrPgGWBrmf" +"gDcvyW8QiGuKLopGj/4c5CQT4yE8JjsyU3Qqo2ZPK4neJYQhOmAlg+Q5dAPLpzWMj5HQyOVHJaSXZ" +"Y8vl/LiKvbdofYLeYNVKAE4q5mfpQMrsysPYpbxBV60AhFyrvtC040MFGcflKQRZNiZwMXVb7DclC" +"BPgvK7rI5Y0ERtVm+yNmH7vCivfyAnDUYA=="; +} + + +class HostKeyPairTest : public testing::Test { + protected: + virtual void SetUp() { + ASSERT_TRUE(test_dir_.CreateUniqueTempDir()); + FilePath config_path = test_dir_.path().AppendASCII("test_config.json"); + config_ = new JsonHostConfig( + config_path, base::MessageLoopProxy::CreateForCurrentThread()); + } + + MessageLoop message_loop_; + ScopedTempDir test_dir_; + scoped_refptr<JsonHostConfig> config_; +}; + +TEST_F(HostKeyPairTest, SaveLoad) { + // Save a key to a config, then load it back, and verify that we + // generate the same signature with both keys. + HostKeyPair exported_key; + exported_key.LoadFromString(kTestHostKeyPair); + exported_key.Save(config_); + + HostKeyPair imported_key; + imported_key.Load(config_); + + ASSERT_EQ(exported_key.GetSignature(kTestMessage), + imported_key.GetSignature(kTestMessage)); +} + +TEST_F(HostKeyPairTest, Signatures) { + // Sign a message and check that we get expected signature. + HostKeyPair key_pair; + key_pair.LoadFromString(kTestHostKeyPair); + + std::string signature_base64 = key_pair.GetSignature(kTestMessage); + ASSERT_EQ(signature_base64, std::string(kExpectedSignature)); +} + +} // namespace remoting |