gopass/internal/action/mount_test.go
Dominik Schulz 7281ca8ab4
[chore] Migrate to golangci-lint v2 (#3104)
* [chore] Migrate to golangci-lint v2

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* [chore] Fix more lint issues

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* [chore] Fix more lint issue

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* [chore] Fix more lint issues

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* [chore] Add more package comments.

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* [chore] Fix golangci-lint config and the remaining checks

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* [fix] Use Go 1.24

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* [fix] Fix container builds

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* Fix more failing tests

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* Fix test failure

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* Fix another len assertion

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* Move location tests

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* [fix] Fix most remaining lint issues

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* [fix] Only run XDG specific tests on linux

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* [fix] Attempt to address on source of flaky failures

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

---------

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>
2025-04-17 08:05:43 +02:00

77 lines
1.9 KiB
Go

package action
import (
"bytes"
"os"
"path/filepath"
"testing"
"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 TestMounts(t *testing.T) {
u := gptest.NewUnitTester(t)
ctx := config.NewContextInMemory()
ctx = ctxutil.WithAlwaysYes(ctx, true)
ctx = ctxutil.WithTerminal(ctx, false)
act, err := newMock(ctx, u.StoreDir(""))
require.NoError(t, err)
require.NotNil(t, act)
ctx = act.cfg.WithConfig(ctx)
buf := &bytes.Buffer{}
out.Stdout = buf
out.Stderr = buf
stdout = buf
defer func() {
out.Stdout = os.Stdout
out.Stderr = os.Stderr
stdout = os.Stdout
}()
t.Run("print mounts", func(t *testing.T) {
defer buf.Reset()
require.NoError(t, act.MountsPrint(gptest.CliCtx(ctx, t)))
})
t.Run("complete mounts", func(t *testing.T) {
defer buf.Reset()
act.MountsComplete(gptest.CliCtx(ctx, t))
assert.Empty(t, buf.String())
})
t.Run("remove no non-existing mount", func(t *testing.T) {
defer buf.Reset()
require.Error(t, act.MountRemove(gptest.CliCtx(ctx, t)))
})
t.Run("remove non-existing mount", func(t *testing.T) {
defer buf.Reset()
require.NoError(t, act.MountRemove(gptest.CliCtx(ctx, t, "foo")))
})
t.Run("add non-existing mount", func(t *testing.T) {
defer buf.Reset()
require.Error(t, act.MountAdd(gptest.CliCtx(ctx, t, "foo", filepath.Join(u.Dir, "mount1"))))
})
t.Run("add some mounts", func(t *testing.T) {
defer buf.Reset()
require.NoError(t, u.InitStore("mount1"))
require.NoError(t, u.InitStore("mount2"))
require.NoError(t, act.Store.AddMount(ctx, "mount1", u.StoreDir("mount1")))
require.NoError(t, act.Store.AddMount(ctx, "mount2", u.StoreDir("mount2")))
})
t.Run("print mounts", func(t *testing.T) {
defer buf.Reset()
require.NoError(t, act.MountsPrint(gptest.CliCtx(ctx, t)))
})
}