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 the minimum CLI version supported by the template #116

Merged
merged 2 commits into from
Nov 6, 2023

Conversation

shreyas-goenka
Copy link
Collaborator

@shreyas-goenka shreyas-goenka commented Nov 2, 2023

This CLI adds minimum version of the CLI required to use the template. Newer features (eg: #112) used by the stack are not compantible with older CLI versions.

The CLI respects the min_databricks_cli_version metadata field and returns an error to the user.

Here's the output for a couple different CLI versions:
CLI version >= {min_databricks_cli_version} (in this case v0.209):
Works as expected

shreyas.goenka@THW32HFW6T playground % ./databricks_cli_0.209.0_darwin_arm64/databricks bundle init ~/mlops-stack
Welcome to MLOps Stacks. For detailed information on project generation, see the README at https://github.com/databricks/mlops-stacks/blob/main/README.md. 

Project Name [my-mlops-project]: ^C

CLI version < {min_databricks_cli_version} AND >= v0.208.2 (when support for min_databricks_cli_version was introduced)

shreyas.goenka@THW32HFW6T playground % ./databricks_cli_0.208.2_darwin_arm64/databricks bundle init ~/mlops-stack
Error: minimum CLI version "v0.209.0" is greater than current CLI version "v0.208.2". Please upgrade your current Databricks CLI

CLI version == v0.208.2
Unfortunately we don't have any method to display an error to the users of this version of the CLI.

CLI version <= v0.208.1
Hacky solution to give warnings to users of older CLI versions. This is the best effort we can do. Once the CLI goes GA this hack can be reverted.

shreyas.goenka@THW32HFW6T playground % ./databricks_cli_0.208.0_darwin_arm64/databricks bundle init ~/mlops-stack
{{if false}}

ERROR: This template is no longer supported supported by CLI versions v0.209 and lower.
Please hit control-C and go to https://docs.databricks.com/en/dev-tools/cli/install.html for instructions on upgrading the CLI.


{{end}}Welcome to MLOps Stacks. For detailed information on project generation, see the README at https://github.com/databricks/mlops-stacks/blob/main/README.md. 

Project Name [my-mlops-project]: 

@shreyas-goenka shreyas-goenka changed the title Add minimum CLI version supported by template Add the minimum CLI version supported by the template Nov 2, 2023
@mingyu89
Copy link
Contributor

mingyu89 commented Nov 3, 2023

It works but it's a very hacky way. Do we have better options?

@arpitjasa-db
Copy link
Collaborator

@shreyas-goenka if we don't have this hacky solution for CLI version < v0.208.1, what error do we run into?

@shreyas-goenka
Copy link
Collaborator Author

shreyas-goenka commented Nov 3, 2023

Customers using a CLI with version < 0.209 will run into issues once we use enums and start using the selection UI for those prompts. Older versions of the CLI did not deal with multiline prompts correctly for selection type questions and would end up overlaying on top of already printed text.

Here's an example of what the experience would look like.
https://github.com/databricks/mlops-stacks/assets/88374338/847668d4-3982-49d3-aeb3-682cf386310a

I agree that this method is hacky and does not look professional. However, I could not come up with any other alternatives and this is probably the best effort we can do here and the right thing for our customers. We made an oversight by not including versioning right out of the box for templates. I'll defer to your judgement however on whether we should include the hacky deprecation notice.

@arpitjasa-db
Copy link
Collaborator

Customers using a CLI with version < 0.209 will run into issues once we use enums and start using the selection UI for those prompts. Older versions of the CLI did not deal with multiline prompts correctly for selection type questions and would end up overlaying on top of already printed text.

Here's an example of what the experience would look like. https://github.com/databricks/mlops-stacks/assets/88374338/847668d4-3982-49d3-aeb3-682cf386310a

I agree that this method is hacky and does not look professional. However, I could not come up with any other alternatives and this is probably the best effort we can do here and the right thing for our customers. We made an oversight by not including versioning right out of the box for templates. I'll defer to your judgement however on whether we should include the hacky deprecation notice.

Love the music choice for that video 😂 but yeah I see the issue, it doesn't fail gracefully with older versions. Is there any way we can send an interrupt ourselves?

@mingyu89
Copy link
Contributor

mingyu89 commented Nov 5, 2023

Cookiecutter has the support of private variable that does not take input from users and has the option to show/not show the private variable values in console output.
https://cookiecutter.readthedocs.io/en/stable/advanced/private_variables.html

How about adding similar support in bundles? Either by using a convention in the name, or adding an explicit field.
After adding the support, we can add the private variable as the first one for prompt. At least it's in a separate input variable.
Screenshot 2023-11-05 at 12 29 37 PM
Screenshot 2023-11-05 at 12 30 49 PM

@shreyas-goenka
Copy link
Collaborator Author

@mingyu89 That's a good suggestion and gets rid of the need for a hack. The main hesitation I have with this approach is we should not introduce a new feature to bundle templates (in this case private variables) for it's side effects related to having a smooth migration path here.

@mingyu89
Copy link
Contributor

mingyu89 commented Nov 6, 2023

Yeah if it's not a feature we wanted to add, nevermind about it.

@arpitjasa-db arpitjasa-db merged commit ea921f6 into main Nov 6, 2023
1 check passed
@arpitjasa-db arpitjasa-db deleted the include-min-cli-version branch November 6, 2023 22:12
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants