Semaphore/db/AccessKey_test.go

91 lines
1.6 KiB
Go

package db
import (
"encoding/base64"
"github.com/ansible-semaphore/semaphore/util"
"testing"
)
func TestSetSecret(t *testing.T) {
accessKey := AccessKey{
Type: AccessKeySSH,
SshKey: SshKey{
PrivateKey: "qerphqeruqoweurqwerqqeuiqwpavqr",
},
}
util.Config = &util.ConfigType{}
err := accessKey.SerializeSecret()
if err != nil {
t.Error(err)
}
secret, err := base64.StdEncoding.DecodeString(*accessKey.Secret)
if err != nil {
t.Error(err)
}
if string(secret) != "{\"passphrase\":\"\",\"private_key\":\"qerphqeruqoweurqwerqqeuiqwpavqr\"}" {
t.Error("invalid secret")
}
}
func TestGetSecret(t *testing.T) {
secret := base64.StdEncoding.EncodeToString([]byte(`{
"passphrase": "123456",
"private_key": "qerphqeruqoweurqwerqqeuiqwpavqr"
}`))
util.Config = &util.ConfigType{}
accessKey := AccessKey{
Secret: &secret,
Type: AccessKeySSH,
}
err := accessKey.DeserializeSecret()
if err != nil {
t.Error(err)
}
if accessKey.SshKey.Passphrase != "123456" {
t.Errorf("")
}
if accessKey.SshKey.PrivateKey != "qerphqeruqoweurqwerqqeuiqwpavqr" {
t.Errorf("")
}
}
func TestSetGetSecretWithEncryption(t *testing.T) {
accessKey := AccessKey{
Type: AccessKeySSH,
SshKey: SshKey{
PrivateKey: "qerphqeruqoweurqwerqqeuiqwpavqr",
},
}
util.Config = &util.ConfigType{
AccessKeyEncryption: "hHYgPrhQTZYm7UFTvcdNfKJMB3wtAXtJENUButH+DmM=",
}
err := accessKey.SerializeSecret()
if err != nil {
t.Error(err)
}
accessKey.ResetSecret()
err = accessKey.DeserializeSecret()
if err != nil {
t.Error(err)
}
if accessKey.SshKey.PrivateKey != "qerphqeruqoweurqwerqqeuiqwpavqr" {
t.Error("invalid secret")
}
}