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

Show DVC Cli Details in DVC Setup #3688

Merged
merged 25 commits into from
Apr 27, 2023
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
83bd304
Pass dvc cli details the front end
julieg18 Apr 14, 2023
c9a0811
Fix vscode tests
julieg18 Apr 14, 2023
395ac9b
wip for front end
julieg18 Apr 17, 2023
c680243
Add WIP frontend design
julieg18 Apr 17, 2023
c8431f4
Add details as a constand and TODO LIST
julieg18 Apr 18, 2023
f55ad95
Resolve comments and clean up
julieg18 Apr 18, 2023
c2afb03
Add frontend tests
julieg18 Apr 18, 2023
8326528
Fix error being thrown in vscode tests
julieg18 Apr 18, 2023
ddb69c4
cleanup
julieg18 Apr 18, 2023
489a372
Merge branch 'main' into show-dvc-cli-details-in-setup
julieg18 Apr 20, 2023
3aba346
new design
julieg18 Apr 20, 2023
6a4f092
Adjust based off feedback
julieg18 Apr 21, 2023
0c7a6eb
Merge branch 'main' into show-dvc-cli-details-in-setup
julieg18 Apr 21, 2023
38764a5
Clean up and add jest tests
julieg18 Apr 24, 2023
48eb1ea
Fix vscode tests
julieg18 Apr 25, 2023
1fdda0e
Cleanup after reviewing code
julieg18 Apr 25, 2023
a372d10
Merge branch 'main' into show-dvc-cli-details-in-setup
julieg18 Apr 25, 2023
5e9ef87
Merge branch 'main' into show-dvc-cli-details-in-setup
julieg18 Apr 26, 2023
12f8500
Break up components and use PropsWithChildren
julieg18 Apr 26, 2023
074d796
Fix typo and bugs
julieg18 Apr 26, 2023
165f3e9
Fix bug
julieg18 Apr 26, 2023
212c8a4
Commit missed file
julieg18 Apr 26, 2023
a05091b
Renaming stuff
julieg18 Apr 26, 2023
d9662cc
Add back "Select Python Interpreter"
julieg18 Apr 27, 2023
a303201
Merge branch 'main' into show-dvc-cli-details-in-setup
julieg18 Apr 27, 2023
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
38 changes: 37 additions & 1 deletion extension/src/setup/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,12 @@ import {
} from 'vscode'
import { Disposable, Disposer } from '@hediet/std/disposable'
import isEmpty from 'lodash.isempty'
import { SetupSection, SetupData as TSetupData } from './webview/contract'
import {
DvcCliDetails,
DvcCliIndicator,
SetupSection,
SetupData as TSetupData
} from './webview/contract'
import { collectSectionCollapsed } from './collect'
import { WebviewMessages } from './webview/messages'
import { validateTokenInput } from './inputBox'
Expand Down Expand Up @@ -84,6 +89,7 @@ export class Setup

private cliAccessible = false
private cliCompatible: boolean | undefined
private cliVersion: string | undefined

private dotFolderWatcher?: Disposer

Expand Down Expand Up @@ -334,6 +340,33 @@ export class Setup
return this.sendDataToWebview()
}

public async getEnvDetails(): Promise<DvcCliDetails> {
const dvcPath = this.config.getCliPath()
const pythonBinPath = this.config.getPythonBinPath()
let version
const cwd = getFirstWorkspaceFolder()

if (cwd) {
version = await this.getCliVersion(cwd)
}

if (dvcPath || !pythonBinPath) {
return {
location: dvcPath || 'dvc',
type: DvcCliIndicator.GLOBAL,
version
}
}

return {
location: pythonBinPath,
type: this.config.isPythonExtensionUsed()
? DvcCliIndicator.AUTO
: DvcCliIndicator.MANUAL,
version
}
}

