Skip to content

Commit

Permalink
Update documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
anujc25 committed Apr 18, 2024
1 parent 822864d commit a6d6769
Show file tree
Hide file tree
Showing 6 changed files with 43 additions and 47 deletions.
3 changes: 1 addition & 2 deletions docs/dev/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -86,9 +86,8 @@ Below is the list of these variables:
| `TANZU_CLI_E2E_TEST_BINARY_PATH` | Specifies the CLI binary to use for E2E tests. Defaults to `tanzu` as found on `$PATH`. | The path including the binary to the CLI |
| `TANZU_CLI_PLUGIN_DB_CACHE_REFRESH_THRESHOLD_SECONDS` | Overrides the default threshold at which point the plugin inventory will be automatically refreshed. Default: 24 hours. | Threshold in seconds |
| `TANZU_CLI_PLUGIN_DB_CACHE_TTL_SECONDS` | Overrides the default 30 minute delay in which the plugin inventory cache is used without checking if it should be refreshed. | Delay in seconds |
| `TANZU_CLI_PLUGIN_DISCOVERY_PATH_FOR_TANZU_CONTEXT` | Allows testing the preliminary context-scoped plugin support for a Tanzu context type. | The path portion of the URI to use for discovery of context-scoped plugins on a Tanzu context |
| `TANZU_CLI_PLUGIN_DISCOVERY_PATH_FOR_TANZU_CONTEXT` | Allows testing the preliminary context-recommended plugin support for a Tanzu context type. | The path portion of the URI to use for discovery of context-recommended plugins on a Tanzu context |
| `TANZU_CLI_SHOW_PLUGIN_INSTALLATION_LOGS` | Allows to print plugin installation logs during the Essential Plugins installation. | `1` or `true` to print the logs, `0`, `false`, `""` or unset not to print them |
| `TANZU_CLI_STANDALONE_OVER_CONTEXT_PLUGINS` | Tells the CLI to use any standalone plugins currently installed even if the same plugin is also installed as context-scoped. This allows to test new plugin versions locally. | `1` or `true` to use standalone plugins before context-scoped plugins, `0`, `false`, `""` or unset to prioritize context-scoped plugins |
| `TANZU_CLI_SUPERCOLLIDER_ENVIRONMENT` | Specifies the use of the staging super collider environment instead of the production environment. | `"staging"` |
| `TANZU_CLI_TMC_UNSTABLE_URL` | Specifies the endpoint for the TMC cluster to use in E2E tests. | The URI of the endpoint |
| `TANZU_CONFIG` | Use a different `config.yaml` file. | Full path to the new config file |
Expand Down
2 changes: 1 addition & 1 deletion docs/full/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@ Commands producing meaningful output consistently provide alternative output suc

The CLI is configured to use a default plugin repository. Through various commands like `tanzu plugin search`, `tanzu plugin install`, `tanzu plugin install --group <groupName>:<groupVersion>`, the CLI provides various means to discover, then securely install or update plugins to serve specific needs of the user.

Certain context endpoints will require that a specific set of plugins be installed so as to enable proper interaction with said endpoints. For these, establishing a connection with these endpoints may lead to the discovery and automatic installation of additional plugins. Plugins installed through this mean of discovery are referred to as "context-scoped" plugins. To learn more about the context-scoped plugins, please check the [context-scoped plugin installation](../full/context-scoped-plugins.md) documentation.
Certain context endpoints will require that a specific set of plugins be installed so as to enable proper interaction with said endpoints. For these, establishing a connection with these endpoints may lead to the discovery and automatic installation of additional plugins. Plugins installed through this mean of discovery are referred to as "context-recommended" plugins. To learn more about the context-recommended plugins, please check the [context-recommended plugin installation](../full/context-recommended-plugins.md) documentation.

For an overview on some of these plugin lifecycle commands, see the [Quickstart Guide](../quickstart/quickstart.md).
For more details on these commands, see the [command reference](../cli/commands/tanzu_plugin.md).
Expand Down
2 changes: 0 additions & 2 deletions docs/full/cli-architecture.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,6 @@ This document aims to provide a general overview of the Tanzu CLI architecture.

