blake2b_f_test.go 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. package blake2b
  2. import (
  3. "fmt"
  4. "reflect"
  5. "testing"
  6. )
  7. func TestF(t *testing.T) {
  8. for i, test := range testVectorsF {
  9. t.Run(fmt.Sprintf("test vector %v", i), func(t *testing.T) {
  10. //toEthereumTestCase(test)
  11. h := test.hIn
  12. F(&h, test.m, test.c, test.f, test.rounds)
  13. if !reflect.DeepEqual(test.hOut, h) {
  14. t.Errorf("Unexpected result\nExpected: [%#x]\nActual: [%#x]\n", test.hOut, h)
  15. }
  16. })
  17. }
  18. }
  19. type testVector struct {
  20. hIn [8]uint64
  21. m [16]uint64
  22. c [2]uint64
  23. f bool
  24. rounds uint32
  25. hOut [8]uint64
  26. }
  27. // https://tools.ietf.org/html/rfc7693#appendix-A
  28. var testVectorsF = []testVector{
  29. {
  30. hIn: [8]uint64{
  31. 0x6a09e667f2bdc948, 0xbb67ae8584caa73b,
  32. 0x3c6ef372fe94f82b, 0xa54ff53a5f1d36f1,
  33. 0x510e527fade682d1, 0x9b05688c2b3e6c1f,
  34. 0x1f83d9abfb41bd6b, 0x5be0cd19137e2179,
  35. },
  36. m: [16]uint64{
  37. 0x0000000000636261, 0x0000000000000000, 0x0000000000000000,
  38. 0x0000000000000000, 0x0000000000000000, 0x0000000000000000,
  39. 0x0000000000000000, 0x0000000000000000, 0x0000000000000000,
  40. 0x0000000000000000, 0x0000000000000000, 0x0000000000000000,
  41. 0x0000000000000000, 0x0000000000000000, 0x0000000000000000,
  42. 0x0000000000000000,
  43. },
  44. c: [2]uint64{3, 0},
  45. f: true,
  46. rounds: 12,
  47. hOut: [8]uint64{
  48. 0x0D4D1C983FA580BA, 0xE9F6129FB697276A, 0xB7C45A68142F214C,
  49. 0xD1A2FFDB6FBB124B, 0x2D79AB2A39C5877D, 0x95CC3345DED552C2,
  50. 0x5A92F1DBA88AD318, 0x239900D4ED8623B9,
  51. },
  52. },
  53. }