package types import ( "encoding/hex" "fmt" "testing" "time" "github.com/stretchr/testify/assert" "gopkg.in/jcmturner/gokrb5.v7/iana" "gopkg.in/jcmturner/gokrb5.v7/iana/adtype" "gopkg.in/jcmturner/gokrb5.v7/iana/nametype" "gopkg.in/jcmturner/gokrb5.v7/test/testdata" ) func unmarshalAuthenticatorTest(t *testing.T, v string) Authenticator { var a Authenticator //t.Logf("Starting unmarshal tests of %s", v) b, err := hex.DecodeString(v) if err != nil { t.Fatalf("Test vector read error: %v", err) } err = a.Unmarshal(b) if err != nil { t.Fatalf("Unmarshal error: %v", err) } return a } func TestUnmarshalAuthenticator(t *testing.T) { t.Parallel() a := unmarshalAuthenticatorTest(t, testdata.MarshaledKRB5authenticator) //Parse the test time value into a time.Time type tt, _ := time.Parse(testdata.TEST_TIME_FORMAT, testdata.TEST_TIME) assert.Equal(t, iana.PVNO, a.AVNO, "Authenticator version number not as expected") assert.Equal(t, testdata.TEST_REALM, a.CRealm, "CRealm not as expected") assert.Equal(t, nametype.KRB_NT_PRINCIPAL, a.CName.NameType, "CName NameType not as expected") assert.Equal(t, len(testdata.TEST_PRINCIPALNAME_NAMESTRING), len(a.CName.NameString), "CName does not have the expected number of NameStrings") assert.Equal(t, testdata.TEST_PRINCIPALNAME_NAMESTRING, a.CName.NameString, "CName entries not as expected") assert.Equal(t, int32(1), a.Cksum.CksumType, "Checksum type not as expected") assert.Equal(t, []byte("1234"), a.Cksum.Checksum, "Checsum not as expected") assert.Equal(t, 123456, a.Cusec, "Client microseconds not as expected") assert.Equal(t, tt, a.CTime, "Client time not as expected") assert.Equal(t, int32(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, 2, len(a.AuthorizationData), "Number of Authorization data items not as expected") for i, entry := range a.AuthorizationData { assert.Equal(t, adtype.ADIfRelevant, entry.ADType, fmt.Sprintf("Authorization type of entry %d not as expected", i+1)) assert.Equal(t, []byte(testdata.TEST_AUTHORIZATION_DATA_VALUE), entry.ADData, fmt.Sprintf("Authorization data of entry %d not as expected", i+1)) } } func TestUnmarshalAuthenticator_optionalsempty(t *testing.T) { t.Parallel() a := unmarshalAuthenticatorTest(t, testdata.MarshaledKRB5authenticatorOptionalsEmpty) //Parse the test time value into a time.Time type tt, _ := time.Parse(testdata.TEST_TIME_FORMAT, testdata.TEST_TIME) assert.Equal(t, iana.PVNO, a.AVNO, "Authenticator version number not as expected") assert.Equal(t, testdata.TEST_REALM, a.CRealm, "CRealm not as expected") assert.Equal(t, nametype.KRB_NT_PRINCIPAL, a.CName.NameType, "CName NameType not as expected") assert.Equal(t, len(testdata.TEST_PRINCIPALNAME_NAMESTRING), len(a.CName.NameString), "CName does not have the expected number of NameStrings") assert.Equal(t, testdata.TEST_PRINCIPALNAME_NAMESTRING, a.CName.NameString, "CName entries not as expected") assert.Equal(t, 123456, a.Cusec, "Client microseconds not as expected") assert.Equal(t, tt, a.CTime, "Client time not as expected") } func TestUnmarshalAuthenticator_optionalsNULL(t *testing.T) { t.Parallel() a := unmarshalAuthenticatorTest(t, testdata.MarshaledKRB5authenticatorOptionalsNULL) //Parse the test time value into a time.Time type tt, _ := time.Parse(testdata.TEST_TIME_FORMAT, testdata.TEST_TIME) assert.Equal(t, iana.PVNO, a.AVNO, "Authenticator version number not as expected") assert.Equal(t, testdata.TEST_REALM, a.CRealm, "CRealm not as expected") assert.Equal(t, nametype.KRB_NT_PRINCIPAL, a.CName.NameType, "CName NameType not as expected") assert.Equal(t, len(testdata.TEST_PRINCIPALNAME_NAMESTRING), len(a.CName.NameString), "CName does not have the expected number of NameStrings") assert.Equal(t, testdata.TEST_PRINCIPALNAME_NAMESTRING, a.CName.NameString, "CName entries not as expected") assert.Equal(t, 123456, a.Cusec, "Client microseconds not as expected") assert.Equal(t, tt, a.CTime, "Client time not as expected") } func TestMarshalAuthenticator(t *testing.T) { t.Parallel() var a Authenticator b, err := hex.DecodeString(testdata.MarshaledKRB5authenticator) if err != nil { t.Fatalf("Test vector read error: %v", err) } err = a.Unmarshal(b) if err != nil { t.Fatalf("Unmarshal error: %v", err) } mb, err := a.Marshal() if err != nil { t.Fatalf("Marshal of ticket errored: %v", err) } assert.Equal(t, b, mb, "Marshal bytes of Authenticator not as expected") }