| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- package messages
- import (
- "encoding/hex"
- "github.com/jcmturner/gokrb5/iana/msgtype"
- "github.com/jcmturner/gokrb5/testdata"
- "github.com/stretchr/testify/assert"
- "testing"
- "time"
- )
- func TestUnmarshalAPRep(t *testing.T) {
- var a APRep
- v := "encode_krb5_ap_rep"
- b, err := hex.DecodeString(testdata.TestVectors[v])
- if err != nil {
- t.Fatalf("Test vector read error of %s: %v\n", v, err)
- }
- err = a.Unmarshal(b)
- if err != nil {
- t.Fatalf("Unmarshal error of %s: %v\n", v, err)
- }
- assert.Equal(t, testdata.TEST_KVNO, a.PVNO, "PVNO not as expected")
- assert.Equal(t, msgtype.KRB_AP_REP, a.MsgType, "MsgType is not as expected")
- assert.Equal(t, testdata.TEST_ETYPE, a.EncPart.EType, "Ticket encPart etype not as expected")
- assert.Equal(t, testdata.TEST_KVNO, a.EncPart.KVNO, "Ticket encPart KVNO not as expected")
- assert.Equal(t, []byte(testdata.TEST_CIPHERTEXT), a.EncPart.Cipher, "Ticket encPart cipher not as expected")
- }
- func TestUnmarshalEncAPRepPart(t *testing.T) {
- var a EncAPRepPart
- v := "encode_krb5_ap_rep_enc_part"
- b, err := hex.DecodeString(testdata.TestVectors[v])
- if err != nil {
- t.Fatalf("Test vector read error of %s: %v\n", v, err)
- }
- err = a.Unmarshal(b)
- if err != nil {
- t.Fatalf("Unmarshal error of %s: %v\n", v, err)
- }
- //Parse the test time value into a time.Time type
- tt, _ := time.Parse(testdata.TEST_TIME_FORMAT, testdata.TEST_TIME)
- assert.Equal(t, tt, a.CTime, "CTime not as expected")
- assert.Equal(t, 123456, a.Cusec, "Client microseconds not as expected")
- assert.Equal(t, 1, a.Subkey.KeyType, "Subkey type not as expected")
- assert.Equal(t, []byte("12345678"), a.Subkey.KeyValue, "Subkey value not as expected")
- assert.Equal(t, 17, a.SequenceNumber, "Sequence number not as expected")
- }
- func TestUnmarshalEncAPRepPart_optionalsNULL(t *testing.T) {
- var a EncAPRepPart
- v := "encode_krb5_ap_rep_enc_part(optionalsNULL)"
- b, err := hex.DecodeString(testdata.TestVectors[v])
- if err != nil {
- t.Fatalf("Test vector read error of %s: %v\n", v, err)
- }
- err = a.Unmarshal(b)
- if err != nil {
- t.Fatalf("Unmarshal error of %s: %v\n", v, err)
- }
- //Parse the test time value into a time.Time type
- tt, _ := time.Parse(testdata.TEST_TIME_FORMAT, testdata.TEST_TIME)
- assert.Equal(t, tt, a.CTime, "CTime not as expected")
- assert.Equal(t, 123456, a.Cusec, "Client microseconds not as expected")
- }
|