|  | 
|  | 1 | +// Copyright (c) Microsoft Corporation. All rights reserved. | 
|  | 2 | +// Licensed under the MIT License. | 
|  | 3 | + | 
|  | 4 | +import { expect } from 'chai'; | 
|  | 5 | +import * as TypeMoq from 'typemoq'; | 
|  | 6 | +import { Disposable, TextDocument, TextEditor, Uri, WorkspaceFolder } from 'vscode'; | 
|  | 7 | +import { ICommandManager, IDocumentManager, IWorkspaceService } from '../../client/common/application/types'; | 
|  | 8 | +import { Commands } from '../../client/common/constants'; | 
|  | 9 | +import { TerminalService } from '../../client/common/terminal/service'; | 
|  | 10 | +import { ITerminalServiceFactory } from '../../client/common/terminal/types'; | 
|  | 11 | +import { IServiceContainer } from '../../client/ioc/types'; | 
|  | 12 | +import { TerminalProvider } from '../../client/providers/terminalProvider'; | 
|  | 13 | + | 
|  | 14 | +// tslint:disable-next-line:max-func-body-length | 
|  | 15 | +suite('Terminal Provider', () => { | 
|  | 16 | + let serviceContainer: TypeMoq.IMock<IServiceContainer>; | 
|  | 17 | + let commandManager: TypeMoq.IMock<ICommandManager>; | 
|  | 18 | + let workspace: TypeMoq.IMock<IWorkspaceService>; | 
|  | 19 | + let documentManager: TypeMoq.IMock<IDocumentManager>; | 
|  | 20 | + let terminalProvider: TerminalProvider; | 
|  | 21 | + setup(() => { | 
|  | 22 | + serviceContainer = TypeMoq.Mock.ofType<IServiceContainer>(); | 
|  | 23 | + commandManager = TypeMoq.Mock.ofType<ICommandManager>(); | 
|  | 24 | + workspace = TypeMoq.Mock.ofType<IWorkspaceService>(); | 
|  | 25 | + documentManager = TypeMoq.Mock.ofType<IDocumentManager>(); | 
|  | 26 | + serviceContainer.setup(c => c.get(ICommandManager)).returns(() => commandManager.object); | 
|  | 27 | + serviceContainer.setup(c => c.get(IWorkspaceService)).returns(() => workspace.object); | 
|  | 28 | + serviceContainer.setup(c => c.get(IDocumentManager)).returns(() => documentManager.object); | 
|  | 29 | + }); | 
|  | 30 | + teardown(() => { | 
|  | 31 | + try { | 
|  | 32 | + terminalProvider.dispose(); | 
|  | 33 | + // tslint:disable-next-line:no-empty | 
|  | 34 | + } catch { } | 
|  | 35 | + }); | 
|  | 36 | + | 
|  | 37 | + test('Ensure command is registered', () => { | 
|  | 38 | + terminalProvider = new TerminalProvider(serviceContainer.object); | 
|  | 39 | + commandManager.verify(c => c.registerCommand(TypeMoq.It.isValue(Commands.Create_Terminal), TypeMoq.It.isAny(), TypeMoq.It.isAny()), TypeMoq.Times.once()); | 
|  | 40 | + }); | 
|  | 41 | + | 
|  | 42 | + test('Ensure command handler is disposed', () => { | 
|  | 43 | + const disposable = TypeMoq.Mock.ofType<Disposable>(); | 
|  | 44 | + commandManager.setup(c => c.registerCommand(TypeMoq.It.isValue(Commands.Create_Terminal), TypeMoq.It.isAny(), TypeMoq.It.isAny())).returns(() => disposable.object); | 
|  | 45 | + | 
|  | 46 | + terminalProvider = new TerminalProvider(serviceContainer.object); | 
|  | 47 | + terminalProvider.dispose(); | 
|  | 48 | + | 
|  | 49 | + disposable.verify(d => d.dispose(), TypeMoq.Times.once()); | 
|  | 50 | + }); | 
|  | 51 | + | 
|  | 52 | + test('Ensure terminal is created and displayed when command is invoked', () => { | 
|  | 53 | + const disposable = TypeMoq.Mock.ofType<Disposable>(); | 
|  | 54 | + let commandHandler: undefined | (() => void); | 
|  | 55 | + commandManager.setup(c => c.registerCommand(TypeMoq.It.isValue(Commands.Create_Terminal), TypeMoq.It.isAny(), TypeMoq.It.isAny())).returns((_cmd, callback) => { | 
|  | 56 | + commandHandler = callback; | 
|  | 57 | + return disposable.object; | 
|  | 58 | + }); | 
|  | 59 | + documentManager.setup(d => d.activeTextEditor).returns(() => undefined); | 
|  | 60 | + workspace.setup(w => w.workspaceFolders).returns(() => undefined); | 
|  | 61 | + | 
|  | 62 | + terminalProvider = new TerminalProvider(serviceContainer.object); | 
|  | 63 | + expect(commandHandler).not.to.be.equal(undefined, 'Handler not set'); | 
|  | 64 | + | 
|  | 65 | + const terminalServiceFactory = TypeMoq.Mock.ofType<ITerminalServiceFactory>(); | 
|  | 66 | + serviceContainer.setup(c => c.get(TypeMoq.It.isValue(ITerminalServiceFactory))).returns(() => terminalServiceFactory.object); | 
|  | 67 | + const terminalService = TypeMoq.Mock.ofType<TerminalService>(); | 
|  | 68 | + terminalServiceFactory.setup(t => t.createTerminalService(TypeMoq.It.isValue(undefined), TypeMoq.It.isValue('Python'))).returns(() => terminalService.object); | 
|  | 69 | + | 
|  | 70 | + commandHandler!.call(terminalProvider); | 
|  | 71 | + terminalService.verify(t => t.show(), TypeMoq.Times.once()); | 
|  | 72 | + }); | 
|  | 73 | + | 
|  | 74 | + test('Ensure terminal creation does not use uri of the active documents which is untitled', () => { | 
|  | 75 | + const disposable = TypeMoq.Mock.ofType<Disposable>(); | 
|  | 76 | + let commandHandler: undefined | (() => void); | 
|  | 77 | + commandManager.setup(c => c.registerCommand(TypeMoq.It.isValue(Commands.Create_Terminal), TypeMoq.It.isAny(), TypeMoq.It.isAny())).returns((_cmd, callback) => { | 
|  | 78 | + commandHandler = callback; | 
|  | 79 | + return disposable.object; | 
|  | 80 | + }); | 
|  | 81 | + const editor = TypeMoq.Mock.ofType<TextEditor>(); | 
|  | 82 | + documentManager.setup(d => d.activeTextEditor).returns(() => editor.object); | 
|  | 83 | + const document = TypeMoq.Mock.ofType<TextDocument>(); | 
|  | 84 | + document.setup(d => d.isUntitled).returns(() => true); | 
|  | 85 | + editor.setup(e => e.document).returns(() => document.object); | 
|  | 86 | + workspace.setup(w => w.workspaceFolders).returns(() => undefined); | 
|  | 87 | + | 
|  | 88 | + terminalProvider = new TerminalProvider(serviceContainer.object); | 
|  | 89 | + expect(commandHandler).not.to.be.equal(undefined, 'Handler not set'); | 
|  | 90 | + | 
|  | 91 | + const terminalServiceFactory = TypeMoq.Mock.ofType<ITerminalServiceFactory>(); | 
|  | 92 | + serviceContainer.setup(c => c.get(TypeMoq.It.isValue(ITerminalServiceFactory))).returns(() => terminalServiceFactory.object); | 
|  | 93 | + const terminalService = TypeMoq.Mock.ofType<TerminalService>(); | 
|  | 94 | + terminalServiceFactory.setup(t => t.createTerminalService(TypeMoq.It.isValue(undefined), TypeMoq.It.isValue('Python'))).returns(() => terminalService.object); | 
|  | 95 | + | 
|  | 96 | + commandHandler!.call(terminalProvider); | 
|  | 97 | + terminalService.verify(t => t.show(), TypeMoq.Times.once()); | 
|  | 98 | + }); | 
|  | 99 | + | 
|  | 100 | + test('Ensure terminal creation uses uri of active document', () => { | 
|  | 101 | + const disposable = TypeMoq.Mock.ofType<Disposable>(); | 
|  | 102 | + let commandHandler: undefined | (() => void); | 
|  | 103 | + commandManager.setup(c => c.registerCommand(TypeMoq.It.isValue(Commands.Create_Terminal), TypeMoq.It.isAny(), TypeMoq.It.isAny())).returns((_cmd, callback) => { | 
|  | 104 | + commandHandler = callback; | 
|  | 105 | + return disposable.object; | 
|  | 106 | + }); | 
|  | 107 | + const editor = TypeMoq.Mock.ofType<TextEditor>(); | 
|  | 108 | + documentManager.setup(d => d.activeTextEditor).returns(() => editor.object); | 
|  | 109 | + const document = TypeMoq.Mock.ofType<TextDocument>(); | 
|  | 110 | + const documentUri = Uri.file('a'); | 
|  | 111 | + document.setup(d => d.isUntitled).returns(() => false); | 
|  | 112 | + document.setup(d => d.uri).returns(() => documentUri); | 
|  | 113 | + editor.setup(e => e.document).returns(() => document.object); | 
|  | 114 | + workspace.setup(w => w.workspaceFolders).returns(() => undefined); | 
|  | 115 | + | 
|  | 116 | + terminalProvider = new TerminalProvider(serviceContainer.object); | 
|  | 117 | + expect(commandHandler).not.to.be.equal(undefined, 'Handler not set'); | 
|  | 118 | + | 
|  | 119 | + const terminalServiceFactory = TypeMoq.Mock.ofType<ITerminalServiceFactory>(); | 
|  | 120 | + serviceContainer.setup(c => c.get(TypeMoq.It.isValue(ITerminalServiceFactory))).returns(() => terminalServiceFactory.object); | 
|  | 121 | + const terminalService = TypeMoq.Mock.ofType<TerminalService>(); | 
|  | 122 | + terminalServiceFactory.setup(t => t.createTerminalService(TypeMoq.It.isValue(documentUri), TypeMoq.It.isValue('Python'))).returns(() => terminalService.object); | 
|  | 123 | + | 
|  | 124 | + commandHandler!.call(terminalProvider); | 
|  | 125 | + terminalService.verify(t => t.show(), TypeMoq.Times.once()); | 
|  | 126 | + }); | 
|  | 127 | + | 
|  | 128 | + test('Ensure terminal creation uses uri of active workspace', () => { | 
|  | 129 | + const disposable = TypeMoq.Mock.ofType<Disposable>(); | 
|  | 130 | + let commandHandler: undefined | (() => void); | 
|  | 131 | + commandManager.setup(c => c.registerCommand(TypeMoq.It.isValue(Commands.Create_Terminal), TypeMoq.It.isAny(), TypeMoq.It.isAny())).returns((_cmd, callback) => { | 
|  | 132 | + commandHandler = callback; | 
|  | 133 | + return disposable.object; | 
|  | 134 | + }); | 
|  | 135 | + documentManager.setup(d => d.activeTextEditor).returns(() => undefined); | 
|  | 136 | + const workspaceUri = Uri.file('a'); | 
|  | 137 | + const workspaceFolder = TypeMoq.Mock.ofType<WorkspaceFolder>(); | 
|  | 138 | + workspaceFolder.setup(w => w.uri).returns(() => workspaceUri); | 
|  | 139 | + workspace.setup(w => w.workspaceFolders).returns(() => [workspaceFolder.object]); | 
|  | 140 | + | 
|  | 141 | + terminalProvider = new TerminalProvider(serviceContainer.object); | 
|  | 142 | + expect(commandHandler).not.to.be.equal(undefined, 'Handler not set'); | 
|  | 143 | + | 
|  | 144 | + const terminalServiceFactory = TypeMoq.Mock.ofType<ITerminalServiceFactory>(); | 
|  | 145 | + serviceContainer.setup(c => c.get(TypeMoq.It.isValue(ITerminalServiceFactory))).returns(() => terminalServiceFactory.object); | 
|  | 146 | + const terminalService = TypeMoq.Mock.ofType<TerminalService>(); | 
|  | 147 | + terminalServiceFactory.setup(t => t.createTerminalService(TypeMoq.It.isValue(workspaceUri), TypeMoq.It.isValue('Python'))).returns(() => terminalService.object); | 
|  | 148 | + | 
|  | 149 | + commandHandler!.call(terminalProvider); | 
|  | 150 | + terminalService.verify(t => t.show(), TypeMoq.Times.once()); | 
|  | 151 | + }); | 
|  | 152 | +}); | 
0 commit comments