AESTestsPerf.swift 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. //
  2. // CryptoSwift
  3. //
  4. // Copyright (C) 2014-2017 Marcin Krzyżanowski <marcin@krzyzanowskim.com>
  5. // This software is provided 'as-is', without any express or implied warranty.
  6. //
  7. // In no event will the authors be held liable for any damages arising from the use of this software.
  8. //
  9. // 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:
  10. //
  11. // - 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.
  12. // - Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
  13. // - This notice may not be removed or altered from any source or binary distribution.
  14. //
  15. import Foundation
  16. import XCTest
  17. @testable import CryptoSwift
  18. final class AESTestsPerf: XCTestCase {
  19. func testAESEncryptPerformance() {
  20. let key: Array<UInt8> = [0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c]
  21. let iv: Array<UInt8> = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f]
  22. let message = Array<UInt8>(repeating: 7, count: 1024 * 1024)
  23. let aes = try! AES(key: key, blockMode: CBC(iv: iv), padding: .pkcs7)
  24. measure {
  25. _ = try! aes.encrypt(message)
  26. }
  27. }
  28. func testAESDecryptPerformance() {
  29. let key: Array<UInt8> = [0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c]
  30. let iv: Array<UInt8> = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f]
  31. let message = Array<UInt8>(repeating: 7, count: 1024 * 1024)
  32. let aes = try! AES(key: key, blockMode: CBC(iv: iv), padding: .pkcs7)
  33. measure {
  34. _ = try! aes.decrypt(message)
  35. }
  36. }
  37. }
  38. extension AESTestsPerf {
  39. static func allTests() -> [(String, (AESTestsPerf) -> () -> Void)] {
  40. let tests = [
  41. ("testAESEncryptPerformance", testAESEncryptPerformance),
  42. ("testAESDecryptPerformance", testAESDecryptPerformance)
  43. ]
  44. return tests
  45. }
  46. }