1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "net/ssl/ssl_cipher_suite_names.h"
7 #include "base/basictypes.h"
8 #include "testing/gtest/include/gtest/gtest.h"
14 TEST(CipherSuiteNamesTest
, Basic
) {
15 const char *key_exchange
, *cipher
, *mac
;
18 SSLCipherSuiteToStrings(&key_exchange
, &cipher
, &mac
, &is_aead
, 0xc001);
19 EXPECT_STREQ("ECDH_ECDSA", key_exchange
);
20 EXPECT_STREQ("NULL", cipher
);
21 EXPECT_STREQ("SHA1", mac
);
22 EXPECT_FALSE(is_aead
);
24 SSLCipherSuiteToStrings(&key_exchange
, &cipher
, &mac
, &is_aead
, 0x009f);
25 EXPECT_STREQ("DHE_RSA", key_exchange
);
26 EXPECT_STREQ("AES_256_GCM", cipher
);
30 SSLCipherSuiteToStrings(&key_exchange
, &cipher
, &mac
, &is_aead
, 0xff31);
31 EXPECT_STREQ("???", key_exchange
);
32 EXPECT_STREQ("???", cipher
);
33 EXPECT_STREQ("???", mac
);
34 EXPECT_FALSE(is_aead
);
37 TEST(CipherSuiteNamesTest
, ParseSSLCipherString
) {
38 uint16 cipher_suite
= 0;
39 EXPECT_TRUE(ParseSSLCipherString("0x0004", &cipher_suite
));
40 EXPECT_EQ(0x00004u
, cipher_suite
);
42 EXPECT_TRUE(ParseSSLCipherString("0xBEEF", &cipher_suite
));
43 EXPECT_EQ(0xBEEFu
, cipher_suite
);
46 TEST(CipherSuiteNamesTest
, ParseSSLCipherStringFails
) {
47 const char* const cipher_strings
[] = {
53 for (size_t i
= 0; i
< arraysize(cipher_strings
); ++i
) {
54 uint16 cipher_suite
= 0;
55 EXPECT_FALSE(ParseSSLCipherString(cipher_strings
[i
], &cipher_suite
));
59 } // anonymous namespace