Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add vtctldclient missing cmds and remove remaining vtctl[client] usage in e2e tests #17442

Open
wants to merge 37 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
b2c696d
Add missing TopoCp replacement
mattlord Dec 26, 2024
45dd233
Add CopySchemaShard
mattlord Dec 26, 2024
0e3a8e1
Add ValidateSchemaShard
mattlord Dec 27, 2024
851ccac
Add missing permissions commands
mattlord Dec 27, 2024
05c4c1d
Fixups
mattlord Dec 27, 2024
a091042
Remove CopySchemaShard
mattlord Dec 28, 2024
2ef4690
Revert "Remove CopySchemaShard"
mattlord Dec 31, 2024
f5fcd6c
Start work on CopySchemaShard
mattlord Dec 31, 2024
84d5bdd
Testing and fixing
mattlord Jan 1, 2025
6d8ef71
Topology cmd option cleanup
mattlord Jan 1, 2025
f6da213
Correct vtctldclient --help output
mattlord Jan 1, 2025
02f93a2
Align old and new client resp handling
mattlord Jan 1, 2025
065fd01
Remove unneded call
mattlord Jan 1, 2025
f0047fa
Minor changes from self review
mattlord Jan 1, 2025
24fdf41
Changes from further testing
mattlord Jan 2, 2025
64b9576
Merge remote-tracking branch 'origin/main' into vtctldclient_missing_…
mattlord Jan 2, 2025
f75ed39
Remove and replace all remaining vtctl[client] usage
mattlord Jan 2, 2025
d817b3c
Fix cell bootstrapping
mattlord Jan 2, 2025
efdefd7
Replace remaining usage of VtctlProcess
mattlord Jan 2, 2025
4ec0dc1
Fix vtctldclient creation
mattlord Jan 2, 2025
49e70b1
Fix SecureTransport test
mattlord Jan 2, 2025
6e4a4b0
Fix tabletmanager tests
mattlord Jan 2, 2025
ca1064b
Remove "--" args
mattlord Jan 2, 2025
7b213c3
Update --help output
mattlord Jan 2, 2025
0d136d4
Fix migrate tests
mattlord Jan 2, 2025
8d8b3b4
Fix unit test
mattlord Jan 2, 2025
1cb43c5
Fix vtgate/reference test
mattlord Jan 3, 2025
8f66a9f
Fix ERS test
mattlord Jan 3, 2025
e1832b2
Fix backup tests
mattlord Jan 3, 2025
e89ca17
Changes from self review
mattlord Jan 3, 2025
2de0bcf
Merge remote-tracking branch 'origin/main' into vtctldclient_missing_…
mattlord Jan 11, 2025
2e4cd37
Update vtctldclient help text
mattlord Jan 16, 2025
096b292
Merge remote-tracking branch 'origin/main' into vtctldclient_missing_…
mattlord Jan 16, 2025
60fca3a
Add unit tests for permissions commands
mattlord Jan 17, 2025
1073206
Reorgnaize the permissions tests
mattlord Jan 17, 2025
afbeb6b
Update copyright year on new files
mattlord Jan 17, 2025
78ca3e0
Fix TestRootWithInternalVtctld
mattlord Jan 17, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
49 changes: 1 addition & 48 deletions go/cmd/vtctldclient/command/keyspaces.go
Original file line number Diff line number Diff line change
Expand Up @@ -109,19 +109,10 @@ SetKeyspaceDurabilityPolicy --durability-policy='semi_sync' customer`,
Args: cobra.ExactArgs(1),
RunE: commandSetKeyspaceDurabilityPolicy,
}
// ValidateSchemaKeyspace makes a ValidateSchemaKeyspace gRPC call to a vtctld.
ValidateSchemaKeyspace = &cobra.Command{
Use: "ValidateSchemaKeyspace [--exclude-tables=<exclude_tables>] [--include-views] [--skip-no-primary] [--include-vschema] <keyspace>",
Short: "Validates that the schema on the primary tablet for shard 0 matches the schema on all other tablets in the keyspace.",
DisableFlagsInUseLine: true,
Aliases: []string{"validateschemakeyspace"},
Args: cobra.ExactArgs(1),
RunE: commandValidateSchemaKeyspace,
}
// ValidateVersionKeyspace makes a ValidateVersionKeyspace gRPC call to a vtctld.
ValidateVersionKeyspace = &cobra.Command{
Use: "ValidateVersionKeyspace <keyspace>",
Short: "Validates that the version on the primary tablet of shard 0 matches all of the other tablets in the keyspace.",
Short: "Validates that the version on the primary tablet of the first shard matches all of the other tablets in the keyspace.",
DisableFlagsInUseLine: true,
Aliases: []string{"validateversionkeyspace"},
Args: cobra.ExactArgs(1),
Expand Down Expand Up @@ -350,38 +341,6 @@ func commandSetKeyspaceDurabilityPolicy(cmd *cobra.Command, args []string) error
return nil
}

var validateSchemaKeyspaceOptions = struct {
ExcludeTables []string
IncludeViews bool
SkipNoPrimary bool
IncludeVSchema bool
}{}

func commandValidateSchemaKeyspace(cmd *cobra.Command, args []string) error {
cli.FinishedParsing(cmd)

ks := cmd.Flags().Arg(0)
resp, err := client.ValidateSchemaKeyspace(commandCtx, &vtctldatapb.ValidateSchemaKeyspaceRequest{
Keyspace: ks,
ExcludeTables: validateSchemaKeyspaceOptions.ExcludeTables,
IncludeVschema: validateSchemaKeyspaceOptions.IncludeVSchema,
SkipNoPrimary: validateSchemaKeyspaceOptions.SkipNoPrimary,
IncludeViews: validateSchemaKeyspaceOptions.IncludeViews,
})

if err != nil {
return err
}

data, err := cli.MarshalJSON(resp)
if err != nil {
return err
}

fmt.Printf("%s\n", data)
return nil
}

func commandValidateVersionKeyspace(cmd *cobra.Command, args []string) error {
cli.FinishedParsing(cmd)

Expand Down Expand Up @@ -428,11 +387,5 @@ func init() {
SetKeyspaceDurabilityPolicy.Flags().StringVar(&setKeyspaceDurabilityPolicyOptions.DurabilityPolicy, "durability-policy", "none", "Type of durability to enforce for this keyspace. Default is none. Other values include 'semi_sync' and others as dictated by registered plugins.")
Root.AddCommand(SetKeyspaceDurabilityPolicy)

ValidateSchemaKeyspace.Flags().BoolVar(&validateSchemaKeyspaceOptions.IncludeViews, "include-views", false, "Includes views in compared schemas.")
ValidateSchemaKeyspace.Flags().BoolVar(&validateSchemaKeyspaceOptions.IncludeVSchema, "include-vschema", false, "Includes VSchema validation in validation results.")
ValidateSchemaKeyspace.Flags().BoolVar(&validateSchemaKeyspaceOptions.SkipNoPrimary, "skip-no-primary", false, "Skips validation on whether or not a primary exists in shards.")
ValidateSchemaKeyspace.Flags().StringSliceVar(&validateSchemaKeyspaceOptions.ExcludeTables, "exclude-tables", []string{}, "Tables to exclude during schema comparison.")
Root.AddCommand(ValidateSchemaKeyspace)

Root.AddCommand(ValidateVersionKeyspace)
}
110 changes: 110 additions & 0 deletions go/cmd/vtctldclient/command/permissions.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
/*
Copyright 2024 The Vitess Authors.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

package command

import (
"fmt"

"github.com/spf13/cobra"

"vitess.io/vitess/go/cmd/vtctldclient/cli"
"vitess.io/vitess/go/vt/topo/topoproto"

vtctldatapb "vitess.io/vitess/go/vt/proto/vtctldata"
)

var (
// GetPermissions makes a GetPermissions gRPC call to a vtctld.
GetPermissions = &cobra.Command{
Use: "GetPermissions <tablet_alias>",
Short: "Displays the permissions for a tablet.",
DisableFlagsInUseLine: true,
Args: cobra.ExactArgs(1),
RunE: commandGetPermissions,
}
ValidatePermissionsShard = &cobra.Command{
Use: "ValidatePermissionsShard <keyspace/shard>",
Short: "Validates that the permissions on primary match all the replicas.",
DisableFlagsInUseLine: true,
Args: cobra.ExactArgs(1),
RunE: commandValidatePermissionsShard,
}
ValidatePermissionsKeyspace = &cobra.Command{
Use: "ValidatePermissionsKeyspace <keyspace name>",
Short: "Validates that the permissions on primary of the first shard match those of all of the other tablets in the keyspace.",
DisableFlagsInUseLine: true,
Args: cobra.ExactArgs(1),
RunE: commandValidatePermissionsKeyspace,
}
)

func commandGetPermissions(cmd *cobra.Command, args []string) error {
alias, err := topoproto.ParseTabletAlias(cmd.Flags().Arg(0))
if err != nil {
return err
}

cli.FinishedParsing(cmd)

resp, err := client.GetPermissions(commandCtx, &vtctldatapb.GetPermissionsRequest{
TabletAlias: alias,
})
if err != nil {
return err
}
p, err := cli.MarshalJSON(resp.Permissions)
if err != nil {
return err
}
fmt.Printf("%s\n", p)

return nil
}

func commandValidatePermissionsKeyspace(cmd *cobra.Command, args []string) error {
keyspace := cmd.Flags().Arg(0)

cli.FinishedParsing(cmd)

_, err := client.ValidatePermissionsKeyspace(commandCtx, &vtctldatapb.ValidatePermissionsKeyspaceRequest{
Keyspace: keyspace,
})

return err
}

func commandValidatePermissionsShard(cmd *cobra.Command, args []string) error {
keyspace, shard, err := topoproto.ParseKeyspaceShard(cmd.Flags().Arg(0))
if err != nil {
return err
}

cli.FinishedParsing(cmd)

_, err = client.ValidatePermissionsKeyspace(commandCtx, &vtctldatapb.ValidatePermissionsKeyspaceRequest{
Keyspace: keyspace,
Shards: []string{shard},
})

return err
}

func init() {
Root.AddCommand(GetPermissions)
Root.AddCommand(ValidatePermissionsKeyspace)
Root.AddCommand(ValidatePermissionsShard)
}
101 changes: 97 additions & 4 deletions go/cmd/vtctldclient/command/schema.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ import (
"vitess.io/vitess/go/vt/vtctl/grpcvtctldserver"

vtctldatapb "vitess.io/vitess/go/vt/proto/vtctldata"
"vitess.io/vitess/go/vt/proto/vtrpc"
vtrpcpb "vitess.io/vitess/go/vt/proto/vtrpc"
)

var (
Expand Down Expand Up @@ -90,6 +90,25 @@ For --sql, semi-colons and repeated values may be mixed, for example:
Args: cobra.ExactArgs(1),
RunE: commandReloadSchemaShard,
}
// ValidateSchemaKeyspace makes a ValidateSchemaKeyspace gRPC call to a vtctld.
ValidateSchemaKeyspace = &cobra.Command{
Use: "ValidateSchemaKeyspace [--exclude-tables=<exclude_tables>] [--include-views] [--skip-no-primary] [--include-vschema] <keyspace>",
Short: "Validates that the schema on the primary tablet for the first shard matches the schema on all other tablets in the keyspace.",
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Short: "Validates that the schema on the primary tablet for the first shard matches the schema on all other tablets in the keyspace.",
Short: "Validates that the schema on the primary tablet for the first shard matches the schema on all other shards in the keyspace.",

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I copied the text from the legacy client, and the server code actually does compare against all tablets.

DisableFlagsInUseLine: true,
Aliases: []string{"validateschemakeyspace"},
Args: cobra.ExactArgs(1),
RunE: commandValidateSchemaKeyspace,
}
// ValidateSchemaShard makes a ValidateSchemaKeyspace gRPC call to a vtctld WITH
// 1 specific shard to examine in the keyspace.
ValidateSchemaShard = &cobra.Command{
Use: "ValidateSchemaShard [--exclude-tables=<exclude_tables>] [--include-views] [--skip-no-primary] [--include-vschema] <keyspace/shard>",
Short: "Validates that the schema on the primary tablet for the specified shard matches the schema on all other tablets in that shard.",
DisableFlagsInUseLine: true,
Aliases: []string{"validateschemashard"},
Args: cobra.ExactArgs(1),
RunE: commandValidateSchemaShard,
}
)

var applySchemaOptions = struct {
Expand Down Expand Up @@ -129,9 +148,9 @@ func commandApplySchema(cmd *cobra.Command, args []string) error {

cli.FinishedParsing(cmd)

var cid *vtrpc.CallerID
var cid *vtrpcpb.CallerID
if applySchemaOptions.CallerID != "" {
cid = &vtrpc.CallerID{Principal: applySchemaOptions.CallerID}
cid = &vtrpcpb.CallerID{Principal: applySchemaOptions.CallerID}
}

ks := cmd.Flags().Arg(0)
Expand Down Expand Up @@ -284,6 +303,69 @@ func commandReloadSchemaShard(cmd *cobra.Command, args []string) error {
return err
}

var validateSchemaKeyspaceOptions = struct {
ExcludeTables []string
IncludeViews bool
SkipNoPrimary bool
IncludeVSchema bool
Shard string
}{}

func commandValidateSchemaKeyspace(cmd *cobra.Command, args []string) error {
cli.FinishedParsing(cmd)

ks := cmd.Flags().Arg(0)
resp, err := client.ValidateSchemaKeyspace(commandCtx, &vtctldatapb.ValidateSchemaKeyspaceRequest{
Keyspace: ks,
ExcludeTables: validateSchemaKeyspaceOptions.ExcludeTables,
IncludeVschema: validateSchemaKeyspaceOptions.IncludeVSchema,
SkipNoPrimary: validateSchemaKeyspaceOptions.SkipNoPrimary,
IncludeViews: validateSchemaKeyspaceOptions.IncludeViews,
})

if err != nil {
return err
}

data, err := cli.MarshalJSON(resp)
if err != nil {
return err
}

fmt.Printf("%s\n", data)
return nil
}

func commandValidateSchemaShard(cmd *cobra.Command, args []string) error {
keyspace, shard, err := topoproto.ParseKeyspaceShard(cmd.Flags().Arg(0))
if err != nil {
return err
}

cli.FinishedParsing(cmd)

resp, err := client.ValidateSchemaKeyspace(commandCtx, &vtctldatapb.ValidateSchemaKeyspaceRequest{
Keyspace: keyspace,
Shards: []string{shard},
ExcludeTables: validateSchemaKeyspaceOptions.ExcludeTables,
IncludeVschema: validateSchemaKeyspaceOptions.IncludeVSchema,
SkipNoPrimary: validateSchemaKeyspaceOptions.SkipNoPrimary,
IncludeViews: validateSchemaKeyspaceOptions.IncludeViews,
})

if err != nil {
return err
}

data, err := cli.MarshalJSON(resp)
if err != nil {
return err
}

fmt.Printf("%s\n", data)
return nil
}

func init() {
ApplySchema.Flags().StringVar(&applySchemaOptions.DDLStrategy, "ddl-strategy", string(schema.DDLStrategyDirect), "Online DDL strategy, compatible with @@ddl_strategy session variable (examples: 'gh-ost', 'pt-osc', 'gh-ost --max-load=Threads_running=100'.")
ApplySchema.Flags().StringSliceVar(&applySchemaOptions.UUIDList, "uuid", nil, "Optional, comma-delimited, repeatable, explicit UUIDs for migration. If given, must match number of DDL changes.")
Expand All @@ -293,7 +375,6 @@ func init() {
ApplySchema.Flags().StringArrayVar(&applySchemaOptions.SQL, "sql", nil, "Semicolon-delimited, repeatable SQL commands to apply. Exactly one of --sql|--sql-file is required.")
ApplySchema.Flags().StringVar(&applySchemaOptions.SQLFile, "sql-file", "", "Path to a file containing semicolon-delimited SQL commands to apply. Exactly one of --sql|--sql-file is required.")
ApplySchema.Flags().Int64Var(&applySchemaOptions.BatchSize, "batch-size", 0, "How many queries to batch together. Only applicable when all queries are CREATE TABLE|VIEW")

Root.AddCommand(ApplySchema)

GetSchema.Flags().StringSliceVar(&getSchemaOptions.Tables, "tables", nil, "List of tables to display the schema for. Each is either an exact match, or a regular expression of the form `/regexp/`.")
Expand All @@ -314,4 +395,16 @@ func init() {
ReloadSchemaShard.Flags().Int32Var(&reloadSchemaShardOptions.Concurrency, "concurrency", 10, "Number of tablets to reload in parallel. Set to zero for unbounded concurrency.")
ReloadSchemaShard.Flags().BoolVar(&reloadSchemaShardOptions.IncludePrimary, "include-primary", false, "Also reload the primary tablet.")
Root.AddCommand(ReloadSchemaShard)

ValidateSchemaKeyspace.Flags().BoolVar(&validateSchemaKeyspaceOptions.IncludeViews, "include-views", false, "Includes views in compared schemas.")
ValidateSchemaKeyspace.Flags().BoolVar(&validateSchemaKeyspaceOptions.IncludeVSchema, "include-vschema", false, "Includes VSchema validation in validation results.")
ValidateSchemaKeyspace.Flags().BoolVar(&validateSchemaKeyspaceOptions.SkipNoPrimary, "skip-no-primary", false, "Skips validation on whether or not a primary exists in shards.")
ValidateSchemaKeyspace.Flags().StringSliceVar(&validateSchemaKeyspaceOptions.ExcludeTables, "exclude-tables", []string{}, "Tables to exclude during schema comparison.")
Root.AddCommand(ValidateSchemaKeyspace)

ValidateSchemaShard.Flags().BoolVar(&validateSchemaKeyspaceOptions.IncludeViews, "include-views", false, "Includes views in compared schemas.")
ValidateSchemaShard.Flags().BoolVar(&validateSchemaKeyspaceOptions.IncludeVSchema, "include-vschema", false, "Includes VSchema validation in validation results.")
ValidateSchemaShard.Flags().BoolVar(&validateSchemaKeyspaceOptions.SkipNoPrimary, "skip-no-primary", false, "Skips validation on whether or not a primary exists in shards.")
ValidateSchemaShard.Flags().StringSliceVar(&validateSchemaKeyspaceOptions.ExcludeTables, "exclude-tables", []string{}, "Tables to exclude during schema comparison.")
Root.AddCommand(ValidateSchemaShard)
}
32 changes: 0 additions & 32 deletions go/cmd/vtctldclient/command/tablets.go
Original file line number Diff line number Diff line change
Expand Up @@ -92,14 +92,6 @@ Note: hook names may not contain slash (/) characters.
Args: cobra.ExactArgs(1),
RunE: commandGetFullStatus,
}
// GetPermissions makes a GetPermissions gRPC call to a vtctld.
GetPermissions = &cobra.Command{
Use: "GetPermissions <tablet_alias>",
Short: "Displays the permissions for a tablet.",
DisableFlagsInUseLine: true,
Args: cobra.ExactArgs(1),
RunE: commandGetPermissions,
}
// GetTablet makes a GetTablet gRPC call to a vtctld.
GetTablet = &cobra.Command{
Use: "GetTablet <alias>",
Expand Down Expand Up @@ -380,29 +372,6 @@ func commandGetFullStatus(cmd *cobra.Command, args []string) error {
return nil
}

func commandGetPermissions(cmd *cobra.Command, args []string) error {
alias, err := topoproto.ParseTabletAlias(cmd.Flags().Arg(0))
if err != nil {
return err
}

cli.FinishedParsing(cmd)

resp, err := client.GetPermissions(commandCtx, &vtctldatapb.GetPermissionsRequest{
TabletAlias: alias,
})
if err != nil {
return err
}
p, err := cli.MarshalJSON(resp.Permissions)
if err != nil {
return err
}
fmt.Printf("%s\n", p)

return nil
}

func commandGetTablet(cmd *cobra.Command, args []string) error {
aliasStr := cmd.Flags().Arg(0)
alias, err := topoproto.ParseTabletAlias(aliasStr)
Expand Down Expand Up @@ -685,7 +654,6 @@ func init() {

Root.AddCommand(ExecuteHook)
Root.AddCommand(GetFullStatus)
Root.AddCommand(GetPermissions)
Root.AddCommand(GetTablet)

GetTablets.Flags().StringSliceVarP(&getTabletsOptions.TabletAliasStrings, "tablet-alias", "t", nil, "List of tablet aliases to filter by.")
Expand Down
Loading
Loading