| Index: net/http/des_unittest.cc
|
| ===================================================================
|
| --- net/http/des_unittest.cc (revision 0)
|
| +++ net/http/des_unittest.cc (revision 0)
|
| @@ -0,0 +1,50 @@
|
| +// Copyright (c) 2009 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.h>
|
| +
|
| +#include "net/http/des.h"
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +
|
| +namespace net {
|
| +
|
| +// This test vector comes from the NSS FIPS power-up self-test.
|
| +TEST(DESTest, KnownAnswerTest1) {
|
| + // DES known key (56-bits).
|
| + static const uint8 des_known_key[] = { "ANSI DES" };
|
| +
|
| + // DES known plaintext (64-bits).
|
| + static const uint8 des_ecb_known_plaintext[] = { "Netscape" };
|
| +
|
| + // DES known ciphertext (64-bits).
|
| + static const uint8 des_ecb_known_ciphertext[] = {
|
| + 0x26, 0x14, 0xe9, 0xc3, 0x28, 0x80, 0x50, 0xb0
|
| + };
|
| +
|
| + uint8 ciphertext[8];
|
| + memset(ciphertext, 0xaf, sizeof(ciphertext));
|
| +
|
| + DESEncrypt(des_known_key, des_ecb_known_plaintext, ciphertext);
|
| + EXPECT_EQ(0, memcmp(ciphertext, des_ecb_known_ciphertext, 8));
|
| +}
|
| +
|
| +// This test vector comes from NIST Special Publication 800-17, Modes of
|
| +// Operation Validation System (MOVS): Requirements and Procedures, Appendix
|
| +// A, page 124.
|
| +TEST(DESTest, KnownAnswerTest2) {
|
| + static const uint8 key[] = {
|
| + 0x10, 0x31, 0x6e, 0x02, 0x8c, 0x8f, 0x3b, 0x4a
|
| + };
|
| + static const uint8 plaintext[] = { 0, 0, 0, 0, 0, 0, 0, 0 };
|
| + static const uint8 known_ciphertext[] = {
|
| + 0x82, 0xdc, 0xba, 0xfb, 0xde, 0xab, 0x66, 0x02
|
| + };
|
| + uint8 ciphertext[8];
|
| + memset(ciphertext, 0xaf, sizeof(ciphertext));
|
| +
|
| + DESEncrypt(key, plaintext, ciphertext);
|
| + EXPECT_EQ(0, memcmp(ciphertext, known_ciphertext, 8));
|
| +}
|
| +
|
| +} // namespace net
|
|
|
| Property changes on: net\http\des_unittest.cc
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|