refactor(language-service): migrate quick_info_spec to new testing package (#40966)

refactor(language-service): migrate quick_info_spec to new testing package

PR Close #40966
This commit is contained in:
Andrew Scott 2021-02-08 11:14:16 -08:00 committed by atscott
parent d2b43d577b
commit d1b7774753
2 changed files with 33 additions and 32 deletions

View File

@ -6,18 +6,14 @@
* found in the LICENSE file at https://angular.io/license * found in the LICENSE file at https://angular.io/license
*/ */
import {absoluteFrom, AbsoluteFsPath} from '@angular/compiler-cli/src/ngtsc/file_system'; import {initMockFileSystem} from '@angular/compiler-cli/src/ngtsc/file_system/testing';
import {initMockFileSystem, TestFile} from '@angular/compiler-cli/src/ngtsc/file_system/testing';
import * as ts from 'typescript/lib/tsserverlibrary'; import * as ts from 'typescript/lib/tsserverlibrary';
import {extractCursorInfo, LanguageServiceTestEnv, Project} from '../testing';
import {LanguageServiceTestEnvironment} from './env'; function quickInfoSkeleton(): {[fileName: string]: string} {
return {
function quickInfoSkeleton(): TestFile[] { 'app.ts': `
return [
{
name: absoluteFrom('/app.ts'),
contents: `
import {Component, Directive, EventEmitter, Input, NgModule, Output, Pipe, PipeTransform} from '@angular/core'; import {Component, Directive, EventEmitter, Input, NgModule, Output, Pipe, PipeTransform} from '@angular/core';
import {CommonModule} from '@angular/common'; import {CommonModule} from '@angular/common';
@ -92,22 +88,19 @@ function quickInfoSkeleton(): TestFile[] {
}) })
export class AppModule {} export class AppModule {}
`, `,
isRoot: true, 'app.html': `Will be overridden`,
}, };
{
name: absoluteFrom('/app.html'),
contents: `Will be overridden`,
}
];
} }
describe('quick info', () => { describe('quick info', () => {
let env: LanguageServiceTestEnvironment; let env: LanguageServiceTestEnv;
let project: Project;
describe('strict templates (happy path)', () => { describe('strict templates (happy path)', () => {
beforeEach(() => { beforeEach(() => {
initMockFileSystem('Native'); initMockFileSystem('Native');
env = LanguageServiceTestEnvironment.setup(quickInfoSkeleton()); env = LanguageServiceTestEnv.setup();
project = env.addProject('test', quickInfoSkeleton());
}); });
describe('elements', () => { describe('elements', () => {
@ -476,9 +469,10 @@ describe('quick info', () => {
}); });
it('should provide documentation', () => { it('should provide documentation', () => {
const {cursor} = const template = project.openFile('app.html');
env.updateFileWithCursor(absoluteFrom('/app.html'), `<div>{{¦title}}</div>`); template.contents = `<div>{{title}}</div>`;
const quickInfo = env.ngLS.getQuickInfoAtPosition(absoluteFrom('/app.html'), cursor); template.moveCursorToText('{{¦title}}');
const quickInfo = template.getQuickInfoAtPosition();
const documentation = toText(quickInfo!.documentation); const documentation = toText(quickInfo!.documentation);
expect(documentation).toBe('This is the title of the `AppCmp` Component.'); expect(documentation).toBe('This is the title of the `AppCmp` Component.');
}); });
@ -486,10 +480,13 @@ describe('quick info', () => {
}); });
describe('non-strict compiler options', () => { describe('non-strict compiler options', () => {
it('should find input binding on text attribute when strictAttributeTypes is false', () => { beforeEach(() => {
initMockFileSystem('Native'); initMockFileSystem('Native');
env = env = LanguageServiceTestEnv.setup();
LanguageServiceTestEnvironment.setup(quickInfoSkeleton(), {strictAttributeTypes: false}); });
it('should find input binding on text attribute when strictAttributeTypes is false', () => {
project = env.addProject('test', quickInfoSkeleton(), {strictAttributeTypes: false});
expectQuickInfo({ expectQuickInfo({
templateOverride: `<test-comp tcN¦ame="title"></test-comp>`, templateOverride: `<test-comp tcN¦ame="title"></test-comp>`,
expectedSpanText: 'tcName', expectedSpanText: 'tcName',
@ -498,9 +495,7 @@ describe('quick info', () => {
}); });
it('can still get quick info when strictOutputEventTypes is false', () => { it('can still get quick info when strictOutputEventTypes is false', () => {
initMockFileSystem('Native'); project = env.addProject('test', quickInfoSkeleton(), {strictOutputEventTypes: false});
env = LanguageServiceTestEnvironment.setup(
quickInfoSkeleton(), {strictOutputEventTypes: false});
expectQuickInfo({ expectQuickInfo({
templateOverride: `<test-comp (te¦st)="myClick($event)"></test-comp>`, templateOverride: `<test-comp (te¦st)="myClick($event)"></test-comp>`,
expectedSpanText: 'test', expectedSpanText: 'test',
@ -509,9 +504,8 @@ describe('quick info', () => {
}); });
it('should work for pipes even if checkTypeOfPipes is false', () => { it('should work for pipes even if checkTypeOfPipes is false', () => {
initMockFileSystem('Native');
// checkTypeOfPipes is set to false when strict templates is false // checkTypeOfPipes is set to false when strict templates is false
env = LanguageServiceTestEnvironment.setup(quickInfoSkeleton(), {strictTemplates: false}); project = env.addProject('test', quickInfoSkeleton(), {strictTemplates: false});
const templateOverride = `<p>The hero's birthday is {{birthday | da¦te: "MM/dd/yy"}}</p>`; const templateOverride = `<p>The hero's birthday is {{birthday | da¦te: "MM/dd/yy"}}</p>`;
expectQuickInfo( expectQuickInfo(
{templateOverride, expectedSpanText: 'date', expectedDisplayString: '(pipe) DatePipe'}); {templateOverride, expectedSpanText: 'date', expectedDisplayString: '(pipe) DatePipe'});
@ -522,10 +516,13 @@ describe('quick info', () => {
{templateOverride, expectedSpanText, expectedDisplayString}: {templateOverride, expectedSpanText, expectedDisplayString}:
{templateOverride: string, expectedSpanText: string, expectedDisplayString: string}): {templateOverride: string, expectedSpanText: string, expectedDisplayString: string}):
ts.QuickInfo { ts.QuickInfo {
const {cursor, text} = env.updateFileWithCursor(absoluteFrom('/app.html'), templateOverride); const {text} = extractCursorInfo(templateOverride);
const template = project.openFile('app.html');
template.contents = text;
env.expectNoSourceDiagnostics(); env.expectNoSourceDiagnostics();
env.expectNoTemplateDiagnostics(absoluteFrom('/app.ts'), 'AppCmp');
const quickInfo = env.ngLS.getQuickInfoAtPosition(absoluteFrom('/app.html'), cursor); template.moveCursorToText(templateOverride);
const quickInfo = template.getQuickInfoAtPosition();
expect(quickInfo).toBeTruthy(); expect(quickInfo).toBeTruthy();
const {textSpan, displayParts} = quickInfo!; const {textSpan, displayParts} = quickInfo!;
expect(text.substring(textSpan.start, textSpan.start + textSpan.length)) expect(text.substring(textSpan.start, textSpan.start + textSpan.length))

View File

@ -80,4 +80,8 @@ export class OpenBuffer {
getTcb() { getTcb() {
return this.ngLS.getTcb(this.scriptInfo.fileName, this._cursor); return this.ngLS.getTcb(this.scriptInfo.fileName, this._cursor);
} }
getQuickInfoAtPosition() {
return this.ngLS.getQuickInfoAtPosition(this.scriptInfo.fileName, this._cursor);
}
} }