HashTests.swift 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. //
  2. // CryptoSwiftTests.swift
  3. // CryptoSwiftTests
  4. //
  5. // Created by Marcin Krzyzanowski on 06/07/14.
  6. // Copyright (c) 2014 Marcin Krzyzanowski. All rights reserved.
  7. //
  8. import XCTest
  9. import CryptoSwift
  10. class CryptoSwiftTests: XCTestCase {
  11. override func setUp() {
  12. super.setUp()
  13. }
  14. override func tearDown() {
  15. super.tearDown()
  16. }
  17. func testMD5() {
  18. let data1:NSData = NSData(bytes: [0x31, 0x32, 0x33] as [Byte], length: 3) // "1", "2", "3"
  19. let data2:NSData = NSData(bytes: [0x31, 0x32, 0x33] as [Byte], length: 3) // "1", "2", "3"
  20. if let d = MD5(data1).calculate() {
  21. XCTAssertEqual(d.hexString, "202CB962AC59075B964B07152D234B70", "MD5 calculation failed");
  22. } else {
  23. XCTFail("MD5 fail")
  24. }
  25. //FIXME: fail on 32-bit simulator for some unknown reason.
  26. // because it's working fine for the first time, and break for the second
  27. // time with the very same input data
  28. if let d = MD5(data2).calculate() {
  29. XCTAssertEqual(d.hexString, "202CB962AC59075B964B07152D234B70", "MD5 calculation failed");
  30. } else {
  31. XCTFail("MD5 fail")
  32. }
  33. let string = "123"
  34. if let hash = string.md5() {
  35. XCTAssertEqual(hash, "202CB962AC59075B964B07152D234B70", "MD5 calculation failed");
  36. } else {
  37. XCTFail("MD5 fail")
  38. }
  39. }
  40. // func testSHA1() {
  41. // var data:NSData = NSData(bytes: [49, 50, 51] as [Byte], length: 3)
  42. // var sha1:NSData = data.sha1()
  43. // XCTAssertNotNil(sha1, "SHA1 calculation failed")
  44. //
  45. // var sha1String:String = sha1.toHexString()
  46. // XCTAssertEqualObjects(sha1String, "40BD001563085FC35165329EA1FF5C5ECBDBBEEF", "SHA1 calculation failed");
  47. // }
  48. //
  49. // func testSHA512() {
  50. // var data:NSData = NSData(bytes: [49, 50, 51] as [Byte], length: 3)
  51. // var sha512:NSData = data.sha512()
  52. // XCTAssertNotNil(sha512, "SHA512 calculation failed")
  53. //
  54. // var sha512String:String = sha512.toHexString()
  55. // XCTAssertEqualObjects(sha512String, "3C9909AFEC25354D551DAE21590BB26E38D53F2173B8D3DC3EEE4C047E7AB1C1EB8B85103E3BE7BA613B31BB5C9C36214DC9F14A42FD7A2FDB84856BCA5C44C2", "SHA512 calculation failed");
  56. // }
  57. //
  58. // func testHashEnum() {
  59. // var data:NSData = NSData(bytes: [49, 50, 51] as [Byte], length: 3)
  60. // let md5 = CryptoHash.md5.hash(data);
  61. // var md5String:String = md5.toHexString();
  62. // XCTAssertEqualObjects(md5String, "202CB962AC59075B964B07152D234B70", "MD5 calculation failed");
  63. // }
  64. }