2024-04-03 08:14:04 +00:00
|
|
|
package auth
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2025-01-07 10:49:23 +00:00
|
|
|
"errors"
|
2024-04-03 08:14:04 +00:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/databricks/cli/cmd/root"
|
|
|
|
"github.com/databricks/databricks-sdk-go/config"
|
|
|
|
"github.com/databricks/databricks-sdk-go/experimental/mocks"
|
|
|
|
"github.com/databricks/databricks-sdk-go/service/iam"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"github.com/stretchr/testify/mock"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestGetWorkspaceAuthStatus(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
m := mocks.NewMockWorkspaceClient(t)
|
|
|
|
ctx = root.SetWorkspaceClient(ctx, m.WorkspaceClient)
|
|
|
|
|
|
|
|
cmd := &cobra.Command{}
|
|
|
|
cmd.SetContext(ctx)
|
|
|
|
|
|
|
|
showSensitive := false
|
|
|
|
|
|
|
|
currentUserApi := m.GetMockCurrentUserAPI()
|
|
|
|
currentUserApi.EXPECT().Me(mock.Anything).Return(&iam.User{
|
|
|
|
UserName: "test-user",
|
|
|
|
}, nil)
|
|
|
|
|
|
|
|
cmd.Flags().String("host", "", "")
|
|
|
|
cmd.Flags().String("profile", "", "")
|
|
|
|
err := cmd.Flag("profile").Value.Set("my-profile")
|
|
|
|
require.NoError(t, err)
|
|
|
|
cmd.Flag("profile").Changed = true
|
|
|
|
|
|
|
|
cfg := &config.Config{
|
|
|
|
Profile: "my-profile",
|
|
|
|
}
|
|
|
|
m.WorkspaceClient.Config = cfg
|
|
|
|
t.Setenv("DATABRICKS_AUTH_TYPE", "azure-cli")
|
|
|
|
err = config.ConfigAttributes.Configure(cfg)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
status, err := getAuthStatus(cmd, []string{}, showSensitive, func(cmd *cobra.Command, args []string) (*config.Config, bool, error) {
|
|
|
|
err := config.ConfigAttributes.ResolveFromStringMap(cfg, map[string]string{
|
|
|
|
"host": "https://test.com",
|
|
|
|
"token": "test-token",
|
|
|
|
"auth_type": "azure-cli",
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
return cfg, false, nil
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotNil(t, status)
|
|
|
|
require.Equal(t, "success", status.Status)
|
|
|
|
require.Equal(t, "test-user", status.Username)
|
|
|
|
require.Equal(t, "https://test.com", status.Details.Host)
|
|
|
|
require.Equal(t, "azure-cli", status.Details.AuthType)
|
|
|
|
|
|
|
|
require.Equal(t, "azure-cli", status.Details.Configuration["auth_type"].Value)
|
|
|
|
require.Equal(t, "DATABRICKS_AUTH_TYPE environment variable", status.Details.Configuration["auth_type"].Source.String())
|
|
|
|
require.False(t, status.Details.Configuration["auth_type"].AuthTypeMismatch)
|
|
|
|
|
|
|
|
require.Equal(t, "********", status.Details.Configuration["token"].Value)
|
|
|
|
require.Equal(t, "dynamic configuration", status.Details.Configuration["token"].Source.String())
|
|
|
|
require.True(t, status.Details.Configuration["token"].AuthTypeMismatch)
|
|
|
|
|
|
|
|
require.Equal(t, "my-profile", status.Details.Configuration["profile"].Value)
|
|
|
|
require.Equal(t, "--profile flag", status.Details.Configuration["profile"].Source.String())
|
|
|
|
require.False(t, status.Details.Configuration["profile"].AuthTypeMismatch)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetWorkspaceAuthStatusError(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
m := mocks.NewMockWorkspaceClient(t)
|
|
|
|
ctx = root.SetWorkspaceClient(ctx, m.WorkspaceClient)
|
|
|
|
|
|
|
|
cmd := &cobra.Command{}
|
|
|
|
cmd.SetContext(ctx)
|
|
|
|
|
|
|
|
showSensitive := false
|
|
|
|
|
|
|
|
cmd.Flags().String("host", "", "")
|
|
|
|
cmd.Flags().String("profile", "", "")
|
|
|
|
err := cmd.Flag("profile").Value.Set("my-profile")
|
|
|
|
require.NoError(t, err)
|
|
|
|
cmd.Flag("profile").Changed = true
|
|
|
|
|
|
|
|
cfg := &config.Config{
|
|
|
|
Profile: "my-profile",
|
|
|
|
}
|
|
|
|
m.WorkspaceClient.Config = cfg
|
|
|
|
t.Setenv("DATABRICKS_AUTH_TYPE", "azure-cli")
|
|
|
|
err = config.ConfigAttributes.Configure(cfg)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
status, err := getAuthStatus(cmd, []string{}, showSensitive, func(cmd *cobra.Command, args []string) (*config.Config, bool, error) {
|
|
|
|
err = config.ConfigAttributes.ResolveFromStringMap(cfg, map[string]string{
|
|
|
|
"host": "https://test.com",
|
|
|
|
"token": "test-token",
|
|
|
|
"auth_type": "azure-cli",
|
|
|
|
})
|
2025-01-07 10:49:23 +00:00
|
|
|
return cfg, false, errors.New("auth error")
|
2024-04-03 08:14:04 +00:00
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotNil(t, status)
|
|
|
|
require.Equal(t, "error", status.Status)
|
|
|
|
|
|
|
|
require.Equal(t, "azure-cli", status.Details.Configuration["auth_type"].Value)
|
|
|
|
require.Equal(t, "DATABRICKS_AUTH_TYPE environment variable", status.Details.Configuration["auth_type"].Source.String())
|
|
|
|
require.False(t, status.Details.Configuration["auth_type"].AuthTypeMismatch)
|
|
|
|
|
|
|
|
require.Equal(t, "********", status.Details.Configuration["token"].Value)
|
|
|
|
require.Equal(t, "dynamic configuration", status.Details.Configuration["token"].Source.String())
|
|
|
|
require.True(t, status.Details.Configuration["token"].AuthTypeMismatch)
|
|
|
|
|
|
|
|
require.Equal(t, "my-profile", status.Details.Configuration["profile"].Value)
|
|
|
|
require.Equal(t, "--profile flag", status.Details.Configuration["profile"].Source.String())
|
|
|
|
require.False(t, status.Details.Configuration["profile"].AuthTypeMismatch)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetWorkspaceAuthStatusSensitive(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
m := mocks.NewMockWorkspaceClient(t)
|
|
|
|
ctx = root.SetWorkspaceClient(ctx, m.WorkspaceClient)
|
|
|
|
|
|
|
|
cmd := &cobra.Command{}
|
|
|
|
cmd.SetContext(ctx)
|
|
|
|
|
|
|
|
showSensitive := true
|
|
|
|
|
|
|
|
cmd.Flags().String("host", "", "")
|
|
|
|
cmd.Flags().String("profile", "", "")
|
|
|
|
err := cmd.Flag("profile").Value.Set("my-profile")
|
|
|
|
require.NoError(t, err)
|
|
|
|
cmd.Flag("profile").Changed = true
|
|
|
|
|
|
|
|
cfg := &config.Config{
|
|
|
|
Profile: "my-profile",
|
|
|
|
}
|
|
|
|
m.WorkspaceClient.Config = cfg
|
|
|
|
t.Setenv("DATABRICKS_AUTH_TYPE", "azure-cli")
|
|
|
|
err = config.ConfigAttributes.Configure(cfg)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
status, err := getAuthStatus(cmd, []string{}, showSensitive, func(cmd *cobra.Command, args []string) (*config.Config, bool, error) {
|
|
|
|
err = config.ConfigAttributes.ResolveFromStringMap(cfg, map[string]string{
|
|
|
|
"host": "https://test.com",
|
|
|
|
"token": "test-token",
|
|
|
|
"auth_type": "azure-cli",
|
|
|
|
})
|
2025-01-07 10:49:23 +00:00
|
|
|
return cfg, false, errors.New("auth error")
|
2024-04-03 08:14:04 +00:00
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotNil(t, status)
|
|
|
|
require.Equal(t, "error", status.Status)
|
|
|
|
|
|
|
|
require.Equal(t, "azure-cli", status.Details.Configuration["auth_type"].Value)
|
|
|
|
require.Equal(t, "DATABRICKS_AUTH_TYPE environment variable", status.Details.Configuration["auth_type"].Source.String())
|
|
|
|
require.False(t, status.Details.Configuration["auth_type"].AuthTypeMismatch)
|
|
|
|
|
|
|
|
require.Equal(t, "test-token", status.Details.Configuration["token"].Value)
|
|
|
|
require.Equal(t, "dynamic configuration", status.Details.Configuration["token"].Source.String())
|
|
|
|
require.True(t, status.Details.Configuration["token"].AuthTypeMismatch)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetAccountAuthStatus(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
m := mocks.NewMockAccountClient(t)
|
|
|
|
ctx = root.SetAccountClient(ctx, m.AccountClient)
|
|
|
|
|
|
|
|
cmd := &cobra.Command{}
|
|
|
|
cmd.SetContext(ctx)
|
|
|
|
|
|
|
|
showSensitive := false
|
|
|
|
|
|
|
|
cmd.Flags().String("host", "", "")
|
|
|
|
cmd.Flags().String("profile", "", "")
|
|
|
|
err := cmd.Flag("profile").Value.Set("my-profile")
|
|
|
|
require.NoError(t, err)
|
|
|
|
cmd.Flag("profile").Changed = true
|
|
|
|
|
|
|
|
cfg := &config.Config{
|
|
|
|
Profile: "my-profile",
|
|
|
|
}
|
|
|
|
m.AccountClient.Config = cfg
|
|
|
|
t.Setenv("DATABRICKS_AUTH_TYPE", "azure-cli")
|
|
|
|
err = config.ConfigAttributes.Configure(cfg)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
wsApi := m.GetMockWorkspacesAPI()
|
|
|
|
wsApi.EXPECT().List(mock.Anything).Return(nil, nil)
|
|
|
|
|
|
|
|
status, err := getAuthStatus(cmd, []string{}, showSensitive, func(cmd *cobra.Command, args []string) (*config.Config, bool, error) {
|
|
|
|
err = config.ConfigAttributes.ResolveFromStringMap(cfg, map[string]string{
|
|
|
|
"account_id": "test-account-id",
|
|
|
|
"username": "test-user",
|
|
|
|
"host": "https://test.com",
|
|
|
|
"token": "test-token",
|
|
|
|
"auth_type": "azure-cli",
|
|
|
|
})
|
|
|
|
return cfg, true, nil
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotNil(t, status)
|
|
|
|
require.Equal(t, "success", status.Status)
|
|
|
|
|
|
|
|
require.Equal(t, "test-user", status.Username)
|
|
|
|
require.Equal(t, "https://test.com", status.Details.Host)
|
|
|
|
require.Equal(t, "azure-cli", status.Details.AuthType)
|
|
|
|
require.Equal(t, "test-account-id", status.AccountID)
|
|
|
|
|
|
|
|
require.Equal(t, "azure-cli", status.Details.Configuration["auth_type"].Value)
|
|
|
|
require.Equal(t, "DATABRICKS_AUTH_TYPE environment variable", status.Details.Configuration["auth_type"].Source.String())
|
|
|
|
require.False(t, status.Details.Configuration["auth_type"].AuthTypeMismatch)
|
|
|
|
|
|
|
|
require.Equal(t, "********", status.Details.Configuration["token"].Value)
|
|
|
|
require.Equal(t, "dynamic configuration", status.Details.Configuration["token"].Source.String())
|
|
|
|
require.True(t, status.Details.Configuration["token"].AuthTypeMismatch)
|
|
|
|
|
|
|
|
require.Equal(t, "my-profile", status.Details.Configuration["profile"].Value)
|
|
|
|
require.Equal(t, "--profile flag", status.Details.Configuration["profile"].Source.String())
|
|
|
|
require.False(t, status.Details.Configuration["profile"].AuthTypeMismatch)
|
|
|
|
}
|