Skip to content

Commit

Permalink
Add created branch (from dvc exp branch) to the experiments table (#…
Browse files Browse the repository at this point in the history
  • Loading branch information
julieg18 authored Oct 25, 2023
1 parent 500ca54 commit e557145
Show file tree
Hide file tree
Showing 5 changed files with 86 additions and 13 deletions.
17 changes: 15 additions & 2 deletions extension/src/experiments/commands/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,21 @@ import { RegisteredCommands } from '../../commands/external'

export const getBranchExperimentCommand =
(experiments: WorkspaceExperiments) =>
(cwd: string, name: string, input: string) =>
experiments.runCommand(AvailableCommands.EXP_BRANCH, cwd, name, input)
async (cwd: string, name: string, input: string) => {
const output = await experiments.runCommand(
AvailableCommands.EXP_BRANCH,
cwd,
name,
input
)

if (!output) {
return
}

const repository = experiments.getRepository(cwd)
return repository.addBranch(input)
}

export const getRenameExperimentCommand =
(experiments: WorkspaceExperiments) =>
Expand Down
5 changes: 5 additions & 0 deletions extension/src/experiments/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -613,6 +613,11 @@ export class Experiments extends BaseRepository<TableData> {
return this.experiments.getAvailableBranchesToSelect()
}

public addBranch(branch: string) {
this.experiments.addBranch(branch)
return this.refresh()
}

public refresh() {
return this.data.update()
}
Expand Down
7 changes: 7 additions & 0 deletions extension/src/experiments/model/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -585,6 +585,13 @@ export class ExperimentsModel extends ModelWithPersistence {
return this.availableBranchesToSelect
}

public addBranch(branch: string) {
const selectedBranches: string[] = this.getSelectedBranches()
const branchesWithNewBranch = [...selectedBranches, branch].sort()

this.setSelectedBranches(branchesWithNewBranch)
}

public setStudioData(
live: { baselineSha: string; name: string }[],
pushed: string[]
Expand Down
66 changes: 56 additions & 10 deletions extension/src/test/suite/experiments/index.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -534,31 +534,77 @@ suite('Experiments Test Suite', () => {
}).timeout(WEBVIEW_TEST_TIMEOUT)

it('should be able to handle a message to create a branch from an experiment', async () => {
const { mockMessageReceived } =
await stubWorkspaceGettersWebview(disposable)

const mockBranch = 'mock-branch-input'
const inputEvent = getInputBoxEvent(mockBranch)
const {
mockMessageReceived,
experimentsModel,
mockUpdateExperimentsData
} = await stubWorkspaceGettersWebview(disposable)

const mockExperimentBranch = stub(
DvcExecutor.prototype,
'expBranch'
).resolves('undefined')
stub(Setup.prototype, 'getCliVersion').resolves('3.22.0')

const mockExperimentId = 'exp-e7a67'
const mockBranch = 'mock-branch-input'
const mockExperimentBranch = stub(DvcExecutor.prototype, 'expBranch')
const mockSetSelectedBranches = stub(
experimentsModel,
'setSelectedBranches'
)
stub(window, 'showInputBox').resolves(mockBranch)

const failedExperimentBranchEvent = new Promise(resolve =>
mockExperimentBranch.onFirstCall().callsFake(() => {
resolve(undefined)
return Promise.resolve('')
})
)

mockMessageReceived.fire({
payload: mockExperimentId,
type: MessageFromWebviewType.CREATE_BRANCH_FROM_EXPERIMENT
})

await inputEvent
await failedExperimentBranchEvent

expect(mockExperimentBranch).to.be.calledOnce
expect(mockExperimentBranch).to.be.calledWithExactly(
dvcDemoPath,
mockExperimentId,
mockBranch
)
expect(mockSetSelectedBranches).not.to.be.called
expect(mockUpdateExperimentsData).not.to.be.called

const selectedBranches = ['main', 'other']
const selectedBranchesWithNewBranch = [
'main',
'mock-branch-input',
'other'
]
mockExperimentBranch.onSecondCall().resolves('branch created')
stub(experimentsModel, 'getSelectedBranches')
.onFirstCall()
.returns(selectedBranches)
const waitForBranchesToBeSelected = new Promise(resolve =>
mockSetSelectedBranches.callsFake(() => resolve(undefined))
)

mockMessageReceived.fire({
payload: mockExperimentId,
type: MessageFromWebviewType.CREATE_BRANCH_FROM_EXPERIMENT
})

await waitForBranchesToBeSelected

expect(mockExperimentBranch).to.be.calledTwice
expect(mockExperimentBranch).to.be.calledWithExactly(
dvcDemoPath,
mockExperimentId,
mockBranch
)
expect(mockSetSelectedBranches).to.be.calledWithExactly(
selectedBranchesWithNewBranch
)
expect(mockUpdateExperimentsData).to.be.calledOnce
}).timeout(WEBVIEW_TEST_TIMEOUT)

it('should be able to handle a message to rename an experiment', async () => {
Expand Down
4 changes: 3 additions & 1 deletion extension/src/test/suite/experiments/util.ts
Original file line number Diff line number Diff line change
Expand Up @@ -387,7 +387,8 @@ export const stubWorkspaceGettersWebview = async (
experimentsModel,
messageSpy,
mockMessageReceived,
webview
webview,
mockUpdateExperimentsData
} = await buildExperimentsWebview({ disposer })

return {
Expand All @@ -399,6 +400,7 @@ export const stubWorkspaceGettersWebview = async (
messageSpy,
...stubWorkspaceExperiments(dvcRoot, experiments),
mockMessageReceived,
mockUpdateExperimentsData,
webview
}
}

0 comments on commit e557145

Please sign in to comment.