Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(174)

Unified Diff: net/cert/internal/test_helpers.cc

Issue 1290553002: [refactor] Extract some test helpers for certificate verification unittests. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@cert_mapper
Patch Set: rebase onto master Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/cert/internal/test_helpers.h ('k') | net/cert/internal/verify_name_match_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/cert/internal/test_helpers.cc
diff --git a/net/cert/internal/test_helpers.cc b/net/cert/internal/test_helpers.cc
new file mode 100644
index 0000000000000000000000000000000000000000..6f5d5edc7dbd4232a3c0060e0a709ae1f60ad82b
--- /dev/null
+++ b/net/cert/internal/test_helpers.cc
@@ -0,0 +1,76 @@
+// Copyright 2015 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 "net/cert/internal/test_helpers.h"
+
+#include "base/base_paths.h"
+#include "base/files/file_util.h"
+#include "base/path_service.h"
+#include "net/cert/pem_tokenizer.h"
+
+namespace net {
+
+der::Input InputFromString(const std::string* s) {
+ return der::Input(reinterpret_cast<const uint8_t*>(s->data()), s->size());
+}
+
+::testing::AssertionResult ReadTestDataFromPemFile(
+ const std::string& file_path_ascii,
+ const PemBlockMapping* mappings,
+ size_t mappings_length) {
+ // Compute the full path, relative to the src/ directory.
+ base::FilePath src_root;
+ PathService::Get(base::DIR_SOURCE_ROOT, &src_root);
+ base::FilePath filepath = src_root.AppendASCII(file_path_ascii);
+
+ // Read the full contents of the PEM file.
+ std::string file_data;
+ if (!base::ReadFileToString(filepath, &file_data)) {
+ return ::testing::AssertionFailure() << "Couldn't read file: "
+ << filepath.value();
+ }
+
+ // mappings_copy is used to keep track of which mappings have already been
+ // satisfied (by nulling the |value| field). This is used to track when
+ // blocks are mulitply defined.
+ std::vector<PemBlockMapping> mappings_copy(mappings,
+ mappings + mappings_length);
+
+ // Build the |pem_headers| vector needed for PEMTokenzier.
+ std::vector<std::string> pem_headers;
+ for (const auto& mapping : mappings_copy) {
+ pem_headers.push_back(mapping.block_name);
+ }
+
+ PEMTokenizer pem_tokenizer(file_data, pem_headers);
+ while (pem_tokenizer.GetNext()) {
+ for (auto& mapping : mappings_copy) {
+ // Find the mapping for this block type.
+ if (pem_tokenizer.block_type() == mapping.block_name) {
+ if (!mapping.value) {
+ return ::testing::AssertionFailure()
+ << "PEM block defined multiple times: " << mapping.block_name;
+ }
+
+ // Copy the data to the result.
+ mapping.value->assign(pem_tokenizer.data());
+
+ // Mark the mapping as having been satisfied.
+ mapping.value = nullptr;
+ }
+ }
+ }
+
+ // Ensure that all specified blocks were found.
+ for (const auto& mapping : mappings_copy) {
+ if (mapping.value) {
+ return ::testing::AssertionFailure() << "PEM block missing: "
+ << mapping.block_name;
+ }
+ }
+
+ return ::testing::AssertionSuccess();
+}
+
+} // namespace net
« no previous file with comments | « net/cert/internal/test_helpers.h ('k') | net/cert/internal/verify_name_match_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698