private async sendDataToWebview() {
const projectInitialized = this.hasRoots()
const hasData = this.getHasData()
Expand All @@ -348,9 +381,12 @@ export class Setup

const pythonBinPath = await findPythonBinForInstall()

const dvcCliDetails = await this.getEnvDetails()
julieg18 marked this conversation as resolved.
Show resolved Hide resolved

this.webviewMessages.sendWebviewMessage({
canGitInitialize,
cliCompatible: this.cliCompatible,
dvcCliDetails,
hasData,
isPythonExtensionInstalled: isPythonExtensionInstalled(),
isStudioConnected: this.studioIsConnected,
Expand Down
14 changes: 14 additions & 0 deletions extension/src/setup/webview/contract.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,20 @@
export enum DvcCliIndicator {
AUTO = 'auto',
MANUAL = 'manual',
GLOBAL = 'global',
UNKNOWN = 'unknown'
}

export type DvcCliDetails = {
location: string
type: DvcCliIndicator
version: string | undefined
}

export type SetupData = {
canGitInitialize: boolean
cliCompatible: boolean | undefined
dvcCliDetails: DvcCliDetails
hasData: boolean | undefined
isPythonExtensionInstalled: boolean
isStudioConnected: boolean
Expand Down
2 changes: 2 additions & 0 deletions extension/src/setup/webview/messages.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ export class WebviewMessages {
public sendWebviewMessage({
canGitInitialize,
cliCompatible,
dvcCliDetails,
hasData,
isPythonExtensionInstalled,
isStudioConnected,
Expand All @@ -48,6 +49,7 @@ export class WebviewMessages {
void this.getWebview()?.show({
canGitInitialize,
cliCompatible,
dvcCliDetails,
hasData,
isPythonExtensionInstalled,
isStudioConnected,
Expand Down
19 changes: 19 additions & 0 deletions extension/src/test/suite/setup/index.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -218,6 +218,7 @@ suite('Setup Test Suite', () => {
setup.setCliCompatible(undefined)
julieg18 marked this conversation as resolved.
Show resolved Hide resolved
setup.setAvailable(false)
await setup.setRoots()
stub(setup, 'getCliVersion').resolves(undefined)

messageSpy.restore()
const mockSendMessage = stub(BaseWebview.prototype, 'show')
Expand All @@ -238,6 +239,7 @@ suite('Setup Test Suite', () => {
expect(mockSendMessage).to.be.calledWithExactly({
canGitInitialize: true,
cliCompatible: undefined,
dvcCliDetails: { location: 'dvc', type: 'global', version: undefined },
hasData: false,
isPythonExtensionInstalled: false,
isStudioConnected: false,
Expand Down Expand Up @@ -278,6 +280,11 @@ suite('Setup Test Suite', () => {
expect(mockSendMessage).to.be.calledWithExactly({
canGitInitialize: true,
cliCompatible: true,
dvcCliDetails: {
location: 'dvc',
type: 'global',
version: MIN_CLI_VERSION
},
hasData: false,
isPythonExtensionInstalled: false,
isStudioConnected: false,
Expand Down Expand Up @@ -324,6 +331,11 @@ suite('Setup Test Suite', () => {
expect(mockSendMessage).to.be.calledWithExactly({
canGitInitialize: false,
cliCompatible: true,
dvcCliDetails: {
location: 'dvc',
type: 'global',
version: MIN_CLI_VERSION
},
hasData: false,
isPythonExtensionInstalled: false,
isStudioConnected: false,
Expand Down Expand Up @@ -370,6 +382,11 @@ suite('Setup Test Suite', () => {
expect(mockSendMessage).to.be.calledWithExactly({
canGitInitialize: false,
cliCompatible: true,
dvcCliDetails: {
location: 'dvc',
type: 'global',
version: MIN_CLI_VERSION
},
hasData: false,
isPythonExtensionInstalled: false,
isStudioConnected: false,
Expand Down Expand Up @@ -568,6 +585,7 @@ suite('Setup Test Suite', () => {
mockRunSetup.restore()
stub(config, 'isPythonExtensionUsed').returns(false)
stub(config, 'getPythonBinPath').resolves(join('python'))
stub(setup, 'getEnvDetails').resolves(undefined)

mockVersion.resetBehavior()
mockVersion
Expand Down Expand Up @@ -627,6 +645,7 @@ suite('Setup Test Suite', () => {
mockExecuteCommand.restore()
mockRunSetup.restore()
stub(config, 'isPythonExtensionUsed').returns(true)
stub(setup, 'getEnvDetails').resolves(undefined)

mockVersion.resetBehavior()
mockVersion.rejects(new Error('no CLI here'))
Expand Down
Loading