diff --git a/CHANGELOG.md b/CHANGELOG.md
index 9b9c4065..9272f327 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -48,6 +48,7 @@
- Отсутствует удаление временного файла после использования.
- Структура модуля. Добавлена проверка области событий.
- Отсутствует включение безопасного режима перед вызовом метода "Выполнить" или "Вычислить"
+- Структура модуля. Добавлена проверка метода вне области.
#### Запросы
diff --git a/bundles/com.e1c.v8codestyle.bsl/markdown/module-structure-method-in-regions.md b/bundles/com.e1c.v8codestyle.bsl/markdown/module-structure-method-in-regions.md
new file mode 100644
index 00000000..b925ae6a
--- /dev/null
+++ b/bundles/com.e1c.v8codestyle.bsl/markdown/module-structure-method-in-regions.md
@@ -0,0 +1,40 @@
+# Check the method is outside a region
+
+The method is outside a region
+
+The Interface section contains export procedures and functions intended for use by other configuration objects or
+by other programs (for example, via an external connection).
+The Internal procedures and functions section contains procedures and functions that comprise
+the internal implementation of the common module. When a common module is a part of some functional subsystem
+that includes multiple metadata objects, this section can also contain other internal export procedures and
+functions intended to be called only from other objects of this subsystem.
+
+## Noncompliant Code Example
+
+```bsl
+
+Procedure Noncompliant()
+//...
+EndProcedure
+
+```bsl
+
+## Compliant Solution
+
+```bsl
+
+#Region Private
+
+Procedure Compliant()
+//...
+EndProcedure
+
+#EndRegion
+
+```bsl
+
+## See
+
+
+- [Module structure](https://1c-dn.com/library/module_structure/)
+- [Module structure](https://support.1ci.com/hc/en-us/articles/360011002360-Module-structure)
diff --git a/bundles/com.e1c.v8codestyle.bsl/markdown/ru/module-structure-method-in-regions.md b/bundles/com.e1c.v8codestyle.bsl/markdown/ru/module-structure-method-in-regions.md
new file mode 100644
index 00000000..4f21ce92
--- /dev/null
+++ b/bundles/com.e1c.v8codestyle.bsl/markdown/ru/module-structure-method-in-regions.md
@@ -0,0 +1,62 @@
+# Проверяет что метод находится в области
+
+Метод находится в области
+
+Раздел «Программный интерфейс» содержит экспортные процедуры и функции, предназначенные для использования
+другими объектами конфигурации или другими программами (например, через внешнее соединение).
+Раздел «Служебный программный интерфейс» предназначен для модулей, которые являются частью некоторой функциональной
+подсистемы. В нем должны быть размещены экспортные процедуры и функции, которые допустимо вызывать только из других
+функциональных подсистем этой же библиотеки.
+Раздел «Служебные процедуры и функции» содержит процедуры и функции, составляющие внутреннюю реализацию общего модуля.
+В тех случаях, когда общий модуль является частью некоторой функциональной подсистемы, включающей в себя несколько
+объектов метаданных, в этом разделе также могут быть размещены служебные экспортные процедуры и функции, предназначенные
+только для вызова из других объектов данной подсистемы.
+
+## Неправильно
+
+```bsl
+
+Процедура МетодВызываемыйИзВне() Экспорт
+
+КонецПроцедуры
+
+#Область ПрограммныйИнтерфейс
+// Код процедур и функций
+#КонецОбласти
+
+#Область СлужебныйПрограммныйИнтерфейс
+// Код процедур и функций
+#КонецОбласти
+
+#Область СлужебныеПроцедурыИФункции
+// Код процедур и функций
+#КонецОбласти
+
+```
+
+## Правильно
+
+```bsl
+
+#Область ПрограммныйИнтерфейс
+
+Процедура МетодВызываемыйИзВне() Экспорт
+
+КонецПроцедуры
+
+#КонецОбласти
+
+#Область СлужебныйПрограммныйИнтерфейс
+// Код процедур и функций
+#КонецОбласти
+
+#Область СлужебныеПроцедурыИФункции
+// Код процедур и функций
+#КонецОбласти
+
+```
+
+## См.
+
+
+- [Структура модуля](https://its.1c.ru/db/v8std#content:455:hdoc)
diff --git a/bundles/com.e1c.v8codestyle.bsl/plugin.xml b/bundles/com.e1c.v8codestyle.bsl/plugin.xml
index 6487e86a..97085619 100644
--- a/bundles/com.e1c.v8codestyle.bsl/plugin.xml
+++ b/bundles/com.e1c.v8codestyle.bsl/plugin.xml
@@ -115,6 +115,10 @@
+
+
getFirstParentRegion(RegionPreprocessor object)
+ protected Optional getFirstParentRegion(EObject object)
{
EObject parent = object.eContainer();
PreprocessorItem lastItem = null;
@@ -83,8 +83,10 @@ public abstract class AbstractModuleStructureCheck
{
return Optional.ofNullable(parentRegion);
}
-
- return Optional.empty();
+ else
+ {
+ lastItem = null;
+ }
}
else if (parent instanceof PreprocessorItem)
{
diff --git a/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/Messages.java b/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/Messages.java
index d492bda1..044614bc 100644
--- a/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/Messages.java
+++ b/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/Messages.java
@@ -154,6 +154,16 @@ final class Messages
public static String ModuleStructureEventRegionsCheck_Title;
+ public static String ModuleStructureMethodInRegionCheck_Description;
+
+ public static String ModuleStructureMethodInRegionCheck_Method_should_be_placed_in_one_of_the_standard_regions;
+
+ public static String ModuleStructureMethodInRegionCheck_Multilevel_nesting_of_regions;
+
+ public static String ModuleStructureMethodInRegionCheck_Only_export;
+
+ public static String ModuleStructureMethodInRegionCheck_Title;
+
public static String QueryInLoop_check_query_in_infinite_loop;
public static String QueryInLoop_description;
public static String QueryInLoop_Loop_has_method_with_query__0;
diff --git a/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/ModuleStructureMethodInRegionCheck.java b/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/ModuleStructureMethodInRegionCheck.java
new file mode 100644
index 00000000..ad5d927e
--- /dev/null
+++ b/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/ModuleStructureMethodInRegionCheck.java
@@ -0,0 +1,147 @@
+/*******************************************************************************
+ * Copyright (C) 2022, 1C-Soft LLC and others.
+ *
+ * This program and the accompanying materials are made
+ * available under the terms of the Eclipse Public License 2.0
+ * which is available at https://www.eclipse.org/legal/epl-2.0/
+ *
+ * SPDX-License-Identifier: EPL-2.0
+ *
+ * Contributors:
+ * 1C-Soft LLC - initial API and implementation
+ *******************************************************************************/
+package com.e1c.v8codestyle.bsl.check;
+
+import static com._1c.g5.v8.dt.bsl.model.BslPackage.Literals.METHOD;
+
+import java.text.MessageFormat;
+import java.util.Collection;
+import java.util.Optional;
+
+import org.eclipse.core.runtime.IProgressMonitor;
+
+import com._1c.g5.v8.dt.bsl.model.Method;
+import com._1c.g5.v8.dt.bsl.model.ModuleType;
+import com._1c.g5.v8.dt.bsl.model.RegionPreprocessor;
+import com._1c.g5.v8.dt.core.platform.IV8Project;
+import com._1c.g5.v8.dt.core.platform.IV8ProjectManager;
+import com._1c.g5.v8.dt.mcore.McorePackage;
+import com._1c.g5.v8.dt.metadata.mdclass.ScriptVariant;
+import com.e1c.g5.v8.dt.check.CheckComplexity;
+import com.e1c.g5.v8.dt.check.ICheckParameters;
+import com.e1c.g5.v8.dt.check.components.ModuleTopObjectNameFilterExtension;
+import com.e1c.g5.v8.dt.check.settings.IssueSeverity;
+import com.e1c.g5.v8.dt.check.settings.IssueType;
+import com.e1c.v8codestyle.bsl.IModuleStructureProvider;
+import com.e1c.v8codestyle.bsl.ModuleStructureSection;
+import com.e1c.v8codestyle.check.StandardCheckExtension;
+import com.e1c.v8codestyle.internal.bsl.BslPlugin;
+import com.google.inject.Inject;
+
+/**
+ * Checks that the method is outside the regions.
+ * Checks the standard interface regions for the existence of non-export methods
+ * and the location of export methods outside the regions provided by the standard for export methods.
+ *
+ * @author Artem Iliukhin
+ *
+ */
+public class ModuleStructureMethodInRegionCheck
+ extends AbstractModuleStructureCheck
+{
+ private static final String CHECK_ID = "module-structure-method-in-regions"; //$NON-NLS-1$
+
+ private static final String DEFAULT_CHECK_NESTING_OF_REGIONS = Boolean.toString(Boolean.TRUE);
+
+ private static final String MULTILEVEL_NESTING_OF_REGIONS = "multilevelNestingOfRegions"; //$NON-NLS-1$
+
+ private final IModuleStructureProvider moduleStructureProvider;
+
+ private final IV8ProjectManager v8ProjectManager;
+
+ @Inject
+ public ModuleStructureMethodInRegionCheck(IModuleStructureProvider moduleStructureProvider,
+ IV8ProjectManager v8ProjectManager)
+ {
+ super();
+ this.moduleStructureProvider = moduleStructureProvider;
+ this.v8ProjectManager = v8ProjectManager;
+ }
+
+ @Override
+ public String getCheckId()
+ {
+ return CHECK_ID;
+ }
+
+ @Override
+ protected void configureCheck(CheckConfigurer builder)
+ {
+ builder.title(Messages.ModuleStructureMethodInRegionCheck_Title)
+ .description(
+ Messages.ModuleStructureMethodInRegionCheck_Description)
+ .complexity(CheckComplexity.NORMAL)
+ .severity(IssueSeverity.MINOR)
+ .issueType(IssueType.CODE_STYLE)
+ .extension(new ModuleTopObjectNameFilterExtension())
+ .extension(new StandardCheckExtension(getCheckId(), BslPlugin.PLUGIN_ID))
+ .module()
+ .checkedObjectType(METHOD)
+ .parameter(MULTILEVEL_NESTING_OF_REGIONS, Boolean.class, DEFAULT_CHECK_NESTING_OF_REGIONS,
+ Messages.ModuleStructureMethodInRegionCheck_Multilevel_nesting_of_regions);
+ }
+
+ @Override
+ protected void check(Object object, ResultAcceptor resultAceptor, ICheckParameters parameters,
+ IProgressMonitor monitor)
+ {
+
+ if (monitor.isCanceled())
+ {
+ return;
+ }
+
+ Method method = (Method)object;
+ IV8Project project = v8ProjectManager.getProject(method);
+ ScriptVariant scriptVariant = project.getScriptVariant();
+
+ ModuleType moduleType = getModuleType(method);
+ Collection regionNames = moduleStructureProvider.getModuleStructureRegions(moduleType, scriptVariant);
+
+ boolean multilevel = parameters.getBoolean(MULTILEVEL_NESTING_OF_REGIONS);
+
+ Optional region = multilevel ? getTopParentRegion(method) : getFirstParentRegion(method);
+
+ // An export method located out of region in a form and command module is checked
+ // by {@link ExportMethodInCommandFormModuleCheck}
+ if (region.isEmpty())
+ {
+ addIssue(resultAceptor, method, String.join(", ", regionNames)); //$NON-NLS-1$
+ }
+ else if (moduleType != ModuleType.FORM_MODULE && moduleType != ModuleType.COMMAND_MODULE)
+ {
+ String publicName = ModuleStructureSection.PUBLIC.getName(scriptVariant);
+ String internalName = ModuleStructureSection.INTERNAL.getName(scriptVariant);
+ String privateName = ModuleStructureSection.PRIVATE.getName(scriptVariant);
+ String regionName = region.get().getName();
+ if (!method.isExport() && (publicName.equals(regionName) || internalName.equals(regionName)))
+ {
+ resultAceptor.addIssue(
+ MessageFormat.format(Messages.ModuleStructureMethodInRegionCheck_Only_export, regionName),
+ McorePackage.Literals.NAMED_ELEMENT__NAME);
+ }
+ else if (method.isExport() && !(publicName.equals(regionName) || internalName.equals(regionName)
+ || privateName.equals(regionName)))
+ {
+ addIssue(resultAceptor, method, String.join(", ", publicName, internalName, privateName)); //$NON-NLS-1$
+ }
+ }
+ }
+
+ private void addIssue(ResultAcceptor resultAceptor, Method method, String regions)
+ {
+ resultAceptor.addIssue(MessageFormat.format(
+ Messages.ModuleStructureMethodInRegionCheck_Method_should_be_placed_in_one_of_the_standard_regions,
+ method.getName(), regions), McorePackage.Literals.NAMED_ELEMENT__NAME);
+ }
+}
diff --git a/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/messages.properties b/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/messages.properties
index b05b4e53..b5cae3bf 100644
--- a/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/messages.properties
+++ b/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/messages.properties
@@ -219,6 +219,16 @@ ModuleStructureEventRegionsCheck_Only_event_methods__0=Only event methods can be
ModuleStructureEventRegionsCheck_Title=Checks the region of event handlers for the existence of methods related only to handlers
+ModuleStructureMethodInRegionCheck_Description=Checks that the method is outside the standard region, and suggests placing the method in one of the standard regions for the current type of module
+
+ModuleStructureMethodInRegionCheck_Method_should_be_placed_in_one_of_the_standard_regions=The method "{0}" should be placed in one of the standard regions: {1}
+
+ModuleStructureMethodInRegionCheck_Multilevel_nesting_of_regions=Allow multilevel nesting of regions
+
+ModuleStructureMethodInRegionCheck_Only_export=Only export methods can be placed in the "{0}" region
+
+ModuleStructureMethodInRegionCheck_Title=Method is outside a standard region
+
NewColorCheck_Use_style_elements=To change the design, you should use style elements, and not set specific values directly in the controls
NewColorCheck_Use_style_elements_not_specific_values=To change the design, you should use style elements, and not set specific values directly in the controls. This is required in order for similar controls to look the same in all forms where they occur.
diff --git a/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/messages_ru.properties b/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/messages_ru.properties
index 8b3e7e35..7763ea20 100644
--- a/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/messages_ru.properties
+++ b/bundles/com.e1c.v8codestyle.bsl/src/com/e1c/v8codestyle/bsl/check/messages_ru.properties
@@ -204,6 +204,14 @@ ModuleStructureTopRegionCheck_error_message = Стандартная облас
ModuleStructureTopRegionCheck_title = Стандартная область структуры модуля верхнеуровневая
+ModuleStructureMethodInRegionCheck_Multilevel_nesting_of_regions = Разрешить многоуровневое вложение областей
+
+ModuleStructureMethodInRegionCheck_Title = Метод вне области
+
+ModuleStructureMethodInRegionCheck_Description = Проверяет что метод находится вне области, и предлагает поместить метод в одну из стандартных для текущего типа модуля область
+
+ModuleStructureMethodInRegionCheck_Method_should_be_placed_in_one_of_the_standard_regions = Метод "{0}" необходимо разместить в одной из верхнеуровневых областей: {1}
+
ModuleUnusedLocalVariableCheck_Description = Проверка модуля на наличие неиспользуемых локальных переменных
ModuleUnusedLocalVariableCheck_Probably_variable_not_initilized_yet__0 = Возможно, переменная ''{0}'' еще не была проинициализирована
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/src/com/e1c/v8codestyle/bsl/check/itests/ModuleStructureMethodInRegionCheckTest.java b/tests/com.e1c.v8codestyle.bsl.itests/src/com/e1c/v8codestyle/bsl/check/itests/ModuleStructureMethodInRegionCheckTest.java
new file mode 100644
index 00000000..ada955cf
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/src/com/e1c/v8codestyle/bsl/check/itests/ModuleStructureMethodInRegionCheckTest.java
@@ -0,0 +1,204 @@
+/*******************************************************************************
+ * Copyright (C) 2022, 1C-Soft LLC and others.
+ *
+ * This program and the accompanying materials are made
+ * available under the terms of the Eclipse Public License 2.0
+ * which is available at https://www.eclipse.org/legal/epl-2.0/
+ *
+ * SPDX-License-Identifier: EPL-2.0
+ *
+ * Contributors:
+ * 1C-Soft LLC - initial API and implementation
+ *******************************************************************************/
+package com.e1c.v8codestyle.bsl.check.itests;
+
+import static org.junit.Assert.assertEquals;
+
+import java.util.Collections;
+import java.util.List;
+import java.util.stream.Collectors;
+
+import org.eclipse.core.resources.IProject;
+import org.eclipse.core.runtime.Path;
+import org.junit.Before;
+import org.junit.Test;
+
+import com._1c.g5.v8.dt.core.platform.IDtProject;
+import com._1c.g5.v8.dt.validation.marker.IExtraInfoKeys;
+import com._1c.g5.v8.dt.validation.marker.Marker;
+import com.e1c.g5.v8.dt.check.settings.CheckUid;
+import com.e1c.g5.v8.dt.check.settings.ICheckSettings;
+import com.e1c.g5.v8.dt.testing.check.SingleProjectReadOnlyCheckTestBase;
+import com.e1c.v8codestyle.bsl.check.ModuleStructureMethodInRegionCheck;
+import com.e1c.v8codestyle.internal.bsl.BslPlugin;
+
+/**
+ * Tests for {@link ModuleStructureMethodInRegionCheck} check.
+ *
+ * @author Artem Iliukhin
+ */
+public class ModuleStructureMethodInRegionCheckTest
+ extends SingleProjectReadOnlyCheckTestBase
+{
+
+ private static final String CHECK_ID = "module-structure-method-in-regions"; //$NON-NLS-1$
+ private static final String PROJECT_NAME = "ModuleStructureMethodInRegionCheck";
+
+ private static final String COMMON_MODULE_NO_REGION_FILE_NAME =
+ "/src/CommonModules/CommonModuleNoRegion/Module.bsl";
+ private static final String COMMON_MODULE_AFTER_REGION_FILE_NAME =
+ "/src/CommonModules/CommonModuleAfterRegion/Module.bsl";
+ private static final String CATALOG_MODULE_MANAGER_EVENT_OUT_REGION_FILE_NAME =
+ "/src/Catalogs/CatalogOutOfRegion/ManagerModule.bsl";
+
+ private static final String COMMON_MODULE_IN_REGION_FILE_NAME =
+ "/src/CommonModules/CommonModuleInRegion/Module.bsl";
+ private static final String COMMON_MODULE_EXPORT_IN_REGION_FILE_NAME =
+ "/src/CommonModules/CommonModuleExportInRegion/Module.bsl";
+ private static final String COMMON_MODULE_EXPORT_IN_NON_INTERFACE_REGION_FILE_NAME =
+ "/src/CommonModules/CommonModuleInNonInterfaceRegion/Module.bsl";
+ private static final String COMMAND_MODULE_OUT_OF_REGION_FILE_NAME =
+ "/src/CommonCommands/CommonCommand/CommandModule.bsl";
+ private static final String FORM_MODULE_OUT_OF_REGION_FILE_NAME =
+ "/src/Catalogs/CatalogOutOfRegion/Forms/ItemForm/Module.bsl";
+ private static final Object MULTILEVEL_NESTING_OF_REGIONS = "multilevelNestingOfRegions";
+ private static final String COMMON_MODULE_OUT_OF_MULTI_REGION_FILE_NAME =
+ "/src/CommonModules/CommonModulMultiLevel/Module.bsl";
+ private static final String COMMON_MODULE_OUT_OF_MULTI_REGION_NONCOMPLIENT_FILE_NAME =
+ "/src/CommonModules/CommonModuleMultiLevel1/Module.bsl";
+
+ @Override
+ protected String getTestConfigurationName()
+ {
+ return PROJECT_NAME;
+ }
+
+ @Before
+ public void setSettings()
+ {
+ IDtProject dtProject = getProject();
+ IProject project = dtProject.getWorkspaceProject();
+ ICheckSettings settings = checkRepository.getSettings(new CheckUid(CHECK_ID, BslPlugin.PLUGIN_ID), project);
+ settings.getParameters().get(MULTILEVEL_NESTING_OF_REGIONS).setValue(Boolean.toString(Boolean.TRUE));
+ checkRepository.applyChanges(Collections.singleton(settings), project);
+ waitForDD(dtProject);
+ }
+
+ @Test
+ public void testNoRegion() throws Exception
+ {
+ List markers = getMarkers(COMMON_MODULE_NO_REGION_FILE_NAME);
+ assertEquals(1, markers.size());
+
+ assertEquals("1", markers.get(0).getExtraInfo().get(IExtraInfoKeys.TEXT_EXTRA_INFO_LINE_KEY));
+ }
+
+ @Test
+ public void testMethodAfterRegion() throws Exception
+ {
+ List markers = getMarkers(COMMON_MODULE_AFTER_REGION_FILE_NAME);
+ assertEquals(1, markers.size());
+
+ assertEquals("5", markers.get(0).getExtraInfo().get(IExtraInfoKeys.TEXT_EXTRA_INFO_LINE_KEY));
+ }
+
+ @Test
+ public void testEventModuleManagerOutOfRegion() throws Exception
+ {
+ List markers = getMarkers(CATALOG_MODULE_MANAGER_EVENT_OUT_REGION_FILE_NAME);
+ assertEquals(1, markers.size());
+
+ assertEquals("10", markers.get(0).getExtraInfo().get(IExtraInfoKeys.TEXT_EXTRA_INFO_LINE_KEY));
+ }
+
+ @Test
+ public void testExportMethodInNonInterfaceRegion() throws Exception
+ {
+ List markers = getMarkers(COMMON_MODULE_EXPORT_IN_NON_INTERFACE_REGION_FILE_NAME);
+ assertEquals(1, markers.size());
+
+ assertEquals("3", markers.get(0).getExtraInfo().get(IExtraInfoKeys.TEXT_EXTRA_INFO_LINE_KEY));
+ }
+
+ @Test
+ public void testMethodInRegion() throws Exception
+ {
+ List markers = getMarkers(COMMON_MODULE_IN_REGION_FILE_NAME);
+ assertEquals(1, markers.size());
+
+ assertEquals("3", markers.get(0).getExtraInfo().get(IExtraInfoKeys.TEXT_EXTRA_INFO_LINE_KEY));
+ }
+
+ @Test
+ public void testExportMethodInRegion() throws Exception
+ {
+ List markers = getMarkers(COMMON_MODULE_EXPORT_IN_REGION_FILE_NAME);
+ assertEquals(0, markers.size());
+ }
+
+ @Test
+ public void testMethodOutOfRegionInForm() throws Exception
+ {
+ List markers = getMarkers(FORM_MODULE_OUT_OF_REGION_FILE_NAME);
+ assertEquals(1, markers.size());
+
+ assertEquals("2", markers.get(0).getExtraInfo().get(IExtraInfoKeys.TEXT_EXTRA_INFO_LINE_KEY));
+ }
+
+ @Test
+ public void testMethodOutOfRegionInCommand() throws Exception
+ {
+ List markers = getMarkers(COMMAND_MODULE_OUT_OF_REGION_FILE_NAME);
+ assertEquals(1, markers.size());
+
+ assertEquals("3", markers.get(0).getExtraInfo().get(IExtraInfoKeys.TEXT_EXTRA_INFO_LINE_KEY));
+ }
+
+ @Test
+ public void testMethodOutOfNonMultiRegionOption() throws Exception
+ {
+ IDtProject dtProject = getProject();
+ IProject project = dtProject.getWorkspaceProject();
+ ICheckSettings settings = checkRepository.getSettings(new CheckUid(CHECK_ID, BslPlugin.PLUGIN_ID), project);
+ settings.getParameters().get(MULTILEVEL_NESTING_OF_REGIONS).setValue(Boolean.toString(Boolean.FALSE));
+ checkRepository.applyChanges(Collections.singleton(settings), project);
+ waitForDD(dtProject);
+
+ List markers = getMarkers(COMMON_MODULE_OUT_OF_MULTI_REGION_FILE_NAME);
+ assertEquals(0, markers.size());
+ }
+
+ @Test
+ public void testMethodOutOfNonMultiRegionOptionNonComplient() throws Exception
+ {
+ IDtProject dtProject = getProject();
+ IProject project = dtProject.getWorkspaceProject();
+ ICheckSettings settings = checkRepository.getSettings(new CheckUid(CHECK_ID, BslPlugin.PLUGIN_ID), project);
+ settings.getParameters().get(MULTILEVEL_NESTING_OF_REGIONS).setValue(Boolean.toString(Boolean.FALSE));
+ checkRepository.applyChanges(Collections.singleton(settings), project);
+ waitForDD(dtProject);
+
+ List markers = getMarkers(COMMON_MODULE_OUT_OF_MULTI_REGION_NONCOMPLIENT_FILE_NAME);
+ assertEquals(1, markers.size());
+
+ assertEquals("6", markers.get(0).getExtraInfo().get(IExtraInfoKeys.TEXT_EXTRA_INFO_LINE_KEY));
+ }
+
+ @Test
+ public void testMethodOutOfMultiRegionOption() throws Exception
+ {
+ List markers = getMarkers(COMMON_MODULE_OUT_OF_MULTI_REGION_FILE_NAME);
+ assertEquals(0, markers.size());
+ }
+
+ private List getMarkers(String moduleFileName)
+ {
+ String moduleId = Path.ROOT.append(getTestConfigurationName()).append(moduleFileName).toString();
+ List markers = List.of(markerManager.getMarkers(getProject().getWorkspaceProject(), moduleId));
+
+ return markers.stream()
+ .filter(marker -> CHECK_ID.equals(getCheckIdFromMarker(marker, getProject())))
+ .collect(Collectors.toList());
+ }
+
+}
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/.project b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/.project
new file mode 100644
index 00000000..8a35e658
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/.project
@@ -0,0 +1,18 @@
+
+
+ ModuleStructureMethodInRegionCheck
+
+
+
+
+
+ org.eclipse.xtext.ui.shared.xtextBuilder
+
+
+
+
+
+ org.eclipse.xtext.ui.shared.xtextNature
+ com._1c.g5.v8.dt.core.V8ConfigurationNature
+
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/.settings/org.eclipse.core.resources.prefs b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/.settings/org.eclipse.core.resources.prefs
new file mode 100644
index 00000000..99f26c02
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/.settings/org.eclipse.core.resources.prefs
@@ -0,0 +1,2 @@
+eclipse.preferences.version=1
+encoding/=UTF-8
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/DT-INF/PROJECT.PMF b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/DT-INF/PROJECT.PMF
new file mode 100644
index 00000000..6835f1cd
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/DT-INF/PROJECT.PMF
@@ -0,0 +1,2 @@
+Manifest-Version: 1.0
+Runtime-Version: 8.3.19
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/CatalogOutOfRegion.mdo b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/CatalogOutOfRegion.mdo
new file mode 100644
index 00000000..4a30056d
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/CatalogOutOfRegion.mdo
@@ -0,0 +1,43 @@
+
+
+
+
+
+
+
+
+
+ CatalogOutOfRegion
+
+ en
+ Catalog out of region
+
+ true
+ Catalog.CatalogOutOfRegion.StandardAttribute.Code
+ Catalog.CatalogOutOfRegion.StandardAttribute.Description
+ DontUse
+ Use
+ Managed
+ Use
+ 2
+ true
+ 9
+ 25
+ String
+ Variable
+ true
+ true
+ AsDescription
+ InDialog
+ BothWays
+ Catalog.CatalogOutOfRegion.Form.ItemForm
+
+ ItemForm
+
+ en
+ Item form
+
+ PersonalComputer
+ MobileDevice
+
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/Forms/ItemForm/Form.form b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/Forms/ItemForm/Form.form
new file mode 100644
index 00000000..26a05f97
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/Forms/ItemForm/Form.form
@@ -0,0 +1,143 @@
+
+
+
+ Code
+ 1
+ true
+ true
+
+ true
+
+
+ Object.Code
+
+
+ CodeExtendedTooltip
+ 3
+ true
+ true
+
+ true
+
+ Label
+ true
+ true
+
+ Left
+
+
+
+ CodeContextMenu
+ 2
+ true
+ true
+
+ true
+
+ true
+
+ InputField
+ EnterOnInput
+ true
+ Left
+ true
+
+ true
+ true
+ true
+ true
+ true
+ true
+
+
+
+ Description
+ 4
+ true
+ true
+
+ true
+
+
+ Object.Description
+
+
+ DescriptionExtendedTooltip
+ 6
+ true
+ true
+
+ true
+
+ Label
+ true
+ true
+
+ Left
+
+
+
+ DescriptionContextMenu
+ 5
+ true
+ true
+
+ true
+
+ true
+
+ InputField
+ EnterOnInput
+ true
+ Left
+ true
+
+ true
+ true
+ true
+ true
+ true
+ true
+
+
+
+ FormCommandBar
+ -1
+ true
+ true
+
+ true
+
+ Left
+ true
+
+ LockOwnerWindow
+ true
+ true
+ Vertical
+ true
+ true
+ true
+ true
+ true
+
+ Object
+ 1
+
+ CatalogObject.CatalogOutOfRegion
+
+
+ true
+
+
+ true
+
+ true
+ true
+
+
+
+
+
+
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/Forms/ItemForm/Module.bsl b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/Forms/ItemForm/Module.bsl
new file mode 100644
index 00000000..53cd9a77
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/Forms/ItemForm/Module.bsl
@@ -0,0 +1,4 @@
+
+Procedure UnComplient()
+
+EndProcedure
\ No newline at end of file
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/ManagerModule.bsl b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/ManagerModule.bsl
new file mode 100644
index 00000000..625e99da
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Catalogs/CatalogOutOfRegion/ManagerModule.bsl
@@ -0,0 +1,21 @@
+
+#Region Public
+// Enter code here.
+#EndRegion
+
+#Region EventHandlers
+
+#EndRegion
+
+Procedure FormGetProcessing(FormType, Parameters, SelectedForm, AdditionalInformation, StandardProcessing)
+ //TODO: Insert the handler content
+EndProcedure
+
+#Region Internal
+// Enter code here.
+#EndRegion
+
+#Region Private
+// Enter code here.
+#EndRegion
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonCommands/CommonCommand/CommandModule.bsl b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonCommands/CommonCommand/CommandModule.bsl
new file mode 100644
index 00000000..7ca68817
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonCommands/CommonCommand/CommandModule.bsl
@@ -0,0 +1,7 @@
+
+&AtClient
+Procedure CommandProcessing(CommandParameter, CommandExecuteParameters)
+ //TODO: Paste handler content.
+ //FormParameters = New Structure("", );
+ //OpenForm("CommonForm.", FormParameters, CommandExecuteParameters.Source, CommandExecuteParameters.Uniqueness, CommandExecuteParameters.Window, CommandExecuteParameters.URL);
+EndProcedure
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonCommands/CommonCommand/CommonCommand.mdo b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonCommands/CommonCommand/CommonCommand.mdo
new file mode 100644
index 00000000..cce16407
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonCommands/CommonCommand/CommonCommand.mdo
@@ -0,0 +1,10 @@
+
+
+ CommonCommand
+
+ en
+ Common command
+
+ ActionsPanelTools
+ Auto
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModulMultiLevel/CommonModulMultiLevel.mdo b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModulMultiLevel/CommonModulMultiLevel.mdo
new file mode 100644
index 00000000..32930493
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModulMultiLevel/CommonModulMultiLevel.mdo
@@ -0,0 +1,11 @@
+
+
+ CommonModulMultiLevel
+
+ en
+ Common modul multi level
+
+ true
+ true
+ true
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModulMultiLevel/Module.bsl b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModulMultiLevel/Module.bsl
new file mode 100644
index 00000000..033b280d
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModulMultiLevel/Module.bsl
@@ -0,0 +1,12 @@
+
+#Region Public
+
+#Region SecondLevel
+
+#EndRegion
+
+Procedure Complient() Export
+
+EndProcedure
+
+#EndRegion
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleAfterRegion/CommonModuleAfterRegion.mdo b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleAfterRegion/CommonModuleAfterRegion.mdo
new file mode 100644
index 00000000..38d40631
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleAfterRegion/CommonModuleAfterRegion.mdo
@@ -0,0 +1,11 @@
+
+
+ CommonModuleAfterRegion
+
+ en
+ Common module after region
+
+ true
+ true
+ true
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleAfterRegion/Module.bsl b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleAfterRegion/Module.bsl
new file mode 100644
index 00000000..b77d5f0a
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleAfterRegion/Module.bsl
@@ -0,0 +1,7 @@
+#Region Public
+
+#EndRegion
+
+Procedure NonComplient()
+
+EndProcedure
\ No newline at end of file
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleExportInRegion/CommonModuleExportInRegion.mdo b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleExportInRegion/CommonModuleExportInRegion.mdo
new file mode 100644
index 00000000..60c4cea2
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleExportInRegion/CommonModuleExportInRegion.mdo
@@ -0,0 +1,11 @@
+
+
+ CommonModuleExportInRegion
+
+ en
+ Common module export in region
+
+ true
+ true
+ true
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleExportInRegion/Module.bsl b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleExportInRegion/Module.bsl
new file mode 100644
index 00000000..54df149b
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleExportInRegion/Module.bsl
@@ -0,0 +1,8 @@
+#Region Public
+
+Procedure Complient() Export
+
+EndProcedure
+
+#EndRegion
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInNonInterfaceRegion/CommonModuleInNonInterfaceRegion.mdo b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInNonInterfaceRegion/CommonModuleInNonInterfaceRegion.mdo
new file mode 100644
index 00000000..9559be51
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInNonInterfaceRegion/CommonModuleInNonInterfaceRegion.mdo
@@ -0,0 +1,11 @@
+
+
+ CommonModuleInNonInterfaceRegion
+
+ en
+ Common module in non interface region
+
+ true
+ true
+ true
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInNonInterfaceRegion/Module.bsl b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInNonInterfaceRegion/Module.bsl
new file mode 100644
index 00000000..6b2aeffa
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInNonInterfaceRegion/Module.bsl
@@ -0,0 +1,8 @@
+#Region NonComplient
+
+Procedure NonComplient() Export
+
+EndProcedure
+
+#EndRegion
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInRegion/CommonModuleInRegion.mdo b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInRegion/CommonModuleInRegion.mdo
new file mode 100644
index 00000000..d8a6b52f
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInRegion/CommonModuleInRegion.mdo
@@ -0,0 +1,11 @@
+
+
+ CommonModuleInRegion
+
+ en
+ Common module in region
+
+ true
+ true
+ true
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInRegion/Module.bsl b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInRegion/Module.bsl
new file mode 100644
index 00000000..18b9f501
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleInRegion/Module.bsl
@@ -0,0 +1,8 @@
+#Region Public
+
+Procedure NonComplient()
+
+EndProcedure
+
+#EndRegion
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleMultiLevel1/CommonModuleMultiLevel1.mdo b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleMultiLevel1/CommonModuleMultiLevel1.mdo
new file mode 100644
index 00000000..dcfce7e1
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleMultiLevel1/CommonModuleMultiLevel1.mdo
@@ -0,0 +1,11 @@
+
+
+ CommonModuleMultiLevel1
+
+ en
+ Common module multi level1
+
+ true
+ true
+ true
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleMultiLevel1/Module.bsl b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleMultiLevel1/Module.bsl
new file mode 100644
index 00000000..08f39248
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleMultiLevel1/Module.bsl
@@ -0,0 +1,12 @@
+
+#Region Public
+
+#Region SecondLevel
+
+Procedure NonComplient() Export
+
+EndProcedure
+
+#EndRegion
+
+#EndRegion
\ No newline at end of file
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleNoRegion/CommonModuleNoRegion.mdo b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleNoRegion/CommonModuleNoRegion.mdo
new file mode 100644
index 00000000..5e104d98
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleNoRegion/CommonModuleNoRegion.mdo
@@ -0,0 +1,11 @@
+
+
+ CommonModuleNoRegion
+
+ en
+ Common module no region
+
+ true
+ true
+ true
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleNoRegion/Module.bsl b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleNoRegion/Module.bsl
new file mode 100644
index 00000000..b367e1f8
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/CommonModules/CommonModuleNoRegion/Module.bsl
@@ -0,0 +1,3 @@
+Procedure NonComplient()
+
+EndProcedure
\ No newline at end of file
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Configuration/CommandInterface.cmi b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Configuration/CommandInterface.cmi
new file mode 100644
index 00000000..0cf6de8a
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Configuration/CommandInterface.cmi
@@ -0,0 +1,2 @@
+
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Configuration/Configuration.mdo b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Configuration/Configuration.mdo
new file mode 100644
index 00000000..ab3e7959
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Configuration/Configuration.mdo
@@ -0,0 +1,50 @@
+
+
+ StructureModule
+
+ en
+ Structure module
+
+
+
+
+
+
+
+
+ 8.3.20
+ ManagedApplication
+ PersonalComputer
+
+
+
+
+
+ OSBackup
+
+
+
+ Language.English
+ Managed
+ NotAutoFree
+ DontUse
+ DontUse
+ 8.3.20
+
+ English
+
+ en
+ English
+
+ en
+
+ CommonModule.CommonModuleAfterRegion
+ CommonModule.CommonModuleExportInRegion
+ CommonModule.CommonModuleInNonInterfaceRegion
+ CommonModule.CommonModuleInRegion
+ CommonModule.CommonModuleNoRegion
+ CommonModule.CommonModulMultiLevel
+ CommonModule.CommonModuleMultiLevel1
+ CommonCommand.CommonCommand
+ Catalog.CatalogOutOfRegion
+
diff --git a/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Configuration/MainSectionCommandInterface.cmi b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Configuration/MainSectionCommandInterface.cmi
new file mode 100644
index 00000000..0cf6de8a
--- /dev/null
+++ b/tests/com.e1c.v8codestyle.bsl.itests/workspace/ModuleStructureMethodInRegionCheck/src/Configuration/MainSectionCommandInterface.cmi
@@ -0,0 +1,2 @@
+
+