The CLI is based on a plugin architecture. This architecture enables teams to build, own, and release their piece of functionality as well as enable external partners to integrate with the system.

Two categories of plugins are determined based on Plugin Discovery. Standalone Plugins and Context-Scoped Plugins

## Plugin Discovery

A plugin discovery points to a group of plugin artifacts that are installable by the Tanzu CLI. It uses an interface to fetch the list of available plugins, their supported versions, and how to download them.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Context-Scope Plugin Installation
# Context Recommended Plugin Installation

## Abstract

Expand All @@ -13,7 +13,7 @@ When a user is working with multiple instances of a product, we want to
automatically select the right set of plugins and plugin versions for use
based on the active context the user is connected to.

The goals of the Context-Scoped Plugin Installation feature are:
The goals of the Context-Recommended Plugin Installation feature are:

As a plugin developer, I want to,

Expand Down Expand Up @@ -42,23 +42,12 @@ Plugin availability is solely dependent on the configured discovery sources in t
tanzu configuration file. Each discovery source points to a plugin repository
which can contain one or more plugins.

## Standalone Plugins

The scope of a plugin depends on how the plugin is getting installed on the user's machine.
Users can run the `tanzu plugin search` command to see all available plugins from
the configured discovery sources.

If the user wants to install a plugin that is not dependent on any active context and
wants to use it with the Tanzu CLI, the user can run `tanzu plugin install <plugin-name>`
to install the required plugin. Installing the plugin this way will make the
plugin a standalone plugin and it will not be associated with any contexts.

## Context-scoped Plugins
## Context Recommended Plugins

As mentioned above in the abstract section, there might be a scenario when a user
is working with multiple contexts at a time and wants to automatically select the
right set of plugins and plugin versions based on the currently active context.
The context-scoped plugin implementation is useful in this scenario.
The context-recommended plugin implementation is useful in this scenario.

When the CLI user creates a new context for the Tanzu CLI using the
`tanzu context create` command, the CLI adds a context in the tanzu configuration file
Expand All @@ -68,19 +57,21 @@ Now, this newly created context can also recommend the list of plugins and their
that are needed to be installed on the user's machine to interact with the created context.
The Tanzu CLI automatically detects the list of recommended plugins and their versions and
installs them as part of the `tanzu context create` or `tanzu context use` commands. Below
is the workflow of context-scoped plugin installation:
is the workflow of context-recommended plugin installation:

- The user runs the `tanzu context create` or `tanzu context use` commands to create a new context or switch active context
- The Tanzu CLI gets the list of recommended plugins and their version from the created context
- The Tanzu CLI finds the plugins and their metadata in the available list of plugins generated from the configured discovery sources
- The Tanzu CLI fetches the plugin binary for these plugins from the specified location and installs the plugin

Users should understand that these plugins (installed based on a context) are
only available when said context is active. If a user deletes the context the plugins
installed based on the deleted context are no longer available to use with the CLI.
If the user switches the context to a different context using the `tanzu context use` command,
the CLI will automatically install/update the recommended plugins based on the new context.

Note: Users should understand that these plugins (installed based on a recommendation from a context) are
installed as normal plugins and will not be automatically deleted when a user deletes the context or switches
the context to a different context. Commands associated with those plugins will remain available
to be used but will likely throw an error if those plugins do not work with the active context.

## Plugin Recommendations from a Context

