mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-06 22:50:15 -05:00
072dd9f8bc
Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/4572 Co-authored-by: TheFox0x7 <thefox0x7@gmail.com> Co-committed-by: TheFox0x7 <thefox0x7@gmail.com>
32 lines
977 B
Go
32 lines
977 B
Go
// Copyright 2019 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package secret
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestEncryptDecrypt(t *testing.T) {
|
|
hex, err := EncryptSecret("foo", "baz")
|
|
require.NoError(t, err)
|
|
str, _ := DecryptSecret("foo", hex)
|
|
assert.Equal(t, "baz", str)
|
|
|
|
hex, err = EncryptSecret("bar", "baz")
|
|
require.NoError(t, err)
|
|
str, _ = DecryptSecret("foo", hex)
|
|
assert.NotEqual(t, "baz", str)
|
|
|
|
_, err = DecryptSecret("a", "b")
|
|
require.ErrorContains(t, err, "invalid hex string")
|
|
|
|
_, err = DecryptSecret("a", "bb")
|
|
require.ErrorContains(t, err, "the key (maybe SECRET_KEY?) might be incorrect: AesDecrypt ciphertext too short")
|
|
|
|
_, err = DecryptSecret("a", "0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef")
|
|
require.ErrorContains(t, err, "the key (maybe SECRET_KEY?) might be incorrect: AesDecrypt invalid decrypted base64 string")
|
|
}
|