1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- //
- // CryptoSwift
- //
- // Copyright (C) 2014-2017 Marcin Krzyżanowski <marcin@krzyzanowskim.com>
- // This software is provided 'as-is', without any express or implied warranty.
- //
- // In no event will the authors be held liable for any damages arising from the use of this software.
- //
- // Permission is granted to anyone to use this software for any purpose,including commercial applications, and to alter it and redistribute it freely, subject to the following restrictions:
- //
- // - The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation is required.
- // - Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
- // - This notice may not be removed or altered from any source or binary distribution.
- //
- import Foundation
- import XCTest
- @testable import CryptoSwift
- final class AESTestsPerf: XCTestCase {
- func testAESEncryptPerformance() {
- let key: Array<UInt8> = [0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c]
- let iv: Array<UInt8> = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f]
- let message = Array<UInt8>(repeating: 7, count: 1024 * 1024)
- let aes = try! AES(key: key, blockMode: CBC(iv: iv), padding: .pkcs7)
- measure {
- _ = try! aes.encrypt(message)
- }
- }
- func testAESDecryptPerformance() {
- let key: Array<UInt8> = [0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c]
- let iv: Array<UInt8> = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f]
- let message = Array<UInt8>(repeating: 7, count: 1024 * 1024)
- let aes = try! AES(key: key, blockMode: CBC(iv: iv), padding: .pkcs7)
- measure {
- _ = try! aes.decrypt(message)
- }
- }
- }
- extension AESTestsPerf {
- static func allTests() -> [(String, (AESTestsPerf) -> () -> Void)] {
- let tests = [
- ("testAESEncryptPerformance", testAESEncryptPerformance),
- ("testAESDecryptPerformance", testAESDecryptPerformance)
- ]
- return tests
- }
- }
|