Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[FP] RefOveruse #2825

Merged
merged 28 commits into from
Jun 3, 2023
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
7cf2091
refOverUse тест с фп
asosnoviy Jun 24, 2022
5a195a0
refOverUse тест с fp
asosnoviy Jun 24, 2022
b43f436
новые методы поиска
artbear Jun 24, 2022
b88f851
исправление FP
artbear Jun 24, 2022
7bbdff9
уточнил комментарии к методу
artbear Jun 24, 2022
fd1a831
refOverUse Fn тест
asosnoviy Jun 24, 2022
d1e3bd1
пропускались вложенные запросы
artbear Jun 24, 2022
28bc2da
исправил еще небольшое ФП
artbear Jun 24, 2022
aa7d88e
refOfuse fn test
asosnoviy Jun 24, 2022
e7586a1
учитываются поля без псевдонимов таблиц
artbear Jun 25, 2022
b171d5f
refOverUse fp test
asosnoviy Jun 27, 2022
9a6bdd1
FP полное имя таблицы
artbear Jun 27, 2022
fc91b7f
refOverUse fp test
asosnoviy Jun 28, 2022
1a3931e
ФП обращение к инлайн-таблице
artbear Jun 28, 2022
2b4f1d1
refOveruse fn fp tests
asosnoviy Jun 29, 2022
7bef41a
исправил FP
artbear Jul 1, 2022
caa878e
refOveruse fp
asosnoviy Jul 5, 2022
07f6ab2
Merge remote-tracking branch 'origin/develop' into fix/refOveruse
artbear Jul 18, 2022
262d231
заготовка под проверку метаданных
artbear Jul 18, 2022
74f66d2
CleanupContextBeforeClassAndAfterEachTestMethod
artbear Jul 19, 2022
834682a
Merge branch 'develop' into fix/refOveruse
artbear Dec 17, 2022
3e73343
Заготовка исправления
artbear Dec 24, 2022
b5f8661
убрал ненужные тесты
artbear Dec 24, 2022
7d7f3a0
вернул прохождение тестов
artbear Dec 24, 2022
7837e2a
заготовка анализа таблиц метаданных
artbear Dec 24, 2022
fe24ac3
форматирование + исправлены замечания
artbear Mar 31, 2023
1e9d3e7
возвращен неверно отправленный код
artbear Mar 31, 2023
7466713
переименовал метод + исправил имя параметра
artbear Mar 31, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -130,7 +130,7 @@ private Map<String, Boolean> dataSourcesWithTabularSection(SDBLParser.QueryConte
var newResult = findAllDataSourceWithoutInnerQueries(ctx)
.collect(Collectors.toMap(
RefOveruseDiagnostic::getTableNameOrAlias,
RefOveruseDiagnostic::isTableWithTabularSection,
this::isTableWithTabularSection,
(existing, replacement) -> existing,
HashMap::new));

Expand Down Expand Up @@ -196,7 +196,7 @@ private static String getTableNameOrAlias(DataSourceContext dataSource) {
.orElse("");
}

private static boolean isTableWithTabularSection(DataSourceContext dataSourceContext) {
private boolean isTableWithTabularSection(DataSourceContext dataSourceContext) {
final var table = dataSourceContext.table();
if (table == null) {
return dataSourceContext.virtualTable() != null;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
*/
package com.github._1c_syntax.bsl.languageserver.diagnostics;

import com.github._1c_syntax.utils.Absolute;
import org.eclipse.lsp4j.Diagnostic;
import org.junit.jupiter.api.Test;

Expand All @@ -29,12 +30,46 @@
import static com.github._1c_syntax.bsl.languageserver.util.Assertions.assertThat;

class RefOveruseDiagnosticTest extends AbstractDiagnosticTest<RefOveruseDiagnostic> {
private static final String PATH_TO_METADATA = "src/test/resources/metadata/designer";

RefOveruseDiagnosticTest() {
super(RefOveruseDiagnostic.class);
}

@Test
void test() {
initServerContext(Absolute.path(PATH_TO_METADATA));
nixel2007 marked this conversation as resolved.
Show resolved Hide resolved

List<Diagnostic> diagnostics = getDiagnostics();

assertThat(diagnostics, true)
.hasRange(3, 28, 3, 45)
.hasRange(13, 8, 13, 34)
.hasRange(14, 8, 14, 38)
.hasRange(25, 8, 25, 21)
.hasRange(37, 8, 37, 29)
.hasRange(38, 8, 38, 35)
.hasRange(56, 37, 56, 43)
.hasRange(57, 42, 57, 48)
.hasRange(92, 8, 29)
.hasRange(153, 13, 153, 41)
.hasRange(164, 13, 164, 53)
.hasRange(178, 13, 178, 35)
.hasRange(216, 13, 37)
.hasRange(226, 13, 37)
.hasRange(238, 13, 38)
.hasRange(296, 33, 80)
.hasRange(300, 33, 70)
.hasRange(309, 12, 28)
.hasRange(309, 12, 28)
.hasRange(342, 12, 56)
.hasRange(343, 12, 56)
.hasRange(354, 26, 96)
// .hasRange(375, 20, 92)
.hasSize(21);
}
@Test
void testSingleFile() {

List<Diagnostic> diagnostics = getDiagnostics();

Expand All @@ -61,6 +96,7 @@ void test() {
.hasRange(342, 12, 56)
.hasRange(343, 12, 56)
.hasRange(354, 26, 96)
// .hasRange(375, 20, 92)
.hasSize(21);
}
}
39 changes: 24 additions & 15 deletions src/test/resources/diagnostics/RefOveruseDiagnostic.bsl
Original file line number Diff line number Diff line change
@@ -1,3 +1,10 @@
Процедура Тест31()
Запрос.Текст =
"ВЫБРАТЬ
| Справочник1.ТабличнаяЧасть1.Ссылка
|ИЗ
| Справочник.Справочник1 КАК Справочник1";
КонецПроцедуры
Процедура Тест()

Запрос = Новый Запрос;
Expand Down Expand Up @@ -359,20 +366,22 @@
| Справочник.Пользователи.ДополнительныеРеквизиты КАК ПользователиДополнительныеРеквизиты";
КонецПроцедуры

Процедура Тест30()

Запрос.Текст =
"ВЫБРАТЬ
| УдалитьСоглашенияОбИспользованииЭД.Ссылка
|ИЗ
| Справочник.УдалитьСоглашенияОбИспользованииЭД КАК УдалитьСоглашенияОбИспользованииЭД
|ГДЕ
| НЕ УдалитьСоглашенияОбИспользованииЭД.УдалитьИспользуетсяКриптография
|
|СГРУППИРОВАТЬ ПО
| УдалитьСоглашенияОбИспользованииЭД.Ссылка
|
|ИМЕЮЩИЕ
| КОЛИЧЕСТВО(УдалитьСоглашенияОбИспользованииЭД.СертификатыПодписейОрганизации.Ссылка) > 0"
Процедура Тест31()
Запрос.Текст =
"ВЫБРАТЬ
| Справочник1.ТабличнаяЧасть1.Ссылка
|ИЗ
| Справочник.Справочник1 КАК Справочник1";
КонецПроцедуры

Процедура Тест32()
Запрос.Текст =
"ВЫБРАТЬ
| Справочник1.Ссылка
|ИЗ
| Справочник.Справочник1 КАК Справочник1
|СГРУППИРОВАТЬ ПО
| Справочник1.Ссылка
|ИМЕЮЩИЕ
| КОЛИЧЕСТВО(Справочник1.ТабличнаяЧасть1.Ссылка) > 0";
КонецПроцедуры