gopass/internal/action/rcs_test.go
Dominik Schulz f58454452f
Increase test coverage (#2461)
RELEASE_NOTES=n/a

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

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>
2022-12-10 23:05:33 +01:00

62 lines
1.2 KiB
Go

package action
import (
"bytes"
"context"
"os"
"testing"
"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 TestGit(t *testing.T) {
u := gptest.NewUnitTester(t)
ctx := context.Background()
ctx = ctxutil.WithAlwaysYes(ctx, true)
ctx = ctxutil.WithInteractive(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
stdout = buf
defer func() {
out.Stdout = os.Stdout
stdout = os.Stdout
}()
// git init
c := gptest.CliCtxWithFlags(ctx, t, map[string]string{"username": "foobar", "useremail": "foo.bar@example.org"})
assert.NoError(t, act.RCSInit(c))
buf.Reset()
// getUserData
name, email := act.getUserData(ctx, "", "", "")
assert.Equal(t, "0xDEADBEEF", name)
assert.Equal(t, "0xDEADBEEF", email)
// GitAddRemote
assert.Error(t, act.RCSAddRemote(c))
buf.Reset()
// GitRemoveRemote
assert.Error(t, act.RCSRemoveRemote(c))
buf.Reset()
// GitPull
assert.Error(t, act.RCSPull(c))
buf.Reset()
// GitPush
assert.Error(t, act.RCSPush(c))
buf.Reset()
}