HashTests.swift 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  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. if let hash = MD5(data1).calculate() {
  20. XCTAssertEqual(hash.hexString, "202CB962AC59075B964B07152D234B70", "MD5 calculation failed");
  21. }
  22. if let hash = "123".md5() {
  23. XCTAssertEqual(hash, "202CB962AC59075B964B07152D234B70", "MD5 calculation failed");
  24. }
  25. if let hash = "".md5() {
  26. XCTAssertEqual(hash, "D41D8CD98F00B204E9800998ECF8427E", "MD5 calculation failed")
  27. }
  28. if let hash = "a".md5() {
  29. XCTAssertEqual(hash, "0CC175B9C0F1B6A831C399E269772661", "MD5 calculation failed")
  30. }
  31. if let hash = "abc".md5() {
  32. XCTAssertEqual(hash, "900150983CD24FB0D6963F7D28E17F72", "MD5 calculation failed")
  33. }
  34. if let hash = "message digest".md5() {
  35. XCTAssertEqual(hash, "F96B697D7CB7938D525A2F31AAF161D0", "MD5 calculation failed")
  36. }
  37. if let hash = "abcdefghijklmnopqrstuvwxyz".md5() {
  38. XCTAssertEqual(hash, "C3FCD3D76192E4007DFB496CCA67E13B", "MD5 calculation failed")
  39. }
  40. if let hash = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789".md5() {
  41. XCTAssertEqual(hash, "D174AB98D277D9F5A5611C2C9F419D9F", "MD5 calculation failed")
  42. }
  43. if let hash = "12345678901234567890123456789012345678901234567890123456789012345678901234567890".md5() {
  44. XCTAssertEqual(hash, "57EDF4A22BE3C955AC49DA2E2107B67A", "MD5 calculation failed")
  45. }
  46. }
  47. // func testSHA1() {
  48. // var data:NSData = NSData(bytes: [49, 50, 51] as [Byte], length: 3)
  49. // var sha1:NSData = data.sha1()
  50. // XCTAssertNotNil(sha1, "SHA1 calculation failed")
  51. //
  52. // var sha1String:String = sha1.toHexString()
  53. // XCTAssertEqualObjects(sha1String, "40BD001563085FC35165329EA1FF5C5ECBDBBEEF", "SHA1 calculation failed");
  54. // }
  55. //
  56. // func testSHA512() {
  57. // var data:NSData = NSData(bytes: [49, 50, 51] as [Byte], length: 3)
  58. // var sha512:NSData = data.sha512()
  59. // XCTAssertNotNil(sha512, "SHA512 calculation failed")
  60. //
  61. // var sha512String:String = sha512.toHexString()
  62. // XCTAssertEqualObjects(sha512String, "3C9909AFEC25354D551DAE21590BB26E38D53F2173B8D3DC3EEE4C047E7AB1C1EB8B85103E3BE7BA613B31BB5C9C36214DC9F14A42FD7A2FDB84856BCA5C44C2", "SHA512 calculation failed");
  63. // }
  64. //
  65. // func testHashEnum() {
  66. // var data:NSData = NSData(bytes: [49, 50, 51] as [Byte], length: 3)
  67. // let md5 = CryptoHash.md5.hash(data);
  68. // var md5String:String = md5.toHexString();
  69. // XCTAssertEqualObjects(md5String, "202CB962AC59075B964B07152D234B70", "MD5 calculation failed");
  70. // }
  71. }