Skip to content

Commit

Permalink
Point release with fix for survey prompt (#4113)
Browse files Browse the repository at this point in the history
  • Loading branch information
DonJayamanne authored Dec 3, 2020
1 parent 89723c7 commit 5ee5bce
Show file tree
Hide file tree
Showing 6 changed files with 33 additions and 17 deletions.
8 changes: 8 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,13 @@
# Changelog


## 2020.11.3 (03 December 2020)

### Fixes

1. Display survey prompt once per session.
([#4077](https://github.com/Microsoft/vscode-jupyter/issues/4077))

## 2020.11.2 (30 November 2020)

### Fixes
Expand Down
2 changes: 1 addition & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "jupyter",
"displayName": "Jupyter",
"version": "2020.11.2",
"version": "2020.11.3",
"description": "Jupyter notebook support, interactive programming and computing that supports Intellisense, debugging and more.",
"featureFlags": {
"usingNewInterpreterStorage": true
Expand Down
12 changes: 5 additions & 7 deletions src/client/datascience/dataScienceSurveyBanner.ts
Original file line number Diff line number Diff line change
Expand Up @@ -136,11 +136,12 @@ export class DataScienceSurveyBanner implements IJupyterExtensionBanner {
}
const executionCount: number = this.getExecutionCount();
const notebookCount: number = this.getOpenNotebookCount();
const show = await this.shouldShowBanner(executionCount, notebookCount);
const show = this.shouldShowBanner(executionCount, notebookCount);
if (!show) {
return;
}

// Disable for the current session.
this.disabledInCurrentSession = true;
const response = await this.appShell.showInformationMessage(this.bannerMessage, ...this.bannerLabels);
switch (response) {
case this.bannerLabels[DSSurveyLabelIndex.Yes]: {
Expand All @@ -154,14 +155,11 @@ export class DataScienceSurveyBanner implements IJupyterExtensionBanner {
await this.disable(3);
break;
}
default: {
// Disable for the current session.
this.disabledInCurrentSession = true;
}
default:
}
}

public async shouldShowBanner(executionCount: number, notebookOpenCount: number): Promise<boolean> {
public shouldShowBanner(executionCount: number, notebookOpenCount: number) {
if (!this.enabled || this.disabledInCurrentSession) {
return false;
}
Expand Down
13 changes: 7 additions & 6 deletions src/client/datascience/insidersNativeNotebookSurveyBanner.ts
Original file line number Diff line number Diff line change
Expand Up @@ -85,13 +85,17 @@ export class InsidersNativeNotebooksSurveyBanner implements IJupyterExtensionBan
}

public async showBanner(): Promise<void> {
if (this.disabledInCurrentSession) {
return;
}
// Disable for the current session.
this.disabledInCurrentSession = true;
const executionCount: number = this.getExecutionCount();
const notebookCount: number = this.getOpenNotebookCount();
const show = await this.shouldShowBanner(executionCount, notebookCount);
if (!show) {
return;
}

const response = await this.appShell.showInformationMessage(this.bannerMessage, ...this.bannerLabels);
switch (response) {
case this.bannerLabels[DSSurveyLabelIndex.Yes]: {
Expand All @@ -105,15 +109,12 @@ export class InsidersNativeNotebooksSurveyBanner implements IJupyterExtensionBan
await this.disable(3);
break;
}
default: {
// Disable for the current session.
this.disabledInCurrentSession = true;
}
default:
}
}

public async shouldShowBanner(executionCount: number, notebookOpenCount: number): Promise<boolean> {
if (!this.enabled || this.disabledInCurrentSession) {
if (!this.enabled) {
return false;
}

Expand Down
13 changes: 11 additions & 2 deletions src/test/datascience/datascienceSurveyBanner.vscode.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -74,14 +74,17 @@ suite('DataScience Survey Banner', () => {
persistentStateFactory.createGlobalPersistentState(DSSurveyStateKeys.ShowBanner, anything(), anything())
).thenReturn(showBannerState);

bannerService = new DataScienceSurveyBanner(
bannerService = createBannerService();
});
function createBannerService() {
return new DataScienceSurveyBanner(
instance(appShell),
instance(persistentStateFactory),
instance(browser),
instance(editorProvider),
instance(appEnv)
);
});
}
test('Confirm prompt is displayed & only once per session', async () => {
when(appShell.showInformationMessage(anything(), anything(), anything())).thenResolve();
await showBannerState.updateValue({ data: true });
Expand All @@ -106,18 +109,21 @@ suite('DataScience Survey Banner', () => {
resetCalls(appShell);

// Attempt to display again & it won't.
bannerService = createBannerService();
await bannerService.showBanner();
verify(browser.launch(anything())).never();
verify(appShell.showInformationMessage(anything(), anything(), anything())).never();

// Advance time by 1 month & still not displayed.
clock.tick(MillisecondsInADay * 30);
bannerService = createBannerService();
await bannerService.showBanner();
verify(browser.launch(anything())).never();
verify(appShell.showInformationMessage(anything(), anything(), anything())).never();

// Advance time by 3.5 month & it will be displayed.
clock.tick(MillisecondsInADay * 30 * 3.5);
bannerService = createBannerService();
await bannerService.showBanner();
verify(browser.launch(anything())).never();
verify(appShell.showInformationMessage(anything(), anything(), anything())).once();
Expand All @@ -137,12 +143,14 @@ suite('DataScience Survey Banner', () => {
resetCalls(appShell);

// Attempt to display again & it won't.
bannerService = createBannerService();
await bannerService.showBanner();
verify(browser.launch(anything())).never();
verify(appShell.showInformationMessage(anything(), anything(), anything())).never();

// Advance time by 1 month & still not displayed.
clock.tick(MillisecondsInADay * 30);
bannerService = createBannerService();
await bannerService.showBanner();
verify(browser.launch(anything())).never();
verify(appShell.showInformationMessage(anything(), anything(), anything())).never();
Expand All @@ -152,6 +160,7 @@ suite('DataScience Survey Banner', () => {
when(appShell.showInformationMessage(anything(), anything(), anything())).thenResolve(
localize.DataScienceSurveyBanner.bannerLabelNo() as any
);
bannerService = createBannerService();
await bannerService.showBanner();
verify(browser.launch(anything())).never();
verify(appShell.showInformationMessage(anything(), anything(), anything())).once();
Expand Down

0 comments on commit 5ee5bce

Please sign in to comment.