mirror of
git://jb55.com/damus
synced 2024-10-06 11:43:21 +00:00
e4860f3ba8
Changelog-Changed: replace Vault dependency with @KeychainStorage property wrapper Closes: #1076
47 lines
1.3 KiB
Swift
47 lines
1.3 KiB
Swift
//
|
|
// KeychainStorageTests.swift
|
|
// damusTests
|
|
//
|
|
// Created by Bryan Montz on 5/3/23.
|
|
//
|
|
|
|
import XCTest
|
|
@testable import damus
|
|
import Security
|
|
|
|
final class KeychainStorageTests: XCTestCase {
|
|
@KeychainStorage(account: "test-keyname")
|
|
var secret: String?
|
|
|
|
override func tearDownWithError() throws {
|
|
secret = nil
|
|
}
|
|
|
|
func testWriteToKeychain() throws {
|
|
// write a secret to the keychain using the property wrapper's setter
|
|
secret = "super-secure-key"
|
|
|
|
// verify it exists in the keychain using the property wrapper's getter
|
|
XCTAssertEqual(secret, "super-secure-key")
|
|
|
|
// verify it exists in the keychain directly
|
|
let query = [
|
|
kSecAttrService: "damus",
|
|
kSecAttrAccount: "test-keyname",
|
|
kSecClass: kSecClassGenericPassword,
|
|
kSecReturnData: true,
|
|
kSecMatchLimit: kSecMatchLimitOne
|
|
] as [CFString: Any] as CFDictionary
|
|
|
|
var result: AnyObject?
|
|
let status = SecItemCopyMatching(query, &result)
|
|
XCTAssertEqual(status, errSecSuccess)
|
|
|
|
let data = try XCTUnwrap(result as? Data)
|
|
let the_secret = String(data: data, encoding: .utf8)
|
|
|
|
XCTAssertEqual(the_secret, "super-secure-key")
|
|
}
|
|
|
|
}
|