utestsha256.pp 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. unit utestsha256;
  2. {$mode objfpc}{$H+}
  3. interface
  4. uses
  5. Classes, SysUtils, fpcunit, testutils, testregistry, fpecc, fpsha256, fphashutils;
  6. type
  7. { TTestSHA256 }
  8. TTestSHA256 = class(TTestCase)
  9. Public
  10. Procedure TestHexString(Const aString,aDigest : String);
  11. Procedure TestBase64String(Const aString,aDigest : String);
  12. Procedure TestHMACString(Const aString,aKey,aDigest : String);
  13. published
  14. procedure TestEmpty;
  15. procedure TestSmallString;
  16. procedure TestEmptyBase64;
  17. procedure TestSmallBase64;
  18. procedure TestSmallHMAC;
  19. procedure TestHMACStream;
  20. end;
  21. { TTestECDSASHA256 }
  22. TTestECDSASHA256 = Class(TTestCase)
  23. // base64url encoded
  24. Const
  25. aInput =
  26. 'eyJ0eXAiOiJKV1QiLCJhbGciOiJFUzI1NiJ9.' +
  27. 'eyJpYXQiOjE1MTYyMzkwMjIsImV4cCI6MTUxNjI0OTAyMiwiaXNzIjoiRGVscGhpIEpPU0UgYW5kIEpXVCBMaWJyYXJ5In0';
  28. aOutput =
  29. '4QDMKAvHwb6pA5fN0oQjlzuKmPIlNpmIQ8vPH7zy4fjZdtcPVJMtfiVhztwQldQL9A5yzBKI8q2puVygm-2Adw';
  30. // Private key in PEM format
  31. Const APrivateKeyPem =
  32. '-----BEGIN EC PRIVATE KEY-----'+ #10+
  33. 'MHcCAQEEIFzS3/5bCnrlpa4902/zkYzURF6E2D8pazgnJu4smhpQoAoGCCqGSM49'+ #10+
  34. 'AwEHoUQDQgAEqTjyg2z65i+zbyUZW8BQ+K87DNsICRaEH7Fy7Rm3MseXy9ItSCQU'+ #10+
  35. 'VeJbtO6kYUA00mx7bKoC1sx5sbtFExnYPQ=='+ #10+
  36. '-----END EC PRIVATE KEY-----';
  37. Published
  38. Procedure TestSignVerify;
  39. Procedure TestVerify;
  40. Procedure TestVerifyFromKey;
  41. end;
  42. implementation
  43. uses
  44. fppem, fpecdsa, basenenc;
  45. { TTestECDSASHA256 }
  46. procedure TTestECDSASHA256.TestSignVerify;
  47. var
  48. aPrivateKey : TEccPrivateKey;
  49. aPublicKey : TEccPublicKey;
  50. aSignature : TECCSignature;
  51. X,Y : Ansistring;
  52. S : TStringStream;
  53. begin
  54. S:=TStringStream.Create(APrivateKeyPem);
  55. try
  56. AssertTrue('Loaded key',PemLoadECDSA(S,aPrivateKey,aPublicKey,X,Y));
  57. AssertTrue('Encrypted',TECDSA.SignSHA256(aInput,aPrivateKey,aSignature));
  58. EccPublicKeyFromPrivateKey(aPublicKey,aPrivateKey);
  59. AssertTrue('Verified our own',TECDSA.SignSHA256(aInput,aPrivateKey,aSignature));
  60. finally
  61. S.Free;
  62. end;
  63. end;
  64. procedure TTestECDSASHA256.TestVerify;
  65. var
  66. aPrivateKey : TEccPrivateKey;
  67. aPublicKey : TEccPublicKey;
  68. aSignature : TECCSignature;
  69. X,Y : Ansistring;
  70. S : TStringStream;
  71. begin
  72. S:=TStringStream.Create(APrivateKeyPem);
  73. try
  74. AssertTrue('Loaded key',PemLoadECDSA(S,aPrivateKey,aPublicKey,X,Y));
  75. AssertTrue('Encrypted',TECDSA.SignSHA256(aInput,aPrivateKey,aSignature));
  76. // Now verify with result of someone else (random elements)
  77. BytesToVar(Base64URL.Decode(aOutput),aSignature,SizeOf(aSignature));
  78. AssertTrue('Verified other',TECDSA.VerifySHA256(aInput,aPrivateKey,aSignature));
  79. finally
  80. S.Free;
  81. end;
  82. end;
  83. procedure TTestECDSASHA256.TestVerifyFromKey;
  84. Const
  85. // from JWT.IO
  86. aInput2 = 'eyJhbGciOiJFUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWUsImlhdCI6MTUxNjIzOTAyMn0';
  87. aOutput2 = 'tyh-VfuzIxCyGYDlkBA7DfyjrqmSHu6pQ2hoZuFqUSLPNY2N0mpHb3nk5K17HWP_3cYHBw7AhHale5wky6-sVA';
  88. aPrivateKey2: TEccPrivateKey = ($7a,$f6,$73,$2f,$58,$1d,$00,$5a,$fc,$f2,$16,$f6,$38,$5f,$f6,
  89. $37,$10,$29,$24,$2c,$c6,$08,$40,$dd,$7d,$2a,$7a,$55,$03,$b7,
  90. $d2,$1c);
  91. var
  92. aSignature : TECCSignature;
  93. begin
  94. BytesToVar(Base64URL.Decode(aOutput2),aSignature,SizeOf(aSignature));
  95. AssertTrue('Verified other',TECDSA.VerifySHA256(aInput2,aPrivateKey2,aSignature));
  96. end;
  97. { TTestSHA256 }
  98. Procedure TTestSHA256.TestHexString(Const aString,aDigest : String);
  99. var
  100. Digest : AnsiString;
  101. S : TBytes;
  102. begin
  103. S:=[];
  104. Digest:='';
  105. S:=TEncoding.UTF8.GetAnsiBytes(aString);
  106. TSHA256.DigestHexa(S, Digest);
  107. AssertEquals('Correct hex digest',aDigest, Digest);
  108. end;
  109. procedure TTestSHA256.TestBase64String(const aString, aDigest: String);
  110. var
  111. Digest : AnsiString;
  112. S : TBytes;
  113. begin
  114. S:=TEncoding.UTF8.GetAnsiBytes(aString);
  115. Digest:='';
  116. TSHA256.DigestBase64(S,False,Digest);
  117. AssertEquals('Correct base64 digest',aDigest, Digest);
  118. end;
  119. procedure TTestSHA256.TestHMACString(const aString, aKey, aDigest: String);
  120. var
  121. Digest : AnsiString;
  122. S,K : TBytes;
  123. begin
  124. S:=TEncoding.UTF8.GetAnsiBytes(aString);
  125. K:=TEncoding.UTF8.GetAnsiBytes(aKey);
  126. TSHA256.HMACHexa(K,S,Digest);
  127. AssertEquals('Correct digest',aDigest, Digest);
  128. end;
  129. procedure TTestSHA256.TestEmpty;
  130. begin
  131. TestHexString('','E3B0C44298FC1C149AFBF4C8996FB92427AE41E4649B934CA495991B7852B855');
  132. end;
  133. procedure TTestSHA256.TestSmallString;
  134. begin
  135. TestHexString('abc','BA7816BF8F01CFEA414140DE5DAE2223B00361A396177A9CB410FF61F20015AD');
  136. end;
  137. procedure TTestSHA256.TestEmptyBase64;
  138. begin
  139. TestBase64String('','47DEQpj8HBSa+/TImW+5JCeuQeRkm5NMpJWZG3hSuFU');
  140. end;
  141. procedure TTestSHA256.TestSmallBase64;
  142. begin
  143. TestBase64String('abc','ungWv48Bz+pBQUDeXa4iI7ADYaOWF3qctBD/YfIAFa0');
  144. end;
  145. procedure TTestSHA256.TestSmallHMAC;
  146. begin
  147. TestHMACString('abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ',
  148. 'Secret key' ,
  149. '6AE3261635F57BF68B6E3DF9C06ED14D3FA793F1B7BE55BC3429895B09F52F77');
  150. end;
  151. procedure TTestSHA256.TestHMACStream;
  152. Var
  153. S : TStringStream;
  154. begin
  155. S:=TStringStream.Create('abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ');
  156. try
  157. AssertEquals('Correct hash','3964294B664613798D1A477EB8AD02118B48D0C5738C427613202F2ED123B5F1',TSHA256.StreamHexa(S));
  158. finally
  159. S.Free;
  160. end;
  161. end;
  162. initialization
  163. RegisterTests([TTestSHA256,TTestECDSASHA256]);
  164. end.