Skip to content

Commit

Permalink
Merge branch 'main' into update-extension-text
Browse files Browse the repository at this point in the history
  • Loading branch information
mattseddon authored May 31, 2023
2 parents 89c4c16 + 1ac8c09 commit 77c815b
Show file tree
Hide file tree
Showing 25 changed files with 607 additions and 623 deletions.
14 changes: 14 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,20 @@

All notable changes to this project will be documented in this file.

## [0.9.2] - 2023-05-31

### 🚀 New Features and Enhancements

- Consolidate Setup and "Get Started" walkthrough [#3993](https://github.com/iterative/vscode-dvc/pull/3993) by [@julieg18](https://github.com/julieg18)

### 🐛 Bug Fixes

- Increase width of supported storage to remove scrollbar [#4016](https://github.com/iterative/vscode-dvc/pull/4016) by [@mattseddon](https://github.com/mattseddon)

### 🔨 Maintenance

- Add "(pip)" to setup install button [#4013](https://github.com/iterative/vscode-dvc/pull/4013) by [@julieg18](https://github.com/julieg18)

## [0.9.1] - 2023-05-31

### 🚀 New Features and Enhancements
Expand Down
20 changes: 10 additions & 10 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -146,16 +146,16 @@ These are the VS Code [settings] available for the Extension:

[settings]: https://code.visualstudio.com/docs/getstarted/settings

| **Option** | **Description** |
| -------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `dvc.dvcPath` | Path or shell command to the DVC binary. Required unless Microsoft's [Python extension] is installed and the `dvc` package found in its environment. |
| `dvc.pythonPath` | Path to the desired Python interpreter to use with DVC. Should only be utilized when using a virtual environment without Microsoft's [Python extension]. |
| `dvc.experimentsTableHeadMaxHeight` | Maximum height of experiment table head rows. |
| `dvc.focusedProjects` | A subset of paths to the workspace's available DVC projects. Using this option will override project auto-discovery. |
| `dvc.doNotShowWalkthroughAfterInstall` | Do not prompt to show the Get Started page after installing. Useful for pre-configured development environments |
| `dvc.doNotRecommendAddStudioToken` | Do not prompt to add a [studio.token] to the global DVC config, which enables automatic sharing of experiments to [Studio]. |
| `dvc.doNotRecommendRedHatExtension` | Do not prompt to install the Red Hat YAML extension, which helps with DVC YAML schema validation (`dvc.yaml` and `.dvc` files). |
| `dvc.doNotShowCliUnavailable` | Do not warn when the workspace contains a DVC project but the DVC binary is unavailable. |
| **Option** | **Description** |
| ----------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `dvc.dvcPath` | Path or shell command to the DVC binary. Required unless Microsoft's [Python extension] is installed and the `dvc` package found in its environment. |
| `dvc.pythonPath` | Path to the desired Python interpreter to use with DVC. Should only be utilized when using a virtual environment without Microsoft's [Python extension]. |
| `dvc.experimentsTableHeadMaxHeight` | Maximum height of experiment table head rows. |
| `dvc.focusedProjects` | A subset of paths to the workspace's available DVC projects. Using this option will override project auto-discovery. |
| `dvc.doNotShowSetupAfterInstall` | Do not prompt to show the setup page after installing. Useful for pre-configured development environments |
| `dvc.doNotRecommendAddStudioToken` | Do not prompt to add a [studio.token] to the global DVC config, which enables automatic sharing of experiments to [Studio]. |
| `dvc.doNotRecommendRedHatExtension` | Do not prompt to install the Red Hat YAML extension, which helps with DVC YAML schema validation (`dvc.yaml` and `.dvc` files). |
| `dvc.doNotShowCliUnavailable` | Do not warn when the workspace contains a DVC project but the DVC binary is unavailable. |

> **Note** that the `Setup The Workspace` command helps you set up the basic
> ones at the [Workspace level] (saved to `.vscode/setting.json`).
Expand Down
32 changes: 3 additions & 29 deletions extension/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
"extensionDependencies": [
"vscode.git"
],
"version": "0.9.1",
"version": "0.9.2",
"license": "Apache-2.0",
"readme": "./README.md",
"repository": {
Expand Down Expand Up @@ -615,8 +615,8 @@
"type": "boolean",
"default": null
},
"dvc.doNotShowWalkthroughAfterInstall": {
"description": "Do not prompt to show the Get Started page after installing. Useful for pre-configured development environments.",
"dvc.doNotShowSetupAfterInstall": {
"description": "Do not prompt to show the setup page after installing. Useful for pre-configured development environments.",
"type": "boolean",
"default": null
},
Expand Down Expand Up @@ -1512,32 +1512,6 @@
"title": "Get Started",
"description": "Your first steps to build better models faster with experiment tracking and dataset versioning",
"steps": [
{
"id": "dvc.installDVC",
"title": "Install DVC",
"description": "This extension requires DVC to be installed.\n\n[Show Setup](command:dvc.showDvcSetup)\n",
"media": {
"markdown": "resources/walkthrough/install-dvc.md"
},
"completionEvents": [
"onLink:https://dvc.org",
"onLink:https://dvc.org/doc/install",
"onCommand:dvc.setupWorkspace"
]
},
{
"id": "dvc.setupProject",
"title": "Setup a DVC Project",
"description": "Try an example DVC project or set one up quickly, and start tracking datasets, models, metrics, and plots\n\n[Example Project](https://github.com/iterative/example-get-started)\n",
"media": {
"markdown": "resources/walkthrough/setup-project.md"
},
"completionEvents": [
"onLink:https://github.com/iterative/example-get-started",
"onLink:https://github.com/iterative/vscode-dvc-demo",
"onLink:https://dvc.org/doc/dvclive"
]
},
{
"id": "dvc.showCommands",
"title": "Available Commands",
Expand Down
4 changes: 4 additions & 0 deletions extension/resources/walkthrough/command-palette.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
> ℹ️ The extension's features cannot be accessed until DVC is installed and a
> DVC project is available in the workspace. Please refer to the
> [setup page](command:dvc.dvc.showDvcSetup) if you have not setup DVC yet.
# Command Palette

This extension makes extensive use of the
Expand Down
4 changes: 0 additions & 4 deletions extension/resources/walkthrough/experiments-table.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,5 @@
# Experiments Table

> ❗ DVC should be installed and DVC project available in the workspace for this
> and the next steps to work properly. Please refer to first two steps of this
> guide.
As you change code, parameters, data and run new experiments this table will
keep all the details about your iterations. It can be manipulated and configured
using the [DVC side panel](command:workbench.view.extension.dvc-views). This is
Expand Down
Binary file not shown.
22 changes: 0 additions & 22 deletions extension/resources/walkthrough/install-dvc.md

This file was deleted.

60 changes: 0 additions & 60 deletions extension/resources/walkthrough/setup-project.md

This file was deleted.

8 changes: 3 additions & 5 deletions extension/src/extension.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,10 +29,8 @@ import {
} from './telemetry'
import { RegisteredCommands } from './commands/external'
import { StopWatch } from './util/time'
import {
registerWalkthroughCommands,
showWalkthroughOnFirstUse
} from './vscode/walkthrough'
import { registerWalkthroughCommands } from './vscode/walkthrough'
import { showSetupOnFirstUse } from './setup/util'
import { WorkspaceRepositories } from './repository/workspace'
import { recommendRedHatExtensionOnce } from './vscode/recommend'
import { WorkspacePlots } from './plots/workspace'
Expand Down Expand Up @@ -258,7 +256,7 @@ class Extension extends Disposable {

registerPersistenceCommands(context.workspaceState, this.internalCommands)

void showWalkthroughOnFirstUse(env.isNewAppInstall)
void showSetupOnFirstUse(env.isNewAppInstall)
this.dispose.track(recommendRedHatExtensionOnce())

this.dispose.track(new LanguageClient())
Expand Down
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
import { commands } from 'vscode'
import { showWalkthroughOnFirstUse } from './walkthrough'
import { ConfigKey, getConfigValue, setUserConfigValue } from './config'
import { Toast } from './toast'
import { Response } from './response'
import { showSetupOnFirstUse } from './util'
import { ConfigKey, getConfigValue, setUserConfigValue } from '../vscode/config'
import { Toast } from '../vscode/toast'
import { Response } from '../vscode/response'
import { RegisteredCommands } from '../commands/external'

jest.mock('vscode')
jest.mock('./toast')
jest.mock('./config')
jest.mock('../vscode/toast')
jest.mock('../vscode/config')

const mockedCommands = jest.mocked(commands)
const mockedExecuteCommand = jest.fn()
Expand All @@ -24,59 +24,59 @@ beforeEach(() => {
jest.resetAllMocks()
})

describe('showWalkthroughOnFirstUse', () => {
it('should ask to show the walkthrough after a new install', async () => {
await showWalkthroughOnFirstUse(true)
describe('showSetupOnFirstUse', () => {
it('should ask to show the setup page after a new install', async () => {
await showSetupOnFirstUse(true)
expect(mockedAskShowOrCloseOrNever).toHaveBeenCalledTimes(1)
})

it('should not ask to show the walkthrough when the install is not new', async () => {
await showWalkthroughOnFirstUse(false)
it('should not ask to show the setup page when the install is not new', async () => {
await showSetupOnFirstUse(false)
expect(mockedAskShowOrCloseOrNever).not.toHaveBeenCalled()
})

it('should not ask to show the walkthrough when the user has set a config option', async () => {
it('should not ask to show the setup page when the user has set a config option', async () => {
mockedGetConfigValue.mockReturnValueOnce(true)
await showWalkthroughOnFirstUse(true)
await showSetupOnFirstUse(true)
expect(mockedAskShowOrCloseOrNever).not.toHaveBeenCalled()
expect(mockedGetConfigValue).toHaveBeenCalledTimes(1)
expect(mockedGetConfigValue).toHaveBeenCalledWith(
ConfigKey.DO_NOT_SHOW_WALKTHROUGH_AFTER_INSTALL
ConfigKey.DO_NOT_SHOW_SETUP_AFTER_INSTALL
)
})

it('should set the config option if the user responds with never', async () => {
mockedAskShowOrCloseOrNever.mockResolvedValueOnce(Response.NEVER)
await showWalkthroughOnFirstUse(true)
await showSetupOnFirstUse(true)

expect(mockedSetConfigValue).toHaveBeenCalledTimes(1)
expect(mockedSetConfigValue).toHaveBeenCalledWith(
ConfigKey.DO_NOT_SHOW_WALKTHROUGH_AFTER_INSTALL,
ConfigKey.DO_NOT_SHOW_SETUP_AFTER_INSTALL,
true
)
})

it('should show the walkthrough if the user responds with show', async () => {
it('should show the setup page if the user responds with show', async () => {
mockedAskShowOrCloseOrNever.mockResolvedValueOnce(Response.SHOW)
await showWalkthroughOnFirstUse(true)
await showSetupOnFirstUse(true)

expect(mockedSetConfigValue).not.toHaveBeenCalled()
expect(mockedExecuteCommand).toHaveBeenCalledWith(
RegisteredCommands.EXTENSION_GET_STARTED
RegisteredCommands.SETUP_SHOW
)
})

it('should take no action if the user closes the dialog', async () => {
mockedAskShowOrCloseOrNever.mockResolvedValueOnce(undefined)
await showWalkthroughOnFirstUse(true)
await showSetupOnFirstUse(true)

expect(mockedSetConfigValue).not.toHaveBeenCalled()
expect(mockedExecuteCommand).not.toHaveBeenCalled()
})

it('should take no action if the user respond with close', async () => {
mockedAskShowOrCloseOrNever.mockResolvedValueOnce(Response.CLOSE)
await showWalkthroughOnFirstUse(true)
await showSetupOnFirstUse(true)

expect(mockedSetConfigValue).not.toHaveBeenCalled()
expect(mockedExecuteCommand).not.toHaveBeenCalled()
Expand Down
27 changes: 27 additions & 0 deletions extension/src/setup/util.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import { commands } from 'vscode'
import { RegisteredCommands } from '../commands/external'
import { ConfigKey, getConfigValue, setUserConfigValue } from '../vscode/config'
import { Response } from '../vscode/response'
import { Toast } from '../vscode/toast'

export const showSetupOnFirstUse = async (
isNewAppInstall: boolean
): Promise<void> => {
if (
!isNewAppInstall ||
getConfigValue<boolean>(ConfigKey.DO_NOT_SHOW_SETUP_AFTER_INSTALL)
) {
return
}

const response = await Toast.askShowOrCloseOrNever(
'Need help? Go to our setup view.'
)

if (response === Response.SHOW) {
void commands.executeCommand(RegisteredCommands.SETUP_SHOW)
}
if (response === Response.NEVER) {
void setUserConfigValue(ConfigKey.DO_NOT_SHOW_SETUP_AFTER_INSTALL, true)
}
}
2 changes: 1 addition & 1 deletion extension/src/vscode/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ export enum ConfigKey {
DO_NOT_RECOMMEND_ADD_STUDIO_TOKEN = 'dvc.doNotRecommendAddStudioToken',
DO_NOT_RECOMMEND_RED_HAT = 'dvc.doNotRecommendRedHatExtension',
DO_NOT_SHOW_CLI_UNAVAILABLE = 'dvc.doNotShowCliUnavailable',
DO_NOT_SHOW_WALKTHROUGH_AFTER_INSTALL = 'dvc.doNotShowWalkthroughAfterInstall',
DO_NOT_SHOW_SETUP_AFTER_INSTALL = 'dvc.doNotShowSetupAfterInstall',
DVC_PATH = 'dvc.dvcPath',
EXP_TABLE_HEAD_MAX_HEIGHT = 'dvc.experimentsTableHeadMaxHeight',
FOCUSED_PROJECTS = 'dvc.focusedProjects',
Expand Down
28 changes: 0 additions & 28 deletions extension/src/vscode/walkthrough.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,4 @@
import { commands } from 'vscode'
import { ConfigKey, getConfigValue, setUserConfigValue } from './config'
import { Response } from './response'
import { Toast } from './toast'
import { RegisteredCommands } from '../commands/external'
import { InternalCommands } from '../commands/internal'
import { joinTruthyItems } from '../util/array'
Expand All @@ -25,28 +22,3 @@ export const registerWalkthroughCommands = (
() => commands.executeCommand('workbench.action.quickOpen', '> DVC')
)
}

export const showWalkthroughOnFirstUse = async (
isNewAppInstall: boolean
): Promise<void> => {
if (
!isNewAppInstall ||
getConfigValue<boolean>(ConfigKey.DO_NOT_SHOW_WALKTHROUGH_AFTER_INSTALL)
) {
return
}

const response = await Toast.askShowOrCloseOrNever(
'Need help? There is a walkthrough.'
)

if (response === Response.SHOW) {
void commands.executeCommand(RegisteredCommands.EXTENSION_GET_STARTED)
}
if (response === Response.NEVER) {
void setUserConfigValue(
ConfigKey.DO_NOT_SHOW_WALKTHROUGH_AFTER_INSTALL,
true
)
}
}
Loading

0 comments on commit 77c815b

Please sign in to comment.