Skip to content

Commit

Permalink
improve search smoke test (microsoft#161652)
Browse files Browse the repository at this point in the history
* improve search smoke test
* prevent text to show when clearing results
  • Loading branch information
andreamah authored and filiptronicek committed Oct 13, 2022
1 parent f841ad3 commit 75579c6
Show file tree
Hide file tree
Showing 4 changed files with 18 additions and 15 deletions.
6 changes: 3 additions & 3 deletions src/vs/workbench/contrib/search/browser/searchView.ts
Original file line number Diff line number Diff line change
Expand Up @@ -532,7 +532,7 @@ export class SearchView extends ViewPane {

private refreshAndUpdateCount(event?: IChangeEvent): void {
this.searchWidget.setReplaceAllActionState(!this.viewModel.searchResult.isEmpty());
this.updateSearchResultCount(this.viewModel.searchResult.query!.userDisabledExcludesAndIgnoreFiles, this.viewModel.searchResult.query?.onlyOpenEditors);
this.updateSearchResultCount(this.viewModel.searchResult.query!.userDisabledExcludesAndIgnoreFiles, this.viewModel.searchResult.query?.onlyOpenEditors, event?.clearingAll);
return this.refreshTree(event);
}

Expand Down Expand Up @@ -1655,14 +1655,14 @@ export class SearchView extends ViewPane {
this.inputPatternIncludes.setOnlySearchInOpenEditors(false);
}

private updateSearchResultCount(disregardExcludesAndIgnores?: boolean, onlyOpenEditors?: boolean): void {
private updateSearchResultCount(disregardExcludesAndIgnores?: boolean, onlyOpenEditors?: boolean, clear: boolean = false): void {
const fileCount = this.viewModel.searchResult.fileCount();
this.hasSearchResultsKey.set(fileCount > 0);

const msgWasHidden = this.messagesElement.style.display === 'none';

const messageEl = this.clearMessage();
const resultMsg = this.buildResultCountMessage(this.viewModel.searchResult.count(), fileCount);
const resultMsg = clear ? '' : this.buildResultCountMessage(this.viewModel.searchResult.count(), fileCount);
this.tree.ariaLabel = resultMsg + nls.localize('forTerm', " - Search: {0}", this.searchResult.query?.contentPattern.pattern ?? '');
dom.append(messageEl, resultMsg);

Expand Down
7 changes: 4 additions & 3 deletions src/vs/workbench/contrib/search/common/searchModel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -476,6 +476,7 @@ export interface IChangeEvent {
elements: FileMatch[];
added?: boolean;
removed?: boolean;
clearingAll?: boolean;
}

export class FolderMatch extends Disposable {
Expand Down Expand Up @@ -578,10 +579,10 @@ export class FolderMatch extends Disposable {
folderMatch.onDispose(() => disposable.dispose());
}

clear(): void {
clear(clearingAll = false): void {
const changed: FileMatch[] = this.downstreamFileMatches();
this.disposeMatches();
this._onChange.fire({ elements: changed, removed: true, added: false });
this._onChange.fire({ elements: changed, removed: true, added: false, clearingAll });
}

remove(matches: FileMatch | FolderMatchWithResource | (FileMatch | FolderMatchWithResource)[]): void {
Expand Down Expand Up @@ -1191,7 +1192,7 @@ export class SearchResult extends Disposable {
}

clear(): void {
this.folderMatches().forEach((folderMatch) => folderMatch.clear());
this.folderMatches().forEach((folderMatch) => folderMatch.clear(true));
this.disposeMatches();
this._folderMatches = [];
this._otherFilesMatch = null;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -449,7 +449,7 @@ suite('SearchResult', () => {
testObject.onChange(target);
testObject.remove(folderMatch);
assert.ok(target.calledOnce);
assert.deepStrictEqual([{ elements: expectedArrayResult, removed: true, added: false }], target.args[0]);
assert.deepStrictEqual([{ elements: expectedArrayResult, removed: true, added: false, clearingAll: false }], target.args[0]);
});

test('Replacing an intermediate folder should remove all downstream folders and file matches', async function () {
Expand Down
18 changes: 10 additions & 8 deletions test/smoke/src/areas/search/search.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,14 +29,16 @@ export function setup(logger: Logger) {

it('searches only for *.js files & checks for correct result number', async function () {
const app = this.app as Application;
await app.workbench.search.searchFor('body');
await app.workbench.search.showQueryDetails();
await app.workbench.search.setFilesToIncludeText('*.js');
await app.workbench.search.submitSearch();

await app.workbench.search.waitForResultText('4 results in 1 file');
await app.workbench.search.setFilesToIncludeText('');
await app.workbench.search.hideQueryDetails();
try {
await app.workbench.search.setFilesToIncludeText('*.js');
await app.workbench.search.searchFor('body');
await app.workbench.search.showQueryDetails();

await app.workbench.search.waitForResultText('4 results in 1 file');
} finally {
await app.workbench.search.setFilesToIncludeText('');
await app.workbench.search.hideQueryDetails();
}
});

it('dismisses result & checks for correct result number', async function () {
Expand Down

0 comments on commit 75579c6

Please sign in to comment.