blob: f583c7a40bd8183cc366286996c33ee689d47819 [file] [log] [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CRYPTO_SCOPED_TEST_NSS_DB_H_
#define CRYPTO_SCOPED_TEST_NSS_DB_H_
#include "base/files/scoped_temp_dir.h"
#include "crypto/crypto_export.h"
#include "crypto/scoped_nss_types.h"
namespace crypto {
// Opens a persistent NSS database in a temporary directory.
// Prior NSS version 3.15.1, because of http://bugzil.la/875601 , the opened DB
// will not be closed automatically.
class CRYPTO_EXPORT ScopedTestNSSDB {
public:
ScopedTestNSSDB();
ScopedTestNSSDB(const ScopedTestNSSDB&) = delete;
ScopedTestNSSDB& operator=(const ScopedTestNSSDB&) = delete;
~ScopedTestNSSDB();
bool is_open() const { return !!slot_; }
PK11SlotInfo* slot() const { return slot_.get(); }
private:
// Removes trust from all certificates found in |slot_|.
void RemoveTrustFromAllCerts();
base::ScopedTempDir temp_dir_;
ScopedPK11Slot slot_;
};
} // namespace crypto
#endif // CRYPTO_SCOPED_TEST_NSS_DB_H_