|
@@ -0,0 +1,68 @@
|
|
|
|
|
+package messages
|
|
|
|
|
+
|
|
|
|
|
+import (
|
|
|
|
|
+ "encoding/hex"
|
|
|
|
|
+ "github.com/stretchr/testify/assert"
|
|
|
|
|
+ "github.com/jcmturner/gokrb5/testdata"
|
|
|
|
|
+ "testing"
|
|
|
|
|
+ "github.com/jcmturner/gokrb5/types"
|
|
|
|
|
+ "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, types.KrbDictionary.MsgTypesByName["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")
|
|
|
|
|
+}
|