This section provides more details on how a context can provide
Expand Down
14 changes: 5 additions & 9 deletions docs/plugindev/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -401,20 +401,16 @@ As a plugin developer, you will want to test your plugin manually at some point.
During the development cycle, you can easily build and install the latest version of your plugin
as described in the section on [building a plugin](#building-a-plugin).

If you are using "contexts" while doing testing of your plugin and that your plugin is context-scoped
you may find that your new plugin version is being overwritten with an older version by the CLI.
When a plugin is context-scoped a context may recommend a specific version of that plugin for the CLI
to use. In such a case, if you want to test your new version and prevent the CLI from overwriting it
with the version recommended by the context you can enable the `TANZU_CLI_STANDALONE_OVER_CONTEXT_PLUGINS`
If you are using "contexts" while doing testing of your plugin and that your plugin is recommended by the
context, you may find that your new plugin version is being overwritten with an older version by the CLI.
In such a case, if you want to test your new version and prevent the CLI from overwriting it
with the version recommended by the context you can set the `TANZU_CLI_DEACTIVATE_AUTO_INSTALLATION_OF_CONTEXT_RECOMMENDED_PLUGINS`
variable by doing:

```sh
tanzu config set env.TANZU_CLI_STANDALONE_OVER_CONTEXT_PLUGINS true
tanzu config set env.TANZU_CLI_DEACTIVATE_AUTO_INSTALLATION_OF_CONTEXT_RECOMMENDED_PLUGINS true
```

This variable will instruct the CLI that any installation done with `tanzu plugin install <pluginName>`
should take precedence over any installation coming from a context.

#### Automated tests using the test plugin

Plugin tests can be run by installing the admin `test` plugin.
Expand Down
40 changes: 26 additions & 14 deletions docs/quickstart/quickstart.md
Original file line number Diff line number Diff line change
Expand Up @@ -324,24 +324,36 @@ Switching to another context:
[i] Successfully installed all required plugins

> tanzu plugin list
Standalone Plugins
NAME DESCRIPTION TARGET VERSION STATUS
isolated-cluster Prepopulating images/bundle for internet-restricted environments global v0.28.0 installed
pinniped-auth Pinniped authentication operations (usually not directly invoked) global v0.28.0 installed
management-cluster Kubernetes management cluster operations kubernetes v0.28.0 installed
package Tanzu package management kubernetes v0.28.0 installed
secret Tanzu secret management kubernetes v0.28.0 installed
telemetry configure cluster-wide settings for vmware tanzu telemetry kubernetes v0.28.0 installed
NAME DESCRIPTION TARGET INSTALLED RECOMMENDED STATUS
cluster Kubernetes cluster operations kubernetes v0.28.0 v0.28.0 installed
feature Operate on features and featuregates kubernetes v0.28.0 v0.28.0 installed
kubernetes-release Kubernetes release operations kubernetes v0.28.0 v0.28.0 installed
isolated-cluster Prepopulating images/bundle for internet-restricted environments global v0.28.0 installed
pinniped-auth Pinniped authentication operations (usually not directly invoked) global v0.28.0 installed
management-cluster Kubernetes management cluster operations kubernetes v0.28.0 installed
package Tanzu package management kubernetes v0.28.0 installed
secret Tanzu secret management kubernetes v0.28.0 installed
telemetry configure cluster-wide settings for vmware tanzu telemetry kubernetes v0.28.0 installed

Plugins from Context: tkg-mgmt-vc
NAME DESCRIPTION TARGET VERSION STATUS
cluster Kubernetes cluster operations kubernetes v0.28.0 installed
feature Operate on features and featuregates kubernetes v0.28.0 installed
kubernetes-release Kubernetes release operations kubernetes v0.28.0 installed
```

The way this type of plugin installation works is that The context you
create or activate can recommend a list of plugins and their versions.
When you create or activate a context, the Tanzu CLI fetches the list of
recommended plugins and automatically tries to install these plugins to
your machine. A `RECOMMENDED` column is shown as part of the
`tanzu plugin list` output that specifies which plugins are recommended
by the active context.

For some reason, the auto-installation of the recommended plugins fails while
creating or activating a context or an existing active context start recommending
some newer versions of the plugins, you can check that with the `tanzu plugin list`
output with the `STATUS` field mentioning `update needed` and a newer version in
the `RECOMMENDED` column. You can run the `tanzu plugin sync` command
to automatically install the recommended version of the plugins.

To learn more about the plugins installed from context, please refer to
[context-scoped plugin installation](../full/context-scoped-plugins.md).
[context recommended plugin installation](../full/context-recommended-plugins.md).

## Notes to users of previous versions of the Tanzu CLI

Expand Down

0 comments on commit a6d6769

Please sign in to comment.