PaddingTests.swift 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. //
  2. // CryptoSwift
  3. //
  4. // Copyright (C) 2014-2022 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 XCTest
  16. @testable import CryptoSwift
  17. final class PaddingTests: XCTestCase {
  18. func testPKCS7_0() {
  19. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6]
  20. let expected: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16]
  21. let padded = PKCS7.Padding().add(to: input, blockSize: 16)
  22. XCTAssertEqual(padded, expected, "PKCS7 failed")
  23. let clean = PKCS7.Padding().remove(from: padded, blockSize: nil)
  24. XCTAssertEqual(clean, input, "PKCS7 failed")
  25. }
  26. func testPKCS7_1() {
  27. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5]
  28. let expected: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 1]
  29. let padded = PKCS7.Padding().add(to: input, blockSize: 16)
  30. XCTAssertEqual(padded, expected, "PKCS7 failed")
  31. let clean = PKCS7.Padding().remove(from: padded, blockSize: nil)
  32. XCTAssertEqual(clean, input, "PKCS7 failed")
  33. }
  34. func testPKCS7_2() {
  35. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4]
  36. let expected: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 2, 2]
  37. let padded = PKCS7.Padding().add(to: input, blockSize: 16)
  38. XCTAssertEqual(padded, expected, "PKCS7 failed")
  39. let clean = PKCS7.Padding().remove(from: padded, blockSize: nil)
  40. XCTAssertEqual(clean, input, "PKCS7 failed")
  41. }
  42. func testZeroPadding1() {
  43. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9]
  44. let expected: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 0, 0, 0, 0, 0, 0]
  45. let padding = ZeroPadding()
  46. XCTAssertEqual(padding.add(to: input, blockSize: 16), expected, "ZeroPadding failed")
  47. XCTAssertEqual(padding.remove(from: padding.add(to: input, blockSize: 16), blockSize: 16), input, "ZeroPadding failed")
  48. }
  49. func testZeroPadding2() {
  50. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6]
  51. let expected: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
  52. let padding = ZeroPadding()
  53. XCTAssertEqual(padding.add(to: input, blockSize: 16), expected, "ZeroPadding failed")
  54. XCTAssertEqual(padding.remove(from: padding.add(to: input, blockSize: 16), blockSize: 16), input, "ZeroPadding failed")
  55. }
  56. func testISO78164_0() {
  57. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 0x80]
  58. let expected: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 0x80, 0x80]
  59. let padded = ISO78164Padding().add(to: input, blockSize: 16)
  60. XCTAssertEqual(padded, expected, "ISO78164 failed")
  61. let clean = ISO78164Padding().remove(from: padded, blockSize: nil)
  62. XCTAssertEqual(clean, input, "ISO78164 failed")
  63. }
  64. func testISO78164_1() {
  65. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 0]
  66. let expected: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 0, 0x80] + [UInt8](repeating: UInt8(0), count: 15)
  67. let padded = ISO78164Padding().add(to: input, blockSize: 16)
  68. XCTAssertEqual(padded, expected, "ISO78164 failed")
  69. let clean = ISO78164Padding().remove(from: padded, blockSize: nil)
  70. XCTAssertEqual(clean, input, "ISO78164 failed")
  71. }
  72. func testISO78164_2() {
  73. let input: Array<UInt8> = []
  74. let expected: Array<UInt8> = [0x80] + [UInt8](repeating: UInt8(0), count: 15)
  75. let padded = ISO78164Padding().add(to: input, blockSize: 16)
  76. XCTAssertEqual(padded, expected, "ISO78164 failed")
  77. let clean = ISO78164Padding().remove(from: padded, blockSize: nil)
  78. XCTAssertEqual(clean, input, "ISO78164 failed")
  79. }
  80. func testISO10126_0() {
  81. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3]
  82. let padded = ISO10126Padding().add(to: input, blockSize: 16)
  83. XCTAssertTrue(padded.starts(with: input), "ISO10126 failed")
  84. XCTAssertEqual(padded.last, 3, "ISO10126 failed")
  85. XCTAssertEqual(padded.count, 16)
  86. let clean = ISO10126Padding().remove(from: padded, blockSize: nil)
  87. XCTAssertEqual(clean, input, "ISO10126 failed")
  88. }
  89. func testISO10126_1() {
  90. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6]
  91. let padded = ISO10126Padding().add(to: input, blockSize: 16)
  92. XCTAssertTrue(padded.starts(with: input), "ISO10126 failed")
  93. XCTAssertEqual(padded.last, 16, "ISO10126 failed")
  94. XCTAssertEqual(padded.count, 32)
  95. let clean = ISO10126Padding().remove(from: padded, blockSize: nil)
  96. XCTAssertEqual(clean, input, "ISO10126 failed")
  97. }
  98. func testISO10126_2() {
  99. let input: Array<UInt8> = []
  100. let padded = ISO10126Padding().add(to: input, blockSize: 16)
  101. XCTAssertTrue(padded.starts(with: input), "ISO10126 failed")
  102. XCTAssertEqual(padded.last, 16, "ISO10126 failed")
  103. XCTAssertEqual(padded.count, 16)
  104. let clean = ISO10126Padding().remove(from: padded, blockSize: nil)
  105. XCTAssertEqual(clean, input, "ISO10126 failed")
  106. }
  107. func testEMSAPKCS1v15_1() {
  108. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6]
  109. let padded = EMSAPKCS1v15Padding().add(to: input, blockSize: 32)
  110. XCTAssertEqual(padded.prefix(2), [0, 1], "EMSAPKCS1v15 failed")
  111. XCTAssertTrue(padded.suffix(16) == input, "EMSAPKCS1v15 failed")
  112. XCTAssertEqual(padded.count, 32)
  113. let clean = EMSAPKCS1v15Padding().remove(from: padded, blockSize: nil)
  114. XCTAssertEqual(clean, input, "EMSAPKCS1v15 failed")
  115. }
  116. func testEMSAPKCS1v15_2() {
  117. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6]
  118. let padded = EMSAPKCS1v15Padding().add(to: input, blockSize: 16)
  119. XCTAssertEqual(padded.prefix(2), [0, 1], "EMSAPKCS1v15 failed")
  120. XCTAssertTrue(padded.suffix(16) == input, "EMSAPKCS1v15 failed")
  121. XCTAssertEqual(padded.count, 32)
  122. let clean = EMSAPKCS1v15Padding().remove(from: padded, blockSize: nil)
  123. XCTAssertEqual(clean, input, "EMSAPKCS1v15 failed")
  124. }
  125. func testEMSAPKCS1v15_3() {
  126. let input: Array<UInt8> = []
  127. let padded = EMSAPKCS1v15Padding().add(to: input, blockSize: 16)
  128. XCTAssertTrue(padded.starts(with: input), "EMSAPKCS1v15 failed")
  129. XCTAssertEqual(padded.last, 0, "EMSAPKCS1v15 failed")
  130. XCTAssertEqual(padded.count, 16)
  131. let clean = EMSAPKCS1v15Padding().remove(from: padded, blockSize: nil)
  132. XCTAssertEqual(clean, input, "EMSAPKCS1v15 failed")
  133. }
  134. func testEMSAPKCS1v15_4() {
  135. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3]
  136. let padded = EMSAPKCS1v15Padding().add(to: input, blockSize: 16)
  137. XCTAssertEqual(padded.prefix(2), [0, 1], "EMSAPKCS1v15 failed")
  138. XCTAssertTrue(padded.suffix(13) == input, "EMSAPKCS1v15 failed")
  139. XCTAssertEqual(padded.count, 32)
  140. let clean = EMSAPKCS1v15Padding().remove(from: padded, blockSize: nil)
  141. XCTAssertEqual(clean, input, "EMSAPKCS1v15 failed")
  142. }
  143. func testEMSAPKCS1v15_5() {
  144. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2]
  145. let padded = EMSAPKCS1v15Padding().add(to: input, blockSize: 16)
  146. XCTAssertEqual(padded.prefix(2), [0, 1], "EMSAPKCS1v15 failed")
  147. XCTAssertTrue(padded.suffix(12) == input, "EMSAPKCS1v15 failed")
  148. XCTAssertEqual(padded.count, 16)
  149. let clean = EMSAPKCS1v15Padding().remove(from: padded, blockSize: nil)
  150. XCTAssertEqual(clean, input, "EMSAPKCS1v15 failed")
  151. }
  152. func testEMEPKCS1v15_1() {
  153. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6]
  154. let padded = EMEPKCS1v15Padding().add(to: input, blockSize: 32)
  155. XCTAssertEqual(padded.prefix(2), [0, 2], "EMEPKCS1v15 failed")
  156. XCTAssertTrue(padded.suffix(16) == input, "EMEPKCS1v15 failed")
  157. XCTAssertEqual(padded.count, 32)
  158. let clean = EMEPKCS1v15Padding().remove(from: padded, blockSize: nil)
  159. XCTAssertEqual(clean, input, "EMEPKCS1v15 failed")
  160. }
  161. func testEMEPKCS1v15_2() {
  162. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6]
  163. let padded = EMEPKCS1v15Padding().add(to: input, blockSize: 16)
  164. XCTAssertEqual(padded.prefix(2), [0, 2], "EMEPKCS1v15 failed")
  165. XCTAssertTrue(padded.suffix(16) == input, "EMEPKCS1v15 failed")
  166. XCTAssertEqual(padded.count, 32)
  167. let clean = EMEPKCS1v15Padding().remove(from: padded, blockSize: nil)
  168. XCTAssertEqual(clean, input, "EMEPKCS1v15 failed")
  169. }
  170. func testEMEPKCS1v15_3() {
  171. let input: Array<UInt8> = []
  172. let padded = EMEPKCS1v15Padding().add(to: input, blockSize: 16)
  173. XCTAssertTrue(padded.starts(with: input), "EMEPKCS1v15 failed")
  174. XCTAssertEqual(padded.last, 0, "EMEPKCS1v15 failed")
  175. XCTAssertEqual(padded.count, 16)
  176. let clean = EMEPKCS1v15Padding().remove(from: padded, blockSize: nil)
  177. XCTAssertEqual(clean, input, "EMEPKCS1v15 failed")
  178. }
  179. func testEMEPKCS1v15_4() {
  180. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3]
  181. let padded = EMEPKCS1v15Padding().add(to: input, blockSize: 16)
  182. XCTAssertEqual(padded.prefix(2), [0, 2], "EMEPKCS1v15 failed")
  183. XCTAssertTrue(padded.suffix(13) == input, "EMEPKCS1v15 failed")
  184. XCTAssertEqual(padded.count, 32)
  185. let clean = EMEPKCS1v15Padding().remove(from: padded, blockSize: nil)
  186. XCTAssertEqual(clean, input, "EMEPKCS1v15 failed")
  187. }
  188. func testEMEPKCS1v15_5() {
  189. let input: Array<UInt8> = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2]
  190. let padded = EMEPKCS1v15Padding().add(to: input, blockSize: 16)
  191. XCTAssertEqual(padded.prefix(2), [0, 2], "EMEPKCS1v15 failed")
  192. XCTAssertTrue(padded.suffix(12) == input, "EMEPKCS1v15 failed")
  193. XCTAssertEqual(padded.count, 16)
  194. let clean = EMEPKCS1v15Padding().remove(from: padded, blockSize: nil)
  195. XCTAssertEqual(clean, input, "EMEPKCS1v15 failed")
  196. }
  197. static let allTests = [
  198. ("testPKCS7_0", testPKCS7_0),
  199. ("testPKCS7_1", testPKCS7_1),
  200. ("testPKCS7_2", testPKCS7_2),
  201. ("testZeroPadding1", testZeroPadding1),
  202. ("testZeroPadding2", testZeroPadding2),
  203. ("testISO78164_0", testISO78164_0),
  204. ("testISO78164_1", testISO78164_1),
  205. ("testISO78164_2", testISO78164_2),
  206. ("testISO10126_0", testISO10126_0),
  207. ("testISO10126_1", testISO10126_1),
  208. ("testISO10126_2", testISO10126_2),
  209. ("testEMSAPKCS1v15_1", testEMSAPKCS1v15_1),
  210. ("testEMSAPKCS1v15_2", testEMSAPKCS1v15_2),
  211. ("testEMSAPKCS1v15_3", testEMSAPKCS1v15_3),
  212. ("testEMSAPKCS1v15_4", testEMSAPKCS1v15_4),
  213. ("testEMSAPKCS1v15_5", testEMSAPKCS1v15_5),
  214. ("testEMEPKCS1v15_1", testEMEPKCS1v15_1),
  215. ("testEMEPKCS1v15_2", testEMEPKCS1v15_2),
  216. ("testEMEPKCS1v15_3", testEMEPKCS1v15_3),
  217. ("testEMEPKCS1v15_4", testEMEPKCS1v15_4),
  218. ("testEMEPKCS1v15_5", testEMEPKCS1v15_5),
  219. ]
  220. }