This is an automated email from the ASF dual-hosted git repository. jmclean pushed a commit to branch main in repository https://gitbox.apache.org/repos/asf/gravitino.git
The following commit(s) were added to refs/heads/main by this push: new 734993e1bf [#6423] improve(CLI): Add tags command context CLI (#6435) 734993e1bf is described below commit 734993e1bf70fbba18deabf92347dd833556b2d8 Author: Lord of Abyss <103809695+abyss-l...@users.noreply.github.com> AuthorDate: Wed Feb 12 07:32:18 2025 +0800 [#6423] improve(CLI): Add tags command context CLI (#6435) ### What changes were proposed in this pull request? Add tags command context CLI ### Why are the changes needed? Fix: #6423 ### Does this PR introduce _any_ user-facing change? No ### How was this patch tested? local test --- .../apache/gravitino/cli/GravitinoCommandLine.java | 2 +- .../apache/gravitino/cli/TagCommandHandler.java | 43 +++-- .../apache/gravitino/cli/TestableCommandLine.java | 54 +++---- .../apache/gravitino/cli/commands/CreateTag.java | 15 +- .../apache/gravitino/cli/commands/DeleteTag.java | 22 ++- .../apache/gravitino/cli/commands/ListAllTags.java | 16 +- .../gravitino/cli/commands/ListEntityTags.java | 10 +- .../gravitino/cli/commands/ListTagProperties.java | 8 +- .../gravitino/cli/commands/RemoveAllTags.java | 16 +- .../gravitino/cli/commands/RemoveTagProperty.java | 11 +- .../gravitino/cli/commands/SetTagProperty.java | 15 +- .../apache/gravitino/cli/commands/TagDetails.java | 10 +- .../apache/gravitino/cli/commands/TagEntity.java | 11 +- .../apache/gravitino/cli/commands/UntagEntity.java | 13 +- .../gravitino/cli/commands/UpdateTagComment.java | 11 +- .../gravitino/cli/commands/UpdateTagName.java | 11 +- .../org/apache/gravitino/cli/TestTagCommands.java | 176 +++++++++------------ 17 files changed, 197 insertions(+), 247 deletions(-) diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/GravitinoCommandLine.java b/clients/cli/src/main/java/org/apache/gravitino/cli/GravitinoCommandLine.java index 7230604655..2bb40373a6 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/GravitinoCommandLine.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/GravitinoCommandLine.java @@ -134,7 +134,7 @@ public class GravitinoCommandLine extends TestableCommandLine { } else if (entity.equals(CommandEntities.GROUP)) { new GroupCommandHandler(this, line, command, ignore).handle(); } else if (entity.equals(CommandEntities.TAG)) { - new TagCommandHandler(this, line, command, ignore).handle(); + new TagCommandHandler(this, line, command, context).handle(); } else if (entity.equals(CommandEntities.ROLE)) { new RoleCommandHandler(this, line, command, ignore).handle(); } else if (entity.equals(CommandEntities.MODEL)) { diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/TagCommandHandler.java b/clients/cli/src/main/java/org/apache/gravitino/cli/TagCommandHandler.java index e274c271f9..13567ac064 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/TagCommandHandler.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/TagCommandHandler.java @@ -26,18 +26,20 @@ public class TagCommandHandler extends CommandHandler { private final GravitinoCommandLine gravitinoCommandLine; private final CommandLine line; private final String command; - private final boolean ignore; - private final String url; + private final CommandContext context; private String[] tags; private String metalake; public TagCommandHandler( - GravitinoCommandLine gravitinoCommandLine, CommandLine line, String command, boolean ignore) { + GravitinoCommandLine gravitinoCommandLine, + CommandLine line, + String command, + CommandContext context) { this.gravitinoCommandLine = gravitinoCommandLine; this.line = line; this.command = command; - this.ignore = ignore; - this.url = getUrl(line); + this.context = context; + this.context.setUrl(getUrl(line)); this.tags = line.getOptionValues(GravitinoOptions.TAG); if (tags != null) { @@ -107,27 +109,26 @@ public class TagCommandHandler extends CommandHandler { private void handleListCommand() { FullName name = new FullName(line); if (!name.hasCatalogName()) { - gravitinoCommandLine.newListTags(url, ignore, metalake).validate().handle(); + gravitinoCommandLine.newListTags(context, metalake).validate().handle(); } else { - gravitinoCommandLine.newListEntityTags(url, ignore, metalake, name).validate().handle(); + gravitinoCommandLine.newListEntityTags(context, metalake, name).validate().handle(); } } /** Handles the "DETAILS" command. */ private void handleDetailsCommand() { - gravitinoCommandLine.newTagDetails(url, ignore, metalake, getOneTag(tags)).validate().handle(); + gravitinoCommandLine.newTagDetails(context, metalake, getOneTag(tags)).validate().handle(); } /** Handles the "CREATE" command. */ private void handleCreateCommand() { String comment = line.getOptionValue(GravitinoOptions.COMMENT); - gravitinoCommandLine.newCreateTags(url, ignore, metalake, tags, comment).validate().handle(); + gravitinoCommandLine.newCreateTags(context, metalake, tags, comment).validate().handle(); } /** Handles the "DELETE" command. */ private void handleDeleteCommand() { - boolean forceDelete = line.hasOption(GravitinoOptions.FORCE); - gravitinoCommandLine.newDeleteTag(url, ignore, forceDelete, metalake, tags).validate().handle(); + gravitinoCommandLine.newDeleteTag(context, metalake, tags).validate().handle(); } /** Handles the "SET" command. */ @@ -136,12 +137,12 @@ public class TagCommandHandler extends CommandHandler { String value = line.getOptionValue(GravitinoOptions.VALUE); if (property == null && value == null) { gravitinoCommandLine - .newTagEntity(url, ignore, metalake, new FullName(line), tags) + .newTagEntity(context, metalake, new FullName(line), tags) .validate() .handle(); } else { gravitinoCommandLine - .newSetTagProperty(url, ignore, metalake, getOneTag(tags), property, value) + .newSetTagProperty(context, metalake, getOneTag(tags), property, value) .validate() .handle(); } @@ -152,20 +153,16 @@ public class TagCommandHandler extends CommandHandler { boolean isTag = line.hasOption(GravitinoOptions.TAG); FullName name = new FullName(line); if (!isTag) { - boolean forceRemove = line.hasOption(GravitinoOptions.FORCE); - gravitinoCommandLine - .newRemoveAllTags(url, ignore, metalake, name, forceRemove) - .validate() - .handle(); + gravitinoCommandLine.newRemoveAllTags(context, metalake, name).validate().handle(); } else { String propertyRemove = line.getOptionValue(GravitinoOptions.PROPERTY); if (propertyRemove != null) { gravitinoCommandLine - .newRemoveTagProperty(url, ignore, metalake, getOneTag(tags), propertyRemove) + .newRemoveTagProperty(context, metalake, getOneTag(tags), propertyRemove) .validate() .handle(); } else { - gravitinoCommandLine.newUntagEntity(url, ignore, metalake, name, tags).validate().handle(); + gravitinoCommandLine.newUntagEntity(context, metalake, name, tags).validate().handle(); } } } @@ -173,7 +170,7 @@ public class TagCommandHandler extends CommandHandler { /** Handles the "PROPERTIES" command. */ private void handlePropertiesCommand() { gravitinoCommandLine - .newListTagProperties(url, ignore, metalake, getOneTag(tags)) + .newListTagProperties(context, metalake, getOneTag(tags)) .validate() .handle(); } @@ -184,14 +181,14 @@ public class TagCommandHandler extends CommandHandler { if (line.hasOption(GravitinoOptions.COMMENT)) { String updateComment = line.getOptionValue(GravitinoOptions.COMMENT); gravitinoCommandLine - .newUpdateTagComment(url, ignore, metalake, getOneTag(tags), updateComment) + .newUpdateTagComment(context, metalake, getOneTag(tags), updateComment) .validate() .handle(); } if (line.hasOption(GravitinoOptions.RENAME)) { String newName = line.getOptionValue(GravitinoOptions.RENAME); gravitinoCommandLine - .newUpdateTagName(url, ignore, metalake, getOneTag(tags), newName) + .newUpdateTagName(context, metalake, getOneTag(tags), newName) .validate() .handle(); } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/TestableCommandLine.java b/clients/cli/src/main/java/org/apache/gravitino/cli/TestableCommandLine.java index b27e24fde9..0217d21d27 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/TestableCommandLine.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/TestableCommandLine.java @@ -474,67 +474,65 @@ public class TestableCommandLine { return new DeleteRole(url, ignore, force, metalake, roles); } - protected TagDetails newTagDetails(String url, boolean ignore, String metalake, String tag) { - return new TagDetails(url, ignore, metalake, tag); + protected TagDetails newTagDetails(CommandContext context, String metalake, String tag) { + return new TagDetails(context, metalake, tag); } - protected ListAllTags newListTags(String url, boolean ignore, String metalake) { - return new ListAllTags(url, ignore, metalake); + protected ListAllTags newListTags(CommandContext context, String metalake) { + return new ListAllTags(context, metalake); } protected CreateTag newCreateTags( - String url, boolean ignore, String metalake, String[] tags, String comment) { - return new CreateTag(url, ignore, metalake, tags, comment); + CommandContext context, String metalake, String[] tags, String comment) { + return new CreateTag(context, metalake, tags, comment); } - protected DeleteTag newDeleteTag( - String url, boolean ignore, boolean force, String metalake, String[] tags) { - return new DeleteTag(url, ignore, force, metalake, tags); + protected DeleteTag newDeleteTag(CommandContext context, String metalake, String[] tags) { + return new DeleteTag(context, metalake, tags); } protected SetTagProperty newSetTagProperty( - String url, boolean ignore, String metalake, String tag, String property, String value) { - return new SetTagProperty(url, ignore, metalake, tag, property, value); + CommandContext context, String metalake, String tag, String property, String value) { + return new SetTagProperty(context, metalake, tag, property, value); } protected RemoveTagProperty newRemoveTagProperty( - String url, boolean ignore, String metalake, String tag, String property) { - return new RemoveTagProperty(url, ignore, metalake, tag, property); + CommandContext context, String metalake, String tag, String property) { + return new RemoveTagProperty(context, metalake, tag, property); } - protected RemoveAllTags newRemoveAllTags( - String url, boolean ignore, String metalake, FullName name, boolean force) { - return new RemoveAllTags(url, ignore, metalake, name, force); + protected RemoveAllTags newRemoveAllTags(CommandContext context, String metalake, FullName name) { + return new RemoveAllTags(context, metalake, name); } protected ListTagProperties newListTagProperties( - String url, boolean ignore, String metalake, String tag) { - return new ListTagProperties(url, ignore, metalake, tag); + CommandContext context, String metalake, String tag) { + return new ListTagProperties(context, metalake, tag); } protected UpdateTagComment newUpdateTagComment( - String url, boolean ignore, String metalake, String tag, String comment) { - return new UpdateTagComment(url, ignore, metalake, tag, comment); + CommandContext context, String metalake, String tag, String comment) { + return new UpdateTagComment(context, metalake, tag, comment); } protected UpdateTagName newUpdateTagName( - String url, boolean ignore, String metalake, String tag, String newName) { - return new UpdateTagName(url, ignore, metalake, tag, newName); + CommandContext context, String metalake, String tag, String newName) { + return new UpdateTagName(context, metalake, tag, newName); } protected ListEntityTags newListEntityTags( - String url, boolean ignore, String metalake, FullName name) { - return new ListEntityTags(url, ignore, metalake, name); + CommandContext context, String metalake, FullName name) { + return new ListEntityTags(context, metalake, name); } protected TagEntity newTagEntity( - String url, boolean ignore, String metalake, FullName name, String[] tags) { - return new TagEntity(url, ignore, metalake, name, tags); + CommandContext context, String metalake, FullName name, String[] tags) { + return new TagEntity(context, metalake, name, tags); } protected UntagEntity newUntagEntity( - String url, boolean ignore, String metalake, FullName name, String[] tags) { - return new UntagEntity(url, ignore, metalake, name, tags); + CommandContext context, String metalake, FullName name, String[] tags) { + return new UntagEntity(context, metalake, name, tags); } protected ColumnAudit newColumnAudit( diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/CreateTag.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/CreateTag.java index dabf34c8b1..46bd517f34 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/CreateTag.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/CreateTag.java @@ -22,6 +22,7 @@ package org.apache.gravitino.cli.commands; import java.util.ArrayList; import java.util.Arrays; import java.util.List; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.client.GravitinoClient; import org.apache.gravitino.exceptions.NoSuchMetalakeException; @@ -35,15 +36,13 @@ public class CreateTag extends Command { /** * Create tags. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. * @param tags The names of the tags. * @param comment The comment of the tag. */ - public CreateTag( - String url, boolean ignoreVersions, String metalake, String[] tags, String comment) { - super(url, ignoreVersions); + public CreateTag(CommandContext context, String metalake, String[] tags, String comment) { + super(context); this.metalake = metalake; this.tags = tags; this.comment = comment; @@ -76,7 +75,7 @@ public class CreateTag extends Command { exitWithError(exp.getMessage()); } - System.out.println("Tag " + tags[0] + " created"); + printInformation("Tag " + tags[0] + " created"); } private void handleMultipleTags() { @@ -95,12 +94,12 @@ public class CreateTag extends Command { exitWithError(exp.getMessage()); } if (!created.isEmpty()) { - System.out.println("Tags " + String.join(",", created) + " created"); + printInformation("Tags " + String.join(",", created) + " created"); } if (created.size() < tags.length) { List<String> remaining = Arrays.asList(tags); remaining.removeAll(created); - System.out.println("Tags " + String.join(",", remaining) + " not created"); + printInformation("Tags " + String.join(",", remaining) + " not created"); } } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/DeleteTag.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/DeleteTag.java index 26919e06ac..f0bdf2f3c5 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/DeleteTag.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/DeleteTag.java @@ -23,6 +23,7 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.List; import org.apache.gravitino.cli.AreYouSure; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.client.GravitinoClient; import org.apache.gravitino.exceptions.NoSuchMetalakeException; @@ -37,16 +38,13 @@ public class DeleteTag extends Command { /** * Delete tags. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. - * @param force Force operation. + * @param context The command context. * @param metalake The name of the metalake. * @param tags The names of the tags. */ - public DeleteTag( - String url, boolean ignoreVersions, boolean force, String metalake, String[] tags) { - super(url, ignoreVersions); - this.force = force; + public DeleteTag(CommandContext context, String metalake, String[] tags) { + super(context); + this.force = context.force(); this.metalake = metalake; this.tags = tags; } @@ -59,7 +57,7 @@ public class DeleteTag extends Command { } if (tags == null || tags.length == 0) { - System.err.println(ErrorMessages.MISSING_TAG); + exitWithError(ErrorMessages.MISSING_TAG); } else { boolean hasOnlyOneTag = tags.length == 1; if (hasOnlyOneTag) { @@ -87,12 +85,12 @@ public class DeleteTag extends Command { exitWithError(exp.getMessage()); } if (!deleted.isEmpty()) { - System.out.println("Tags " + String.join(",", deleted) + " deleted."); + printInformation("Tags " + String.join(",", deleted) + " deleted."); } if (deleted.size() < tags.length) { List<String> remaining = Arrays.asList(tags); remaining.removeAll(deleted); - System.out.println("Tags " + String.join(",", remaining) + " not deleted."); + printInformation("Tags " + String.join(",", remaining) + " not deleted."); } } @@ -111,9 +109,9 @@ public class DeleteTag extends Command { } if (deleted) { - System.out.println("Tag " + tags[0] + " deleted."); + printInformation("Tag " + tags[0] + " deleted."); } else { - System.out.println("Tag " + tags[0] + " not deleted."); + printInformation("Tag " + tags[0] + " not deleted."); } } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListAllTags.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListAllTags.java index e3bd42ae04..63657bb0fd 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListAllTags.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListAllTags.java @@ -19,6 +19,7 @@ package org.apache.gravitino.cli.commands; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.client.GravitinoClient; import org.apache.gravitino.exceptions.NoSuchMetalakeException; @@ -31,12 +32,11 @@ public class ListAllTags extends Command { /** * Lists all tags in a metalake. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. */ - public ListAllTags(String url, boolean ignoreVersions, String metalake) { - super(url, ignoreVersions); + public ListAllTags(CommandContext context, String metalake) { + super(context); this.metalake = metalake; } @@ -53,8 +53,10 @@ public class ListAllTags extends Command { exitWithError(exp.getMessage()); } - String all = tags.length == 0 ? "No tags exist." : String.join(",", tags); - - System.out.println(all); + if (tags.length == 0) { + printInformation("No tags exist."); + } else { + printResults(String.join(",", tags)); + } } } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListEntityTags.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListEntityTags.java index 90b1000fa0..e0ebf4b58f 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListEntityTags.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListEntityTags.java @@ -21,6 +21,7 @@ package org.apache.gravitino.cli.commands; import org.apache.gravitino.Catalog; import org.apache.gravitino.Schema; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.cli.FullName; import org.apache.gravitino.cli.utils.FullNameUtil; @@ -43,13 +44,12 @@ public class ListEntityTags extends Command { /** * Lists all tags in a metalake. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. * @param name The name of the entity. */ - public ListEntityTags(String url, boolean ignoreVersions, String metalake, FullName name) { - super(url, ignoreVersions); + public ListEntityTags(CommandContext context, String metalake, FullName name) { + super(context); this.metalake = metalake; this.name = name; } @@ -113,6 +113,6 @@ public class ListEntityTags extends Command { String all = String.join(",", tags); - System.out.println(all); + printResults(all); } } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListTagProperties.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListTagProperties.java index 5e191003ed..13ace743f7 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListTagProperties.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/ListTagProperties.java @@ -20,6 +20,7 @@ package org.apache.gravitino.cli.commands; import java.util.Map; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.client.GravitinoClient; import org.apache.gravitino.exceptions.NoSuchMetalakeException; @@ -35,13 +36,12 @@ public class ListTagProperties extends ListProperties { /** * List the properties of a tag. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. * @param tag The name of the tag. */ - public ListTagProperties(String url, boolean ignoreVersions, String metalake, String tag) { - super(url, ignoreVersions); + public ListTagProperties(CommandContext context, String metalake, String tag) { + super(context); this.metalake = metalake; this.tag = tag; } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/RemoveAllTags.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/RemoveAllTags.java index 9c774dfaac..123f6d32f8 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/RemoveAllTags.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/RemoveAllTags.java @@ -22,6 +22,7 @@ package org.apache.gravitino.cli.commands; import org.apache.gravitino.Catalog; import org.apache.gravitino.Schema; import org.apache.gravitino.cli.AreYouSure; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.cli.FullName; import org.apache.gravitino.cli.utils.FullNameUtil; @@ -49,18 +50,15 @@ public class RemoveAllTags extends Command { /** * Removes all the tags of an entity * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. * @param name The name of the entity. - * @param force Force operation. */ - public RemoveAllTags( - String url, boolean ignoreVersions, String metalake, FullName name, boolean force) { - super(url, ignoreVersions); + public RemoveAllTags(CommandContext context, String metalake, FullName name) { + super(context); this.metalake = metalake; this.name = name; - this.force = force; + this.force = context.force(); } @Override @@ -152,10 +150,10 @@ public class RemoveAllTags extends Command { } if (tags.length > 0) { - System.out.println( + printInformation( entity + " removed tags " + String.join(",", tags) + " now tagged with nothing"); } else { - System.out.println(entity + " has no tags"); + printInformation(entity + " has no tags"); } } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/RemoveTagProperty.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/RemoveTagProperty.java index a91395baf8..b92cd5cc45 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/RemoveTagProperty.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/RemoveTagProperty.java @@ -19,6 +19,7 @@ package org.apache.gravitino.cli.commands; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.client.GravitinoClient; import org.apache.gravitino.exceptions.NoSuchMetalakeException; @@ -35,15 +36,13 @@ public class RemoveTagProperty extends Command { /** * Remove a property of a tag. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. * @param tag The name of the tag. * @param property The name of the property. */ - public RemoveTagProperty( - String url, boolean ignoreVersions, String metalake, String tag, String property) { - super(url, ignoreVersions); + public RemoveTagProperty(CommandContext context, String metalake, String tag, String property) { + super(context); this.metalake = metalake; this.tag = tag; this.property = property; @@ -64,6 +63,6 @@ public class RemoveTagProperty extends Command { exitWithError(exp.getMessage()); } - System.out.println(property + " property removed."); + printInformation(property + " property removed."); } } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/SetTagProperty.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/SetTagProperty.java index da7a267b8d..e0b66e6e6d 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/SetTagProperty.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/SetTagProperty.java @@ -19,6 +19,7 @@ package org.apache.gravitino.cli.commands; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.client.GravitinoClient; import org.apache.gravitino.exceptions.NoSuchMetalakeException; @@ -36,21 +37,15 @@ public class SetTagProperty extends Command { /** * Set a property of a tag. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. * @param tag The name of the tag. * @param property The name of the property. * @param value The value of the property. */ public SetTagProperty( - String url, - boolean ignoreVersions, - String metalake, - String tag, - String property, - String value) { - super(url, ignoreVersions); + CommandContext context, String metalake, String tag, String property, String value) { + super(context); this.metalake = metalake; this.tag = tag; this.property = property; @@ -72,7 +67,7 @@ public class SetTagProperty extends Command { exitWithError(exp.getMessage()); } - System.out.println(tag + " property set."); + printInformation(tag + " property set."); } @Override diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/TagDetails.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/TagDetails.java index 871a7e7074..75b127cf55 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/TagDetails.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/TagDetails.java @@ -19,6 +19,7 @@ package org.apache.gravitino.cli.commands; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.client.GravitinoClient; import org.apache.gravitino.exceptions.NoSuchCatalogException; @@ -33,13 +34,12 @@ public class TagDetails extends Command { /** * Displays the name and comment of a catalog. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. * @param tag The name of the tag. */ - public TagDetails(String url, boolean ignoreVersions, String metalake, String tag) { - super(url, ignoreVersions); + public TagDetails(CommandContext context, String metalake, String tag) { + super(context); this.metalake = metalake; this.tag = tag; } @@ -61,7 +61,7 @@ public class TagDetails extends Command { } if (result != null) { - System.out.println(result.name() + "," + result.comment()); + printResults(result.name() + "," + result.comment()); } } } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/TagEntity.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/TagEntity.java index 3b97778818..2ea2de5df7 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/TagEntity.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/TagEntity.java @@ -21,6 +21,7 @@ package org.apache.gravitino.cli.commands; import org.apache.gravitino.Catalog; import org.apache.gravitino.Schema; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.cli.FullName; import org.apache.gravitino.cli.utils.FullNameUtil; @@ -43,15 +44,13 @@ public class TagEntity extends Command { /** * Tag an entity with existing tags. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. * @param name The name of the entity. * @param tags The names of the tags. */ - public TagEntity( - String url, boolean ignoreVersions, String metalake, FullName name, String[] tags) { - super(url, ignoreVersions); + public TagEntity(CommandContext context, String metalake, FullName name, String[] tags) { + super(context); this.metalake = metalake; this.name = name; this.tags = tags; @@ -130,7 +129,7 @@ public class TagEntity extends Command { String all = tagsToAdd.length == 0 ? "nothing" : String.join(",", tagsToAdd); - System.out.println(entity + " now tagged with " + all); + printInformation(entity + " now tagged with " + all); } @Override diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UntagEntity.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UntagEntity.java index 205242135b..9fd1c4ca39 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UntagEntity.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UntagEntity.java @@ -21,6 +21,7 @@ package org.apache.gravitino.cli.commands; import org.apache.gravitino.Catalog; import org.apache.gravitino.Schema; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.cli.FullName; import org.apache.gravitino.cli.utils.FullNameUtil; @@ -42,15 +43,13 @@ public class UntagEntity extends Command { /** * Remove existing tags from an entity. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. * @param name The name of the entity. * @param tags The names of the tags. */ - public UntagEntity( - String url, boolean ignoreVersions, String metalake, FullName name, String[] tags) { - super(url, ignoreVersions); + public UntagEntity(CommandContext context, String metalake, FullName name, String[] tags) { + super(context); this.metalake = metalake; this.name = name; this.tags = tags; @@ -132,10 +131,10 @@ public class UntagEntity extends Command { } if (tags.length > 1) { - System.out.println( + printInformation( entity + " removed tags " + String.join(",", tags) + " now tagged with " + all); } else { - System.out.println(entity + " removed tag " + tags[0].toString() + " now tagged with " + all); + printInformation(entity + " removed tag " + tags[0].toString() + " now tagged with " + all); } } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UpdateTagComment.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UpdateTagComment.java index 2994d78f30..3abc7f29c3 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UpdateTagComment.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UpdateTagComment.java @@ -19,6 +19,7 @@ package org.apache.gravitino.cli.commands; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.client.GravitinoClient; import org.apache.gravitino.exceptions.NoSuchMetalakeException; @@ -35,15 +36,13 @@ public class UpdateTagComment extends Command { /** * Update the comment of a tag. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the metalake. * @param tag The name of the tag. * @param comment New metalake comment. */ - public UpdateTagComment( - String url, boolean ignoreVersions, String metalake, String tag, String comment) { - super(url, ignoreVersions); + public UpdateTagComment(CommandContext context, String metalake, String tag, String comment) { + super(context); this.metalake = metalake; this.tag = tag; this.comment = comment; @@ -64,6 +63,6 @@ public class UpdateTagComment extends Command { exitWithError(exp.getMessage()); } - System.out.println(tag + " comment changed."); + printInformation(tag + " comment changed."); } } diff --git a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UpdateTagName.java b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UpdateTagName.java index f4ef43412d..1dc79b76e9 100644 --- a/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UpdateTagName.java +++ b/clients/cli/src/main/java/org/apache/gravitino/cli/commands/UpdateTagName.java @@ -19,6 +19,7 @@ package org.apache.gravitino.cli.commands; +import org.apache.gravitino.cli.CommandContext; import org.apache.gravitino.cli.ErrorMessages; import org.apache.gravitino.client.GravitinoClient; import org.apache.gravitino.exceptions.NoSuchMetalakeException; @@ -35,15 +36,13 @@ public class UpdateTagName extends Command { /** * Update the name of a tag. * - * @param url The URL of the Gravitino server. - * @param ignoreVersions If true don't check the client/server versions match. + * @param context The command context. * @param metalake The name of the tag. * @param tag The name of the catalog. * @param name The new tag name. */ - public UpdateTagName( - String url, boolean ignoreVersions, String metalake, String tag, String name) { - super(url, ignoreVersions); + public UpdateTagName(CommandContext context, String metalake, String tag, String name) { + super(context); this.metalake = metalake; this.tag = tag; this.name = name; @@ -64,6 +63,6 @@ public class UpdateTagName extends Command { exitWithError(exp.getMessage()); } - System.out.println(tag + " name changed."); + printInformation(tag + " name changed."); } } diff --git a/clients/cli/src/test/java/org/apache/gravitino/cli/TestTagCommands.java b/clients/cli/src/test/java/org/apache/gravitino/cli/TestTagCommands.java index a94ccee7da..4a7549510b 100644 --- a/clients/cli/src/test/java/org/apache/gravitino/cli/TestTagCommands.java +++ b/clients/cli/src/test/java/org/apache/gravitino/cli/TestTagCommands.java @@ -22,6 +22,7 @@ package org.apache.gravitino.cli; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertThrows; import static org.mockito.ArgumentMatchers.argThat; +import static org.mockito.ArgumentMatchers.isNull; import static org.mockito.Mockito.any; import static org.mockito.Mockito.doReturn; import static org.mockito.Mockito.eq; @@ -93,7 +94,7 @@ class TestTagCommands { mockCommandLine, mockOptions, CommandEntities.TAG, CommandActions.LIST)); doReturn(mockList) .when(commandLine) - .newListTags(GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo"); + .newListTags(any(CommandContext.class), eq("metalake_demo")); doReturn(mockList).when(mockList).validate(); commandLine.handleCommandLine(); verify(mockList).handle(); @@ -112,7 +113,7 @@ class TestTagCommands { mockCommandLine, mockOptions, CommandEntities.TAG, CommandActions.DETAILS)); doReturn(mockDetails) .when(commandLine) - .newTagDetails(GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", "tagA"); + .newTagDetails(any(CommandContext.class), eq("metalake_demo"), eq("tagA")); doReturn(mockDetails).when(mockDetails).validate(); commandLine.handleCommandLine(); verify(mockDetails).handle(); @@ -132,7 +133,7 @@ class TestTagCommands { assertThrows(RuntimeException.class, commandLine::handleCommandLine); verify(commandLine, never()) - .newTagDetails(eq(GravitinoCommandLine.DEFAULT_URL), eq(false), eq("metalake_demo"), any()); + .newTagDetails(any(CommandContext.class), eq("metalake_demo"), any()); String output = new String(errContent.toByteArray(), StandardCharsets.UTF_8).trim(); assertEquals(ErrorMessages.MULTIPLE_TAG_COMMAND_ERROR, output); } @@ -153,11 +154,10 @@ class TestTagCommands { doReturn(mockCreate) .when(commandLine) .newCreateTags( - GravitinoCommandLine.DEFAULT_URL, - false, - "metalake_demo", - new String[] {"tagA"}, - "comment"); + any(CommandContext.class), + eq("metalake_demo"), + argThat(argument -> argument.length == 1 && argument[0].equals("tagA")), + eq("comment")); doReturn(mockCreate).when(mockCreate).validate(); commandLine.handleCommandLine(); verify(mockCreate).handle(); @@ -166,10 +166,9 @@ class TestTagCommands { @Test void testCreateCommandWithoutTagOption() { Main.useExit = false; - CreateTag spyCreate = - spy( - new CreateTag( - GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", null, "comment")); + CommandContext mockContext = mock(CommandContext.class); + when(mockContext.url()).thenReturn(GravitinoCommandLine.DEFAULT_URL); + CreateTag spyCreate = spy(new CreateTag(mockContext, "metalake_demo", null, "comment")); assertThrows(RuntimeException.class, spyCreate::validate); verify(spyCreate, never()).handle(); @@ -194,8 +193,7 @@ class TestTagCommands { doReturn(mockCreate) .when(commandLine) .newCreateTags( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), + any(CommandContext.class), eq("metalake_demo"), argThat( argument -> @@ -222,7 +220,10 @@ class TestTagCommands { doReturn(mockCreate) .when(commandLine) .newCreateTags( - GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", new String[] {"tagA"}, null); + any(CommandContext.class), + eq("metalake_demo"), + argThat(argument -> argument.length == 1), + isNull()); doReturn(mockCreate).when(mockCreate).validate(); commandLine.handleCommandLine(); verify(mockCreate).handle(); @@ -242,7 +243,9 @@ class TestTagCommands { doReturn(mockDelete) .when(commandLine) .newDeleteTag( - GravitinoCommandLine.DEFAULT_URL, false, false, "metalake_demo", new String[] {"tagA"}); + any(CommandContext.class), + eq("metalake_demo"), + argThat(argument -> argument.length == 1 && argument[0].equals("tagA"))); doReturn(mockDelete).when(mockDelete).validate(); commandLine.handleCommandLine(); verify(mockDelete).handle(); @@ -263,11 +266,13 @@ class TestTagCommands { doReturn(mockDelete) .when(commandLine) .newDeleteTag( - GravitinoCommandLine.DEFAULT_URL, - false, - false, - "metalake_demo", - new String[] {"tagA", "tagB"}); + any(CommandContext.class), + eq("metalake_demo"), + argThat( + argument -> + argument.length == 2 + && argument[0].equals("tagA") + && argument[1].equals("tagB"))); doReturn(mockDelete).when(mockDelete).validate(); commandLine.handleCommandLine(); verify(mockDelete).handle(); @@ -288,7 +293,9 @@ class TestTagCommands { doReturn(mockDelete) .when(commandLine) .newDeleteTag( - GravitinoCommandLine.DEFAULT_URL, false, true, "metalake_demo", new String[] {"tagA"}); + any(CommandContext.class), + eq("metalake_demo"), + argThat(argument -> argument.length == 1 && argument[0].equals("tagA"))); doReturn(mockDelete).when(mockDelete).validate(); commandLine.handleCommandLine(); verify(mockDelete).handle(); @@ -312,7 +319,11 @@ class TestTagCommands { doReturn(mockSetProperty) .when(commandLine) .newSetTagProperty( - GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", "tagA", "property", "value"); + any(CommandContext.class), + eq("metalake_demo"), + eq("tagA"), + eq("property"), + eq("value")); doReturn(mockSetProperty).when(mockSetProperty).validate(); commandLine.handleCommandLine(); verify(mockSetProperty).handle(); @@ -321,10 +332,10 @@ class TestTagCommands { @Test void testSetTagPropertyCommandWithoutPropertyAndValue() { Main.useExit = false; + CommandContext mockContext = mock(CommandContext.class); + when(mockContext.url()).thenReturn(GravitinoCommandLine.DEFAULT_URL); SetTagProperty spySetProperty = - spy( - new SetTagProperty( - GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", "tagA", null, null)); + spy(new SetTagProperty(mockContext, "metalake_demo", "tagA", null, null)); assertThrows(RuntimeException.class, spySetProperty::validate); verify(spySetProperty, never()).handle(); String output = new String(errContent.toByteArray(), StandardCharsets.UTF_8).trim(); @@ -334,10 +345,10 @@ class TestTagCommands { @Test void testSetTagPropertyCommandWithoutPropertyOption() { Main.useExit = false; + CommandContext mockContext = mock(CommandContext.class); + when(mockContext.url()).thenReturn(GravitinoCommandLine.DEFAULT_URL); SetTagProperty spySetProperty = - spy( - new SetTagProperty( - GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", "tagA", null, "value")); + spy(new SetTagProperty(mockContext, "metalake_demo", "tagA", null, "value")); assertThrows(RuntimeException.class, spySetProperty::validate); verify(spySetProperty, never()).handle(); String output = new String(errContent.toByteArray(), StandardCharsets.UTF_8).trim(); @@ -347,15 +358,10 @@ class TestTagCommands { @Test void testSetTagPropertyCommandWithoutValueOption() { Main.useExit = false; + CommandContext mockContext = mock(CommandContext.class); + when(mockContext.url()).thenReturn(GravitinoCommandLine.DEFAULT_URL); SetTagProperty spySetProperty = - spy( - new SetTagProperty( - GravitinoCommandLine.DEFAULT_URL, - false, - "metalake_demo", - "tagA", - "property", - null)); + spy(new SetTagProperty(mockContext, "metalake_demo", "tagA", "property", null)); assertThrows(RuntimeException.class, spySetProperty::validate); verify(spySetProperty, never()).handle(); String output = new String(errContent.toByteArray(), StandardCharsets.UTF_8).trim(); @@ -381,12 +387,7 @@ class TestTagCommands { Assertions.assertThrows(RuntimeException.class, commandLine::handleCommandLine); verify(commandLine, never()) .newSetTagProperty( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), - eq("metalake_demo"), - any(), - eq("property"), - eq("value")); + any(CommandContext.class), eq("metalake_demo"), any(), eq("property"), eq("value")); String output = new String(errContent.toByteArray(), StandardCharsets.UTF_8).trim(); assertEquals(ErrorMessages.MULTIPLE_TAG_COMMAND_ERROR, output); } @@ -407,7 +408,7 @@ class TestTagCommands { doReturn(mockRemoveProperty) .when(commandLine) .newRemoveTagProperty( - GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", "tagA", "property"); + any(CommandContext.class), eq("metalake_demo"), eq("tagA"), eq("property")); doReturn(mockRemoveProperty).when(mockRemoveProperty).validate(); commandLine.handleCommandLine(); verify(mockRemoveProperty).handle(); @@ -431,13 +432,9 @@ class TestTagCommands { assertThrows(RuntimeException.class, commandLine::handleCommandLine); verify(commandLine, never()) .newRemoveTagProperty( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), - eq("metalake_demo"), - any(), - eq("property")); + any(CommandContext.class), eq("metalake_demo"), any(), eq("property")); String output = new String(errContent.toByteArray(), StandardCharsets.UTF_8).trim(); - assertEquals(ErrorMessages.MULTIPLE_TAG_COMMAND_ERROR, output); + Assertions.assertEquals(ErrorMessages.MULTIPLE_TAG_COMMAND_ERROR, output); } @Test @@ -453,7 +450,7 @@ class TestTagCommands { mockCommandLine, mockOptions, CommandEntities.TAG, CommandActions.PROPERTIES)); doReturn(mockListProperties) .when(commandLine) - .newListTagProperties(GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", "tagA"); + .newListTagProperties(any(CommandContext.class), eq("metalake_demo"), eq("tagA")); doReturn(mockListProperties).when(mockListProperties).validate(); commandLine.handleCommandLine(); verify(mockListProperties).handle(); @@ -474,12 +471,7 @@ class TestTagCommands { mockCommandLine, mockOptions, CommandEntities.TAG, CommandActions.REMOVE)); doReturn(mockRemoveAllTags) .when(commandLine) - .newRemoveAllTags( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), - eq("metalake_demo"), - any(FullName.class), - eq(true)); + .newRemoveAllTags(any(CommandContext.class), eq("metalake_demo"), any(FullName.class)); doReturn(mockRemoveAllTags).when(mockRemoveAllTags).validate(); commandLine.handleCommandLine(); verify(mockRemoveAllTags).handle(); @@ -501,7 +493,7 @@ class TestTagCommands { doReturn(mockUpdateComment) .when(commandLine) .newUpdateTagComment( - GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", "tagA", "new comment"); + any(CommandContext.class), eq("metalake_demo"), eq("tagA"), eq("new comment")); doReturn(mockUpdateComment).when(mockUpdateComment).validate(); commandLine.handleCommandLine(); verify(mockUpdateComment).handle(); @@ -525,11 +517,7 @@ class TestTagCommands { assertThrows(RuntimeException.class, commandLine::handleCommandLine); verify(commandLine, never()) .newUpdateTagComment( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), - eq("metalake_demo"), - any(), - eq("new comment")); + any(CommandContext.class), eq("metalake_demo"), any(), eq("new comment")); String output = new String(errContent.toByteArray(), StandardCharsets.UTF_8).trim(); assertEquals(ErrorMessages.MULTIPLE_TAG_COMMAND_ERROR, output); } @@ -549,7 +537,7 @@ class TestTagCommands { mockCommandLine, mockOptions, CommandEntities.TAG, CommandActions.UPDATE)); doReturn(mockUpdateName) .when(commandLine) - .newUpdateTagName(GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", "tagA", "tagB"); + .newUpdateTagName(any(CommandContext.class), eq("metalake_demo"), eq("tagA"), eq("tagB")); doReturn(mockUpdateName).when(mockUpdateName).validate(); commandLine.handleCommandLine(); verify(mockUpdateName).handle(); @@ -572,12 +560,7 @@ class TestTagCommands { assertThrows(RuntimeException.class, commandLine::handleCommandLine); verify(commandLine, never()) - .newUpdateTagName( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), - eq("metalake_demo"), - any(), - eq("tagC")); + .newUpdateTagName(any(CommandContext.class), eq("metalake_demo"), any(), eq("tagC")); String output = new String(errContent.toByteArray(), StandardCharsets.UTF_8).trim(); assertEquals(ErrorMessages.MULTIPLE_TAG_COMMAND_ERROR, output); } @@ -595,8 +578,7 @@ class TestTagCommands { mockCommandLine, mockOptions, CommandEntities.TAG, CommandActions.LIST)); doReturn(mockListTags) .when(commandLine) - .newListEntityTags( - eq(GravitinoCommandLine.DEFAULT_URL), eq(false), eq("metalake_demo"), any()); + .newListEntityTags(any(CommandContext.class), eq("metalake_demo"), any(FullName.class)); doReturn(mockListTags).when(mockListTags).validate(); commandLine.handleCommandLine(); verify(mockListTags).handle(); @@ -618,8 +600,7 @@ class TestTagCommands { doReturn(mockTagEntity) .when(commandLine) .newTagEntity( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), + any(CommandContext.class), eq("metalake_demo"), any(), argThat( @@ -637,14 +618,10 @@ class TestTagCommands { @Test void testTagEntityCommandWithoutName() { Main.useExit = false; + CommandContext mockContext = mock(CommandContext.class); + when(mockContext.url()).thenReturn(GravitinoCommandLine.DEFAULT_URL); TagEntity spyTagEntity = - spy( - new TagEntity( - GravitinoCommandLine.DEFAULT_URL, - false, - "metalake_demo", - null, - new String[] {"tagA"})); + spy(new TagEntity(mockContext, "metalake_demo", null, new String[] {"tagA"})); assertThrows(RuntimeException.class, spyTagEntity::validate); verify(spyTagEntity, never()).handle(); @@ -669,8 +646,7 @@ class TestTagCommands { doReturn(mockTagEntity) .when(commandLine) .newTagEntity( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), + any(CommandContext.class), eq("metalake_demo"), any(), argThat( @@ -707,8 +683,7 @@ class TestTagCommands { doReturn(mockUntagEntity) .when(commandLine) .newUntagEntity( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), + any(CommandContext.class), eq("metalake_demo"), any(), argThat( @@ -726,14 +701,10 @@ class TestTagCommands { @Test void testUntagEntityCommandWithoutName() { Main.useExit = false; + CommandContext mockContext = mock(CommandContext.class); + when(mockContext.url()).thenReturn(GravitinoCommandLine.DEFAULT_URL); UntagEntity spyUntagEntity = - spy( - new UntagEntity( - GravitinoCommandLine.DEFAULT_URL, - false, - "metalake_demo", - null, - new String[] {"tagA"})); + spy(new UntagEntity(mockContext, "metalake_demo", null, new String[] {"tagA"})); assertThrows(RuntimeException.class, spyUntagEntity::validate); verify(spyUntagEntity, never()).handle(); @@ -760,8 +731,7 @@ class TestTagCommands { doReturn(mockUntagEntity) .when(commandLine) .newUntagEntity( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), + any(CommandContext.class), eq("metalake_demo"), any(), argThat( @@ -782,8 +752,9 @@ class TestTagCommands { @Test void testDeleteTagCommandWithoutTagOption() { Main.useExit = false; - DeleteTag spyDeleteTag = - spy(new DeleteTag(GravitinoCommandLine.DEFAULT_URL, false, false, "metalake", null)); + CommandContext mockContext = mock(CommandContext.class); + when(mockContext.url()).thenReturn(GravitinoCommandLine.DEFAULT_URL); + DeleteTag spyDeleteTag = spy(new DeleteTag(mockContext, "metalake", null)); assertThrows(RuntimeException.class, spyDeleteTag::validate); verify(spyDeleteTag, never()).handle(); @@ -809,16 +780,14 @@ class TestTagCommands { doReturn(mockRemoveAllTags) .when(commandLine) .newRemoveAllTags( - eq(GravitinoCommandLine.DEFAULT_URL), - eq(false), + any(CommandContext.class), eq("metalake_demo"), argThat( argument -> argument != null && "catalog".equals(argument.getCatalogName()) && "schema".equals(argument.getSchemaName()) - && "table".equals(argument.getTableName())), - eq(true)); + && "table".equals(argument.getTableName()))); doReturn(mockRemoveAllTags).when(mockRemoveAllTags).validate(); commandLine.handleCommandLine(); verify(mockRemoveAllTags).handle(); @@ -827,10 +796,9 @@ class TestTagCommands { @Test void testRemoveAllTagsCommandWithoutName() { Main.useExit = false; - RemoveAllTags spyRemoveAllTags = - spy( - new RemoveAllTags( - GravitinoCommandLine.DEFAULT_URL, false, "metalake_demo", null, false)); + CommandContext mockContext = mock(CommandContext.class); + when(mockContext.url()).thenReturn(GravitinoCommandLine.DEFAULT_URL); + RemoveAllTags spyRemoveAllTags = spy(new RemoveAllTags(mockContext, "metalake_demo", null)); assertThrows(RuntimeException.class, spyRemoveAllTags::validate); verify(spyRemoveAllTags, never()).handle();