APRep_test.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. package messages
  2. import (
  3. "encoding/hex"
  4. "testing"
  5. "time"
  6. "github.com/stretchr/testify/assert"
  7. "gopkg.in/jcmturner/gokrb5.v7/iana"
  8. "gopkg.in/jcmturner/gokrb5.v7/iana/msgtype"
  9. "gopkg.in/jcmturner/gokrb5.v7/test/testdata"
  10. )
  11. func TestUnmarshalAPRep(t *testing.T) {
  12. t.Parallel()
  13. var a APRep
  14. b, err := hex.DecodeString(testdata.MarshaledKRB5ap_rep)
  15. if err != nil {
  16. t.Fatalf("Test vector read error: %v", err)
  17. }
  18. err = a.Unmarshal(b)
  19. if err != nil {
  20. t.Fatalf("Unmarshal error: %v", err)
  21. }
  22. assert.Equal(t, iana.PVNO, a.PVNO, "PVNO not as expected")
  23. assert.Equal(t, msgtype.KRB_AP_REP, a.MsgType, "MsgType is not as expected")
  24. assert.Equal(t, testdata.TEST_ETYPE, a.EncPart.EType, "Ticket encPart etype not as expected")
  25. assert.Equal(t, iana.PVNO, a.EncPart.KVNO, "Ticket encPart KVNO not as expected")
  26. assert.Equal(t, []byte(testdata.TEST_CIPHERTEXT), a.EncPart.Cipher, "Ticket encPart cipher not as expected")
  27. }
  28. func TestUnmarshalEncAPRepPart(t *testing.T) {
  29. t.Parallel()
  30. var a EncAPRepPart
  31. b, err := hex.DecodeString(testdata.MarshaledKRB5ap_rep_enc_part)
  32. if err != nil {
  33. t.Fatalf("Test vector read error: %v", err)
  34. }
  35. err = a.Unmarshal(b)
  36. if err != nil {
  37. t.Fatalf("Unmarshal error: %v", err)
  38. }
  39. //Parse the test time value into a time.Time type
  40. tt, _ := time.Parse(testdata.TEST_TIME_FORMAT, testdata.TEST_TIME)
  41. assert.Equal(t, tt, a.CTime, "CTime not as expected")
  42. assert.Equal(t, 123456, a.Cusec, "Client microseconds not as expected")
  43. assert.Equal(t, int32(1), a.Subkey.KeyType, "Subkey type not as expected")
  44. assert.Equal(t, []byte("12345678"), a.Subkey.KeyValue, "Subkey value not as expected")
  45. assert.Equal(t, int64(17), a.SequenceNumber, "Sequence number not as expected")
  46. }
  47. func TestUnmarshalEncAPRepPart_optionalsNULL(t *testing.T) {
  48. t.Parallel()
  49. var a EncAPRepPart
  50. b, err := hex.DecodeString(testdata.MarshaledKRB5ap_rep_enc_partOptionalsNULL)
  51. if err != nil {
  52. t.Fatalf("Test vector read error: %v", err)
  53. }
  54. err = a.Unmarshal(b)
  55. if err != nil {
  56. t.Fatalf("Unmarshal error: %v", err)
  57. }
  58. //Parse the test time value into a time.Time type
  59. tt, _ := time.Parse(testdata.TEST_TIME_FORMAT, testdata.TEST_TIME)
  60. assert.Equal(t, tt, a.CTime, "CTime not as expected")
  61. assert.Equal(t, 123456, a.Cusec, "Client microseconds not as expected")
  62. }