ExtensionsTest.swift 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. //
  2. // ExtensionsTest.swift
  3. // CryptoSwift
  4. //
  5. // Created by Marcin Krzyzanowski on 15/08/14.
  6. // Copyright (c) 2014 Marcin Krzyzanowski. All rights reserved.
  7. //
  8. import XCTest
  9. @testable import CryptoSwift
  10. final class ExtensionsTest: XCTestCase {
  11. override func setUp() {
  12. super.setUp()
  13. }
  14. override func tearDown() {
  15. super.tearDown()
  16. }
  17. func testArrayChunksPerformance() {
  18. measureMetrics([XCTPerformanceMetric_WallClockTime], automaticallyStartMeasuring: false, forBlock: { () -> Void in
  19. let message = Array<UInt8>(count: 1024 * 1024, repeatedValue: 7)
  20. self.startMeasuring()
  21. message.chunks(AES.blockSize)
  22. self.stopMeasuring()
  23. })
  24. }
  25. func testIntExtension() {
  26. let i1:Int = 1024
  27. let i1Array = i1.bytes(32 / 8) // 32 bit
  28. let i1recovered = Int.withBytes(i1Array)
  29. XCTAssertEqual(i1, i1recovered, "Bytes conversion failed")
  30. let i2:Int = 1024
  31. let i2Array = i2.bytes(160 / 8) // 160 bit
  32. let i2recovered = Int.withBytes(i2Array)
  33. XCTAssertEqual(i2, i2recovered, "Bytes conversion failed")
  34. }
  35. func testBytes() {
  36. let size = sizeof(UInt32) // 32 or 64 bit
  37. let i:UInt32 = 1024
  38. var bytes = i.bytes()
  39. XCTAssertTrue(bytes.count == size, "Invalid bytes length = \(bytes.count)")
  40. // test padding
  41. bytes = i.bytes(16)
  42. XCTAssertTrue(bytes.count == 16, "Invalid return type \(bytes.count)")
  43. XCTAssertTrue(bytes[14] == 4, "Invalid return type \(bytes.count)")
  44. }
  45. func testShiftLeft() {
  46. // Unsigned
  47. let i:UInt32 = 1
  48. XCTAssert(i &<< 1 == 2, "shift left failed")
  49. XCTAssert(i &<< 8 == 256, "shift left failed")
  50. XCTAssert(i &<< 31 == i << 31, "shift left failed")
  51. XCTAssert(i &<< 32 == 0, "shift left failed")
  52. // Signed
  53. let ii:Int = 21
  54. XCTAssert(ii &<< 1 == ii << 1, "shift left failed")
  55. XCTAssert(ii &<< 8 == ii << 8, "shift left failed")
  56. XCTAssert(ii &<< ((sizeofValue(ii) * 8) - 1) == ii << ((sizeofValue(ii) * 8) - 1), "shift left failed")
  57. XCTAssert(ii &<< ((sizeofValue(ii) * 8)) == 0, "shift left failed")
  58. let iii:UInt32 = 21
  59. XCTAssert(iii &<< 1 == iii << 1, "shift left failed")
  60. XCTAssert(iii &<< 8 == iii << 8, "shift left failed")
  61. XCTAssert((iii &<< 32) == 0, "shift left failed")
  62. }
  63. func testtoUInt32Array() {
  64. let chunk:ArraySlice<UInt8> = [1,1,1,7,2,3,4,5]
  65. let result = toUInt32Array(chunk)
  66. XCTAssert(result.count == 2, "Invalid conversion")
  67. XCTAssert(result[0] == 117506305, "Invalid conversion")
  68. XCTAssert(result[1] == 84148994, "Invalid conversion")
  69. }
  70. func test_NSData_init() {
  71. let data = NSData(bytes: [0x01, 0x02, 0x03])
  72. XCTAssert(data.length == 3, "Invalid data")
  73. }
  74. func test_String_encrypt_base64() {
  75. let encryptedBase64 = try! "my secret string".encrypt(AES(key: "secret0key000000", iv: "0123456789012345")).toBase64()
  76. XCTAssertEqual(encryptedBase64, "aPf/i9th9iX+vf49eR7PYk2q7S5xmm3jkRLejgzHNJs=")
  77. }
  78. func test_String_decrypt_base64() {
  79. let encryptedBase64 = "aPf/i9th9iX+vf49eR7PYk2q7S5xmm3jkRLejgzHNJs="
  80. let decrypted = try! encryptedBase64.decryptBase64ToString(AES(key: "secret0key000000", iv: "0123456789012345"))
  81. XCTAssertEqual(decrypted, "my secret string")
  82. }
  83. }