mirror of
https://github.com/grafana/grafana.git
synced 2025-08-01 06:51:49 +08:00
97 lines
3.0 KiB
TypeScript
97 lines
3.0 KiB
TypeScript
import { monacoTypes, Monaco } from '@grafana/ui';
|
|
|
|
import { CompletionProvider } from './autocomplete';
|
|
|
|
describe('CompletionProvider', () => {
|
|
it('suggests labels', async () => {
|
|
const { provider, model } = setup('{}', 1, defaultLabels);
|
|
const result = await provider.provideCompletionItems(model, {} as monacoTypes.Position);
|
|
expect((result! as monacoTypes.languages.CompletionList).suggestions).toEqual([
|
|
expect.objectContaining({ label: 'foo', insertText: 'foo' }),
|
|
]);
|
|
});
|
|
|
|
it('suggests label names with quotes', async () => {
|
|
const { provider, model } = setup('{foo=}', 6, defaultLabels);
|
|
const result = await provider.provideCompletionItems(model, {} as monacoTypes.Position);
|
|
expect((result! as monacoTypes.languages.CompletionList).suggestions).toEqual([
|
|
expect.objectContaining({ label: 'bar', insertText: '"bar"' }),
|
|
]);
|
|
});
|
|
|
|
it('suggests label names without quotes', async () => {
|
|
const { provider, model } = setup('{foo="}', 7, defaultLabels);
|
|
const result = await provider.provideCompletionItems(model, {} as monacoTypes.Position);
|
|
expect((result! as monacoTypes.languages.CompletionList).suggestions).toEqual([
|
|
expect.objectContaining({ label: 'bar', insertText: 'bar' }),
|
|
]);
|
|
});
|
|
|
|
it('suggests nothing without labels', async () => {
|
|
const { provider, model } = setup('{foo="}', 7, []);
|
|
const result = await provider.provideCompletionItems(model, {} as monacoTypes.Position);
|
|
expect((result! as monacoTypes.languages.CompletionList).suggestions).toEqual([]);
|
|
});
|
|
|
|
it('suggests labels on empty input', async () => {
|
|
const { provider, model } = setup('', 0, defaultLabels);
|
|
const result = await provider.provideCompletionItems(model, {} as monacoTypes.Position);
|
|
expect((result! as monacoTypes.languages.CompletionList).suggestions).toEqual([
|
|
expect.objectContaining({ label: 'foo', insertText: '{foo="' }),
|
|
]);
|
|
});
|
|
});
|
|
|
|
const defaultLabels = ['foo'];
|
|
|
|
function setup(value: string, offset: number, labels: string[] = []) {
|
|
const provider = new CompletionProvider();
|
|
provider.init(labels, (label) => {
|
|
if (labels.length === 0) {
|
|
return Promise.resolve([]);
|
|
}
|
|
const val = { foo: 'bar' }[label];
|
|
const result = [];
|
|
if (val) {
|
|
result.push(val);
|
|
}
|
|
return Promise.resolve(result);
|
|
});
|
|
const model = makeModel(value, offset);
|
|
provider.monaco = {
|
|
Range: {
|
|
fromPositions() {
|
|
return null;
|
|
},
|
|
},
|
|
languages: {
|
|
CompletionItemKind: {
|
|
Enum: 1,
|
|
EnumMember: 2,
|
|
},
|
|
},
|
|
} as unknown as Monaco;
|
|
provider.editor = {
|
|
getModel() {
|
|
return model;
|
|
},
|
|
} as monacoTypes.editor.IStandaloneCodeEditor;
|
|
|
|
return { provider, model };
|
|
}
|
|
|
|
function makeModel(value: string, offset: number) {
|
|
return {
|
|
id: 'test_monaco',
|
|
getWordAtPosition() {
|
|
return null;
|
|
},
|
|
getOffsetAt() {
|
|
return offset;
|
|
},
|
|
getValue() {
|
|
return value;
|
|
},
|
|
} as unknown as monacoTypes.editor.ITextModel;
|
|
}
|