Path: blob/main/extensions/copilot/test/inline/slashDoc.util.ts
13388 views
/*---------------------------------------------------------------------------------------------1* Copyright (c) Microsoft Corporation. All rights reserved.2* Licensed under the MIT License. See License.txt in the project root for license information.3*--------------------------------------------------------------------------------------------*/4import * as assert from 'assert';56export function assertDocLines(fileContents: string | string[], line: string, lineAssertion = (line: string) => { }) {78const fileLines = (Array.isArray(fileContents)) ? fileContents : fileContents.split('\n');910const lineNum = fileLines.findIndex(s => s.startsWith(line));11assert.ok(lineNum >= 0, 'missing or unterminated doc comment');1213assert.strictEqual(fileLines[lineNum - 1].trim(), '*/', 'has closing */');1415for (let i = lineNum - 2; i >= 0; --i) {16const line = fileLines[i];17if (line.trimStart().startsWith('/**')) {18return;19}20assert.ok(line.trimStart().startsWith('*'), 'has middle *');21lineAssertion(line);22}2324}2526/**27* Golang & Ruby use inline comments for doc comments, ie golang uses `//` both for implementation & doc comments28*/29export function assertDocLinesForInlineComments(fileContents: string | string[], line: string, docCommentPrefix: string) {3031const fileLines = (Array.isArray(fileContents)) ? fileContents : fileContents.split('\n');3233const lineNum = fileLines.lastIndexOf(line);3435if (lineNum === -1) { throw new Error(`given line cannot be found: either original line was changed or test was incorrectly created`); }3637const indentation = fileLines[lineNum].match(/^\s+/)?.[0] ?? '';38const expectedPrefix = `${indentation}${docCommentPrefix}`;3940let hadDoc = false;41for (let i = lineNum - 1; i >= 0; --i) {42const line = fileLines[i];43if (line.startsWith(expectedPrefix)) {44hadDoc = true;45} else {46break;47}48}49assert.ok(hadDoc, 'did not see comments');50}515253