mirror of
https://github.com/semaphoreui/semaphore.git
synced 2024-11-23 12:30:41 +01:00
91 lines
1.6 KiB
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) != "{\"login\":\"\",\"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")
|
|
}
|
|
} |