mirror of
https://github.com/rclone/rclone.git
synced 2025-01-25 07:39:13 +01:00
7751d5a00b
Fixes: #6540 Discussed: https://forum.rclone.org/t/environment-variable-config-not-used-for-remote-control/39014
180 lines
4.7 KiB
Go
180 lines
4.7 KiB
Go
package config_test
|
|
|
|
import (
|
|
"context"
|
|
"os"
|
|
"testing"
|
|
|
|
_ "github.com/rclone/rclone/backend/local"
|
|
"github.com/rclone/rclone/fs"
|
|
"github.com/rclone/rclone/fs/config"
|
|
"github.com/rclone/rclone/fs/config/configfile"
|
|
"github.com/rclone/rclone/fs/config/obscure"
|
|
"github.com/rclone/rclone/fs/rc"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
const testName = "configTestNameForRc"
|
|
|
|
func TestRc(t *testing.T) {
|
|
ctx := context.Background()
|
|
configfile.Install()
|
|
// Create the test remote
|
|
call := rc.Calls.Get("config/create")
|
|
assert.NotNil(t, call)
|
|
in := rc.Params{
|
|
"name": testName,
|
|
"type": "local",
|
|
"parameters": rc.Params{
|
|
"test_key": "sausage",
|
|
},
|
|
}
|
|
out, err := call.Fn(ctx, in)
|
|
require.NoError(t, err)
|
|
require.Nil(t, out)
|
|
assert.Equal(t, "local", config.FileGet(testName, "type"))
|
|
assert.Equal(t, "sausage", config.FileGet(testName, "test_key"))
|
|
|
|
// The sub tests rely on the remote created above but they can
|
|
// all be run independently
|
|
|
|
t.Run("Dump", func(t *testing.T) {
|
|
call := rc.Calls.Get("config/dump")
|
|
assert.NotNil(t, call)
|
|
in := rc.Params{}
|
|
out, err := call.Fn(context.Background(), in)
|
|
require.NoError(t, err)
|
|
require.NotNil(t, out)
|
|
|
|
require.NotNil(t, out[testName])
|
|
config := out[testName].(rc.Params)
|
|
|
|
assert.Equal(t, "local", config["type"])
|
|
assert.Equal(t, "sausage", config["test_key"])
|
|
})
|
|
|
|
t.Run("Get", func(t *testing.T) {
|
|
call := rc.Calls.Get("config/get")
|
|
assert.NotNil(t, call)
|
|
in := rc.Params{
|
|
"name": testName,
|
|
}
|
|
out, err := call.Fn(context.Background(), in)
|
|
require.NoError(t, err)
|
|
require.NotNil(t, out)
|
|
|
|
assert.Equal(t, "local", out["type"])
|
|
assert.Equal(t, "sausage", out["test_key"])
|
|
})
|
|
|
|
t.Run("ListRemotes", func(t *testing.T) {
|
|
assert.NoError(t, os.Setenv("RCLONE_CONFIG_MY-LOCAL_TYPE", "local"))
|
|
defer func() {
|
|
assert.NoError(t, os.Unsetenv("RCLONE_CONFIG_MY-LOCAL_TYPE"))
|
|
}()
|
|
call := rc.Calls.Get("config/listremotes")
|
|
assert.NotNil(t, call)
|
|
in := rc.Params{}
|
|
out, err := call.Fn(context.Background(), in)
|
|
require.NoError(t, err)
|
|
require.NotNil(t, out)
|
|
|
|
var remotes []string
|
|
err = out.GetStruct("remotes", &remotes)
|
|
require.NoError(t, err)
|
|
|
|
assert.Contains(t, remotes, testName)
|
|
assert.Contains(t, remotes, "my-local")
|
|
})
|
|
|
|
t.Run("Update", func(t *testing.T) {
|
|
call := rc.Calls.Get("config/update")
|
|
assert.NotNil(t, call)
|
|
in := rc.Params{
|
|
"name": testName,
|
|
"parameters": rc.Params{
|
|
"test_key": "rutabaga",
|
|
"test_key2": "cabbage",
|
|
},
|
|
}
|
|
out, err := call.Fn(context.Background(), in)
|
|
require.NoError(t, err)
|
|
assert.Nil(t, out)
|
|
|
|
assert.Equal(t, "local", config.FileGet(testName, "type"))
|
|
assert.Equal(t, "rutabaga", config.FileGet(testName, "test_key"))
|
|
assert.Equal(t, "cabbage", config.FileGet(testName, "test_key2"))
|
|
})
|
|
|
|
t.Run("Password", func(t *testing.T) {
|
|
call := rc.Calls.Get("config/password")
|
|
assert.NotNil(t, call)
|
|
pw2 := obscure.MustObscure("password")
|
|
in := rc.Params{
|
|
"name": testName,
|
|
"parameters": rc.Params{
|
|
"test_key": "rutabaga",
|
|
"test_key2": pw2, // check we encode an already encoded password
|
|
},
|
|
}
|
|
out, err := call.Fn(context.Background(), in)
|
|
require.NoError(t, err)
|
|
assert.Nil(t, out)
|
|
|
|
assert.Equal(t, "local", config.FileGet(testName, "type"))
|
|
assert.Equal(t, "rutabaga", obscure.MustReveal(config.FileGet(testName, "test_key")))
|
|
assert.Equal(t, pw2, obscure.MustReveal(config.FileGet(testName, "test_key2")))
|
|
})
|
|
|
|
// Delete the test remote
|
|
call = rc.Calls.Get("config/delete")
|
|
assert.NotNil(t, call)
|
|
in = rc.Params{
|
|
"name": testName,
|
|
}
|
|
out, err = call.Fn(context.Background(), in)
|
|
require.NoError(t, err)
|
|
assert.Nil(t, out)
|
|
assert.Equal(t, "", config.FileGet(testName, "type"))
|
|
assert.Equal(t, "", config.FileGet(testName, "test_key"))
|
|
}
|
|
|
|
func TestRcProviders(t *testing.T) {
|
|
call := rc.Calls.Get("config/providers")
|
|
assert.NotNil(t, call)
|
|
in := rc.Params{}
|
|
out, err := call.Fn(context.Background(), in)
|
|
require.NoError(t, err)
|
|
require.NotNil(t, out)
|
|
var registry []*fs.RegInfo
|
|
err = out.GetStruct("providers", ®istry)
|
|
require.NoError(t, err)
|
|
foundLocal := false
|
|
for _, provider := range registry {
|
|
if provider.Name == "local" {
|
|
foundLocal = true
|
|
break
|
|
}
|
|
}
|
|
assert.True(t, foundLocal, "didn't find local provider")
|
|
}
|
|
|
|
func TestRcSetPath(t *testing.T) {
|
|
oldPath := config.GetConfigPath()
|
|
newPath := oldPath + ".newPath"
|
|
call := rc.Calls.Get("config/setpath")
|
|
assert.NotNil(t, call)
|
|
in := rc.Params{
|
|
"path": newPath,
|
|
}
|
|
_, err := call.Fn(context.Background(), in)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, newPath, config.GetConfigPath())
|
|
|
|
in["path"] = oldPath
|
|
_, err = call.Fn(context.Background(), in)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, oldPath, config.GetConfigPath())
|
|
}
|