mirror of
https://github.com/gopasspw/gopass.git
synced 2025-12-08 19:24:54 +00:00
* [FEATURE] Allow for non-interactive age setup Also updates Go to Go 1.23.2 and get rid of min and max functions Signed-off-by: Yolan Romailler <AnomalRoil@users.noreply.github.com> * [n/a] also renaming clear for Windows Signed-off-by: Yolan Romailler <AnomalRoil@users.noreply.github.com> * [n/a] bumping our GHA to Go 1.23 Signed-off-by: Yolan Romailler <AnomalRoil@users.noreply.github.com> * [n/a] make our harden runner softer Signed-off-by: Yolan Romailler <AnomalRoil@users.noreply.github.com> * [n/a] make our harden runner accept go.dev Signed-off-by: Yolan Romailler <AnomalRoil@users.noreply.github.com> * [n/a] applying code review changes Signed-off-by: Yolan Romailler <AnomalRoil@users.noreply.github.com> --------- Signed-off-by: Yolan Romailler <AnomalRoil@users.noreply.github.com>
124 lines
3.6 KiB
Go
124 lines
3.6 KiB
Go
package action
|
|
|
|
import (
|
|
"bytes"
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/gopasspw/gopass/internal/backend"
|
|
"github.com/gopasspw/gopass/internal/backend/crypto/plain"
|
|
"github.com/gopasspw/gopass/internal/config"
|
|
"github.com/gopasspw/gopass/internal/out"
|
|
"github.com/gopasspw/gopass/pkg/ctxutil"
|
|
"github.com/gopasspw/gopass/tests/gptest"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestSetupAgeGitFS(t *testing.T) {
|
|
u := gptest.NewUnitTester(t) //nolint:staticcheck
|
|
|
|
ctx := config.NewContextInMemory()
|
|
ctx = ctxutil.WithAlwaysYes(ctx, true)
|
|
ctx = ctxutil.WithInteractive(ctx, false)
|
|
ctx = backend.WithCryptoBackend(ctx, backend.Age)
|
|
ctx = backend.WithStorageBackend(ctx, backend.GitFS)
|
|
ctx = ctxutil.WithPasswordCallback(ctx, func(_ string, _ bool) ([]byte, error) {
|
|
return []byte("foobar"), nil
|
|
})
|
|
ctx = ctxutil.WithPasswordPurgeCallback(ctx, func(s string) {}) //nolint:staticcheck
|
|
|
|
act, err := newMock(ctx, u.StoreDir(""))
|
|
require.ErrorContains(t, err, "not initialized")
|
|
require.NotNil(t, act)
|
|
|
|
buf := &bytes.Buffer{}
|
|
out.Stdout = buf
|
|
out.Stderr = buf
|
|
defer func() {
|
|
out.Stdout = os.Stdout
|
|
out.Stderr = os.Stderr
|
|
}()
|
|
|
|
// remove existing config and store, we want to start fresh
|
|
require.NoError(t, os.RemoveAll(u.StoreDir("")))
|
|
require.NoError(t, os.Remove(u.GPConfig()))
|
|
|
|
c := gptest.CliCtxWithFlags(ctx, t, map[string]string{"storage": "gitfs", "crypto": "age"})
|
|
require.Error(t, act.IsInitialized(c))
|
|
require.NoError(t, act.Setup(c))
|
|
assert.Contains(t, buf.String(), "Welcome to gopass")
|
|
|
|
crypto := act.Store.Crypto(ctx, "")
|
|
require.NotNil(t, crypto)
|
|
assert.Equal(t, "age", crypto.Name())
|
|
assert.True(t, act.initHasUseablePrivateKeys(ctx, crypto))
|
|
require.NoError(t, act.initGenerateIdentity(ctx, crypto, "foo bar", "foo.bar@example.org"))
|
|
buf.Reset()
|
|
|
|
act.printRecipients(ctx, "")
|
|
assert.Contains(t, buf.String(), "age1")
|
|
buf.Reset()
|
|
}
|
|
|
|
func TestSetupPlainFS(t *testing.T) {
|
|
u := gptest.NewUnitTester(t)
|
|
|
|
ctx := config.NewContextInMemory()
|
|
ctx = ctxutil.WithAlwaysYes(ctx, true)
|
|
ctx = ctxutil.WithInteractive(ctx, false)
|
|
ctx = backend.WithCryptoBackend(ctx, backend.Plain)
|
|
ctx = backend.WithStorageBackend(ctx, backend.FS)
|
|
|
|
act, err := newMock(ctx, u.StoreDir(""))
|
|
require.NoError(t, err)
|
|
require.NotNil(t, act)
|
|
|
|
buf := &bytes.Buffer{}
|
|
out.Stdout = buf
|
|
out.Stderr = buf
|
|
defer func() {
|
|
out.Stdout = os.Stdout
|
|
out.Stderr = os.Stderr
|
|
}()
|
|
|
|
c := gptest.CliCtx(ctx, t, "foo.bar@example.org")
|
|
require.NoError(t, act.IsInitialized(c))
|
|
buf.Reset()
|
|
|
|
require.Error(t, act.Init(c))
|
|
assert.Contains(t, buf.String(), "already initialized")
|
|
buf.Reset()
|
|
|
|
// this will abort because the store is already initialized
|
|
require.NoError(t, act.Setup(c))
|
|
assert.Contains(t, buf.String(), "already initialized")
|
|
buf.Reset()
|
|
|
|
crypto := act.Store.Crypto(ctx, "")
|
|
require.NotNil(t, crypto)
|
|
assert.Equal(t, "plain", crypto.Name())
|
|
assert.True(t, act.initHasUseablePrivateKeys(ctx, crypto))
|
|
require.Error(t, act.initGenerateIdentity(ctx, crypto, "foo bar", "foo.bar@example.org"))
|
|
buf.Reset()
|
|
|
|
act.printRecipients(ctx, "")
|
|
assert.Contains(t, buf.String(), "0xDEADBEEF")
|
|
buf.Reset()
|
|
|
|
// un-initialize the store
|
|
require.NoError(t, os.Remove(filepath.Join(u.StoreDir(""), plain.IDFile)))
|
|
require.Error(t, act.IsInitialized(c))
|
|
buf.Reset()
|
|
|
|
// remove existing config and store
|
|
require.NoError(t, os.RemoveAll(u.StoreDir("")))
|
|
require.NoError(t, os.Remove(u.GPConfig()))
|
|
|
|
// re-initialize the store, i.e. test that a fresh setup with plain and fs works
|
|
require.NoError(t, act.Setup(c))
|
|
assert.Contains(t, buf.String(), "Welcome to gopass")
|
|
buf.Reset()
|
|
}
|