2022-06-15 15:49:31 +01:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/btcsuite/btcutil/base58"
|
|
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestCerts(t *testing.T) {
|
|
|
|
suite.Run(t, new(CertsSuite))
|
|
|
|
}
|
|
|
|
|
|
|
|
type CertsSuite struct {
|
|
|
|
suite.Suite
|
2022-06-15 16:36:17 +01:00
|
|
|
TestKeyComponents
|
|
|
|
TestCertComponents
|
2022-06-15 15:49:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *CertsSuite) SetupSuite() {
|
2022-06-15 16:36:17 +01:00
|
|
|
s.SetupKeyComponents(s.T())
|
|
|
|
s.SetupCertComponents(s.T())
|
2022-06-15 15:49:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *CertsSuite) Test_makeSerialNumberFromKey() {
|
2022-06-15 16:36:17 +01:00
|
|
|
s.Require().Zero(makeSerialNumberFromKey(s.PK).Cmp(s.SN))
|
2022-06-15 15:49:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *CertsSuite) TestToECDSA() {
|
|
|
|
k := ToECDSA(base58.Decode(DB58))
|
|
|
|
s.Require().NotNil(k.PublicKey.X)
|
|
|
|
s.Require().NotNil(k.PublicKey.Y)
|
|
|
|
|
|
|
|
s.Require().Zero(k.PublicKey.X.Cmp(s.X))
|
|
|
|
s.Require().Zero(k.PublicKey.Y.Cmp(s.Y))
|
|
|
|
s.Require().Zero(k.D.Cmp(s.D))
|
|
|
|
|
|
|
|
b58 := base58.Encode(s.D.Bytes())
|
|
|
|
s.Require().Equal(DB58, b58)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *CertsSuite) TestGenerateX509Cert() {
|
|
|
|
notBefore := time.Now()
|
|
|
|
notAfter := notBefore.Add(time.Hour)
|
|
|
|
|
2023-01-06 20:21:14 +08:00
|
|
|
c1 := GenerateX509Cert(s.SN, notBefore, notAfter, Localhost)
|
|
|
|
s.Require().Exactly([]string{Localhost}, c1.DNSNames)
|
2022-06-15 15:49:31 +01:00
|
|
|
s.Require().Nil(c1.IPAddresses)
|
|
|
|
|
2023-01-06 20:21:14 +08:00
|
|
|
c2 := GenerateX509Cert(s.SN, notBefore, notAfter, DefaultIP.String())
|
2022-06-15 15:49:31 +01:00
|
|
|
s.Require().Len(c2.IPAddresses, 1)
|
2023-01-06 20:21:14 +08:00
|
|
|
s.Require().Equal(DefaultIP.String(), c2.IPAddresses[0].String())
|
2022-06-15 15:49:31 +01:00
|
|
|
s.Require().Nil(c2.DNSNames)
|
|
|
|
}
|