Skip to content

Commit

Permalink
Revert "Add public API event for kernel post-initialization (#16214)"
Browse files Browse the repository at this point in the history
This reverts commit dbd78ca.
  • Loading branch information
DonJayamanne committed Dec 24, 2024
1 parent a4e0393 commit 0fc3715
Show file tree
Hide file tree
Showing 12 changed files with 24 additions and 293 deletions.
16 changes: 0 additions & 16 deletions src/api.proposed.kernelStartHook.d.ts

This file was deleted.

5 changes: 1 addition & 4 deletions src/extension.node.ts
Original file line number Diff line number Diff line change
Expand Up @@ -124,10 +124,7 @@ export async function activate(context: IExtensionContext): Promise<IExtensionAp
createJupyterServerCollection: () => {
throw new Error('Not Implemented');
},
kernels: {
getKernel: () => Promise.resolve(undefined),
onDidStart: () => ({ dispose: noop })
}
kernels: { getKernel: () => Promise.resolve(undefined) }
};
}
}
Expand Down
5 changes: 1 addition & 4 deletions src/extension.web.ts
Original file line number Diff line number Diff line change
Expand Up @@ -117,10 +117,7 @@ export async function activate(context: IExtensionContext): Promise<IExtensionAp
createJupyterServerCollection: () => {
throw new Error('Not Implemented');
},
kernels: {
getKernel: () => Promise.resolve(undefined),
onDidStart: () => ({ dispose: noop })
}
kernels: { getKernel: () => Promise.resolve(undefined) }
};
}
}
Expand Down
22 changes: 1 addition & 21 deletions src/kernels/kernel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -129,9 +129,6 @@ abstract class BaseKernel implements IBaseKernel {
get onStarted(): Event<void> {
return this._onStarted.event;
}
get onPostInitialized(): Event<void> {
return this._onPostInitialized.event;
}
get onDisposed(): Event<void> {
return this._onDisposed.event;
}
Expand All @@ -141,9 +138,6 @@ abstract class BaseKernel implements IBaseKernel {
get startedAtLeastOnce() {
return this._startedAtLeastOnce;
}
get userStartedKernel() {
return !this.startupUI.disableUI;
}
private _info?: KernelMessage.IInfoReplyMsg['content'];
private _startedAtLeastOnce?: boolean;
get info(): KernelMessage.IInfoReplyMsg['content'] | undefined {
Expand Down Expand Up @@ -178,12 +172,10 @@ abstract class BaseKernel implements IBaseKernel {
private _disposed?: boolean;
private _disposing?: boolean;
private _ignoreJupyterSessionDisposedErrors?: boolean;
private _postInitializedOnStart?: boolean;
private readonly _onDidKernelSocketChange = new EventEmitter<void>();
private readonly _onStatusChanged = new EventEmitter<KernelMessage.Status>();
private readonly _onRestarted = new EventEmitter<void>();
private readonly _onStarted = new EventEmitter<void>();
private readonly _onPostInitialized = new EventEmitter<void>();
private readonly _onDisposed = new EventEmitter<void>();
private _jupyterSessionPromise?: Promise<IKernelSession>;
private readonly hookedSessionForEvents = new WeakSet<IKernelSession>();
Expand Down Expand Up @@ -254,16 +246,7 @@ abstract class BaseKernel implements IBaseKernel {
this.startCancellation.dispose();
this.startCancellation = new CancellationTokenSource();
}
return this.startJupyterSession(options).then((result) => {
// If we started and the UI is no longer disabled (ie., a user executed a cell)
// then we can signal that the kernel was created and can be used by third-party extensions.
// We also only want to fire off a single event here.
if (!options?.disableUI && !this._postInitializedOnStart) {
this._onPostInitialized.fire();
this._postInitializedOnStart = true;
}
return result;
});
return this.startJupyterSession(options);
}
/**
* Interrupts the execution of cells.
Expand Down Expand Up @@ -426,9 +409,6 @@ abstract class BaseKernel implements IBaseKernel {

// Indicate a restart occurred if it succeeds
this._onRestarted.fire();

// Also signal that the kernel post initialization completed.
this._onPostInitialized.fire();
} catch (ex) {
logger.error(`Failed to restart kernel ${getDisplayPath(this.uri)}`, ex);
throw ex;
Expand Down
10 changes: 0 additions & 10 deletions src/kernels/kernelProvider.base.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,6 @@ export abstract class BaseCoreKernelProvider implements IKernelProvider {
protected readonly _onDidCreateKernel = new EventEmitter<IKernel>();
protected readonly _onDidDisposeKernel = new EventEmitter<IKernel>();
protected readonly _onKernelStatusChanged = new EventEmitter<{ status: KernelMessage.Status; kernel: IKernel }>();
protected readonly _onDidPostInitializeKernel = new EventEmitter<IKernel>();
public readonly onKernelStatusChanged = this._onKernelStatusChanged.event;
public get kernels() {
const kernels = new Set<IKernel>();
Expand All @@ -59,7 +58,6 @@ export abstract class BaseCoreKernelProvider implements IKernelProvider {
disposables.push(this._onKernelStatusChanged);
disposables.push(this._onDidStartKernel);
disposables.push(this._onDidCreateKernel);
disposables.push(this._onDidPostInitializeKernel);
}

public get onDidDisposeKernel(): Event<IKernel> {
Expand All @@ -75,9 +73,6 @@ export abstract class BaseCoreKernelProvider implements IKernelProvider {
public get onDidCreateKernel(): Event<IKernel> {
return this._onDidCreateKernel.event;
}
public get onDidPostInitializeKernel(): Event<IKernel> {
return this._onDidPostInitializeKernel.event;
}
public get(uriOrNotebook: Uri | NotebookDocument | string): IKernel | undefined {
if (isUri(uriOrNotebook)) {
const notebook = workspace.notebookDocuments.find(
Expand Down Expand Up @@ -192,7 +187,6 @@ export abstract class BaseThirdPartyKernelProvider implements IThirdPartyKernelP
protected readonly _onDidStartKernel = new EventEmitter<IThirdPartyKernel>();
protected readonly _onDidCreateKernel = new EventEmitter<IThirdPartyKernel>();
protected readonly _onDidDisposeKernel = new EventEmitter<IThirdPartyKernel>();
protected readonly _onDidPostInitializeKernel = new EventEmitter<IThirdPartyKernel>();
protected readonly _onKernelStatusChanged = new EventEmitter<{
status: KernelMessage.Status;
kernel: IThirdPartyKernel;
Expand All @@ -219,7 +213,6 @@ export abstract class BaseThirdPartyKernelProvider implements IThirdPartyKernelP
disposables.push(this._onKernelStatusChanged);
disposables.push(this._onDidStartKernel);
disposables.push(this._onDidCreateKernel);
disposables.push(this._onDidPostInitializeKernel);
}

public get onDidDisposeKernel(): Event<IThirdPartyKernel> {
Expand All @@ -234,9 +227,6 @@ export abstract class BaseThirdPartyKernelProvider implements IThirdPartyKernelP
public get onDidCreateKernel(): Event<IThirdPartyKernel> {
return this._onDidCreateKernel.event;
}
public get onDidPostInitializeKernel(): Event<IThirdPartyKernel> {
return this._onDidPostInitializeKernel.event;
}
public get(uri: Uri | string): IThirdPartyKernel | undefined {
return this.kernelsByUri.get(uri.toString())?.kernel || this.kernelsById.get(uri.toString())?.kernel;
}
Expand Down
14 changes: 0 additions & 14 deletions src/kernels/kernelProvider.node.ts
Original file line number Diff line number Diff line change
Expand Up @@ -97,13 +97,6 @@ export class KernelProvider extends BaseCoreKernelProvider {
this,
this.disposables
);
kernel.onPostInitialized(
() => {
this._onDidPostInitializeKernel.fire(kernel);
},
this,
this.disposables
);

this.executions.set(kernel, new NotebookKernelExecution(kernel, this.context, this.formatters, notebook));
this.asyncDisposables.push(kernel);
Expand Down Expand Up @@ -159,13 +152,6 @@ export class ThirdPartyKernelProvider extends BaseThirdPartyKernelProvider {
this,
this.disposables
);
kernel.onPostInitialized(
() => {
this._onDidPostInitializeKernel.fire(kernel);
},
this,
this.disposables
);
this.asyncDisposables.push(kernel);
this.storeKernel(uri, options, kernel);
this.deleteMappingIfKernelIsDisposed(uri, kernel);
Expand Down
11 changes: 0 additions & 11 deletions src/kernels/kernelProvider.node.unit.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -101,24 +101,20 @@ suite('Jupyter Session', () => {
const kernelStarted = createEventHandler(kernelProvider, 'onDidStartKernel', disposables);
const kernelDisposed = createEventHandler(kernelProvider, 'onDidDisposeKernel', disposables);
const kernelRestarted = createEventHandler(kernelProvider, 'onDidRestartKernel', disposables);
const kernelPostInitialized = createEventHandler(kernelProvider, 'onDidPostInitializeKernel', disposables);
const kernelStatusChanged = createEventHandler(kernelProvider, 'onKernelStatusChanged', disposables);
const notebook = new TestNotebookDocument(undefined, 'jupyter-notebook');
const onStarted = new EventEmitter<void>();
const onStatusChanged = new EventEmitter<void>();
const onRestartedEvent = new EventEmitter<void>();
const onPostInitializedEvent = new EventEmitter<void>();
const onDisposedEvent = new EventEmitter<void>();
disposables.push(onStatusChanged);
disposables.push(onRestartedEvent);
disposables.push(onPostInitializedEvent);
disposables.push(onStarted);
disposables.push(onDisposedEvent);
if (kernelProvider instanceof KernelProvider) {
sinon.stub(Kernel.prototype, 'onStarted').get(() => onStarted.event);
sinon.stub(Kernel.prototype, 'onStatusChanged').get(() => onStatusChanged.event);
sinon.stub(Kernel.prototype, 'onRestarted').get(() => onRestartedEvent.event);
sinon.stub(Kernel.prototype, 'onPostInitialized').get(() => onPostInitializedEvent.event);
sinon.stub(Kernel.prototype, 'onDisposed').get(() => onDisposedEvent.event);
const kernel = kernelProvider.getOrCreate(notebook, {
controller,
Expand All @@ -130,7 +126,6 @@ suite('Jupyter Session', () => {
sinon.stub(ThirdPartyKernel.prototype, 'onStarted').get(() => onStarted.event);
sinon.stub(ThirdPartyKernel.prototype, 'onStatusChanged').get(() => onStatusChanged.event);
sinon.stub(ThirdPartyKernel.prototype, 'onRestarted').get(() => onRestartedEvent.event);
sinon.stub(ThirdPartyKernel.prototype, 'onPostInitialized').get(() => onPostInitializedEvent.event);
sinon.stub(ThirdPartyKernel.prototype, 'onDisposed').get(() => onDisposedEvent.event);
const kernel = kernelProvider.getOrCreate(notebook.uri, {
metadata: instance(metadata),
Expand All @@ -143,10 +138,6 @@ suite('Jupyter Session', () => {
assert.isFalse(kernelStarted.fired, 'IKernelProvider.onDidStartKernel should not be fired');
assert.isFalse(kernelStatusChanged.fired, 'IKernelProvider.onKernelStatusChanged should not be fired');
assert.isFalse(kernelRestarted.fired, 'IKernelProvider.onDidRestartKernel should not have fired');
assert.isFalse(
kernelPostInitialized.fired,
'IKernelProvider.onDidPostInitializeKernel should not have fired'
);
assert.isFalse(kernelDisposed.fired, 'IKernelProvider.onDidDisposeKernel should not have fired');

onStarted.fire();
Expand All @@ -155,8 +146,6 @@ suite('Jupyter Session', () => {
assert.isTrue(kernelStatusChanged.fired, 'IKernelProvider.onKernelStatusChanged not fired');
onRestartedEvent.fire();
assert.isTrue(kernelRestarted.fired, 'IKernelProvider.onKernelRestarted not fired');
onPostInitializedEvent.fire();
assert.isTrue(kernelPostInitialized.fired, 'IKernelProvider.onDidPostInitializeKernel not fired');
onDisposedEvent.fire();
assert.isTrue(kernelDisposed.fired, 'IKernelProvider.onDisposedEvent not fired');
}
Expand Down
2 changes: 0 additions & 2 deletions src/kernels/kernelProvider.web.ts
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,6 @@ export class KernelProvider extends BaseCoreKernelProvider {
this.workspaceStorage
) as IKernel;
kernel.onRestarted(() => this._onDidRestartKernel.fire(kernel), this, this.disposables);
kernel.onPostInitialized(() => this._onDidPostInitializeKernel.fire(kernel), this, this.disposables);
kernel.onDisposed(() => this._onDidDisposeKernel.fire(kernel), this, this.disposables);
kernel.onStarted(() => this._onDidStartKernel.fire(kernel), this, this.disposables);
kernel.onStatusChanged(
Expand Down Expand Up @@ -133,7 +132,6 @@ export class ThirdPartyKernelProvider extends BaseThirdPartyKernelProvider {
this.workspaceStorage
);
kernel.onRestarted(() => this._onDidRestartKernel.fire(kernel), this, this.disposables);
kernel.onPostInitialized(() => this._onDidPostInitializeKernel.fire(kernel), this, this.disposables);
kernel.onDisposed(() => this._onDidDisposeKernel.fire(kernel), this, this.disposables);
kernel.onStarted(() => this._onDidStartKernel.fire(kernel), this, this.disposables);
kernel.onStatusChanged(
Expand Down
11 changes: 0 additions & 11 deletions src/kernels/kernelProvider.web.unit.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -82,24 +82,20 @@ suite('Jupyter Session', () => {
const kernelStarted = createEventHandler(kernelProvider, 'onDidStartKernel', disposables);
const kernelDisposed = createEventHandler(kernelProvider, 'onDidDisposeKernel', disposables);
const kernelRestarted = createEventHandler(kernelProvider, 'onDidRestartKernel', disposables);
const kernelPostInitialized = createEventHandler(kernelProvider, 'onDidPostInitializeKernel', disposables);
const kernelStatusChanged = createEventHandler(kernelProvider, 'onKernelStatusChanged', disposables);
const notebook = new TestNotebookDocument(undefined, 'jupyter-notebook');
const onStarted = new EventEmitter<void>();
const onStatusChanged = new EventEmitter<void>();
const onRestartedEvent = new EventEmitter<void>();
const onPostInitializedEvent = new EventEmitter<void>();
const onDisposedEvent = new EventEmitter<void>();
disposables.push(onStatusChanged);
disposables.push(onRestartedEvent);
disposables.push(onPostInitializedEvent);
disposables.push(onStarted);
disposables.push(onDisposedEvent);
if (kernelProvider instanceof KernelProvider) {
sinon.stub(Kernel.prototype, 'onStarted').get(() => onStarted.event);
sinon.stub(Kernel.prototype, 'onStatusChanged').get(() => onStatusChanged.event);
sinon.stub(Kernel.prototype, 'onRestarted').get(() => onRestartedEvent.event);
sinon.stub(Kernel.prototype, 'onPostInitialized').get(() => onPostInitializedEvent.event);
sinon.stub(Kernel.prototype, 'onDisposed').get(() => onDisposedEvent.event);
const kernel = kernelProvider.getOrCreate(notebook, {
controller,
Expand All @@ -111,7 +107,6 @@ suite('Jupyter Session', () => {
sinon.stub(ThirdPartyKernel.prototype, 'onStarted').get(() => onStarted.event);
sinon.stub(ThirdPartyKernel.prototype, 'onStatusChanged').get(() => onStatusChanged.event);
sinon.stub(ThirdPartyKernel.prototype, 'onRestarted').get(() => onRestartedEvent.event);
sinon.stub(ThirdPartyKernel.prototype, 'onPostInitialized').get(() => onPostInitializedEvent.event);
sinon.stub(ThirdPartyKernel.prototype, 'onDisposed').get(() => onDisposedEvent.event);
const kernel = kernelProvider.getOrCreate(notebook.uri, {
metadata: instance(metadata),
Expand All @@ -124,10 +119,6 @@ suite('Jupyter Session', () => {
assert.isFalse(kernelStarted.fired, 'IKernelProvider.onDidStartKernel should not be fired');
assert.isFalse(kernelStatusChanged.fired, 'IKernelProvider.onKernelStatusChanged should not be fired');
assert.isFalse(kernelRestarted.fired, 'IKernelProvider.onDidRestartKernel should not have fired');
assert.isFalse(
kernelPostInitialized.fired,
'IKernelProvider.onDidPostInitializeKernel should not have fired'
);
assert.isFalse(kernelDisposed.fired, 'IKernelProvider.onDidDisposeKernel should not have fired');

onStarted.fire();
Expand All @@ -136,8 +127,6 @@ suite('Jupyter Session', () => {
assert.isTrue(kernelStatusChanged.fired, 'IKernelProvider.onKernelStatusChanged not fired');
onRestartedEvent.fire();
assert.isTrue(kernelRestarted.fired, 'IKernelProvider.onKernelRestarted not fired');
onPostInitializedEvent.fire();
assert.isTrue(kernelPostInitialized.fired, 'IKernelProvider.onDidPostInitializeKernel not fired');
onDisposedEvent.fire();
assert.isTrue(kernelDisposed.fired, 'IKernelProvider.onDisposedEvent not fired');
}
Expand Down
8 changes: 0 additions & 8 deletions src/kernels/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -355,7 +355,6 @@ export interface IBaseKernel extends IAsyncDisposable {
readonly onDisposed: Event<void>;
readonly onStarted: Event<void>;
readonly onRestarted: Event<void>;
readonly onPostInitialized: Event<void>;
readonly restarting: Promise<void>;
readonly status: KernelMessage.Status;
readonly disposed: boolean;
Expand All @@ -382,12 +381,6 @@ export interface IBaseKernel extends IAsyncDisposable {
* This flag will tell us whether a real kernel was or is active.
*/
readonly startedAtLeastOnce?: boolean;
/**
* A kernel might be started (e.g., for pre-warming or other internal reasons) but this does not
* necessarily correlate with whether it was started by a user.
* This flag will tell us whether the kernel has been started explicitly through user action from the UI.
*/
readonly userStartedKernel: boolean;
start(options?: IDisplayOptions): Promise<IKernelSession>;
interrupt(): Promise<void>;
restart(): Promise<void>;
Expand Down Expand Up @@ -513,7 +506,6 @@ export interface IBaseKernelProvider<T extends IBaseKernel> extends IAsyncDispos
onDidRestartKernel: Event<T>;
onDidDisposeKernel: Event<T>;
onKernelStatusChanged: Event<{ status: KernelMessage.Status; kernel: T }>;
onDidPostInitializeKernel: Event<T>;
}

/**
Expand Down
Loading

0 comments on commit 0fc3715

Please sign in to comment.