shithub: tlsclient

ref: 8bc69a872883224675a55db51ac8f60ab5ed9e5a
dir: /third_party/boringssl/src/crypto/conf/conf_test.cc/

View raw version
/* Copyright (c) 2021, Google Inc.
 *
 * Permission to use, copy, modify, and/or distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 *
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
 * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
 * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */

#include <openssl/bio.h>
#include <openssl/conf.h>

#include <gtest/gtest.h>


TEST(ConfTest, Parse) {
  // Check that basic parsing works. (We strongly recommend that people don't
  // use the [N]CONF functions.)

  static const char kConf[] = R"(
# Comment

key=value

[section_name]
key=value2
)";

  bssl::UniquePtr<BIO> bio(BIO_new_mem_buf(kConf, sizeof(kConf) - 1));
  ASSERT_TRUE(bio);
  bssl::UniquePtr<CONF> conf(NCONF_new(nullptr));
  ASSERT_TRUE(conf);
  ASSERT_TRUE(NCONF_load_bio(conf.get(), bio.get(), nullptr));
  EXPECT_TRUE(NCONF_get_section(conf.get(), "section_name"));
  EXPECT_FALSE(NCONF_get_section(conf.get(), "other_section"));
  EXPECT_STREQ(NCONF_get_string(conf.get(), nullptr, "key"), "value");
  EXPECT_STREQ(NCONF_get_string(conf.get(), "section_name", "key"), "value2");
  EXPECT_STREQ(NCONF_get_string(conf.get(), "other_section", "key"), nullptr);
}