Rainbond/gateway/v1/ssl_cert_test.go
2019-03-27 12:09:14 +08:00

60 lines
1.6 KiB
Go

// RAINBOND, Application Management Platform
// Copyright (C) 2014-2017 Goodrain Co., Ltd.
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version. For any non-GPL usage of Rainbond,
// one or multiple Commercial Licenses authorized by Goodrain Co., Ltd.
// must be obtained first.
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
package v1
import (
"crypto/x509"
"testing"
"time"
)
func TestSSLCert_Equals(t *testing.T) {
s := newFakeSSLCert()
c := newFakeSSLCert()
if !s.Equals(c) {
t.Errorf("s should equal c.")
}
s.Certificate = nil
if s.Equals(c) {
t.Errorf("s should not equal c.")
}
c.Certificate = nil
if !s.Equals(c) {
t.Errorf("s should equal c.")
}
}
func newFakeSSLCert() *SSLCert {
meta := newFakeMeta()
certificate := &x509.Certificate{}
certificate.Raw = []byte("foobar")
return &SSLCert{
Meta: &meta,
CertificateStr: "dummy certificate str",
Certificate: certificate,
PrivateKey: "dummy private key",
CertificatePem: "/expert/servers/nginx/certificate/dummy-secret.pem",
CN: []string{
"CN-1",
"CN-2",
},
ExpireTime: time.Time{},
}
}