-
Notifications
You must be signed in to change notification settings - Fork 117
[WIP] Делегаты в native-режиме #1697
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
Open
dmpas
wants to merge
5
commits into
EvilBeaver:develop
Choose a base branch
from
dmpas:feature/native-delegate-call-1531
base: develop
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
+230
−3
Open
Changes from all commits
Commits
Show all changes
5 commits
Select commit
Hold shift + click to select a range
18b5ffe
#1531: тесты на кросс-вызовы делегатов.
dmpas c22978a
Исправлен падающий тест.
dmpas aaeaa5f
#1531: Метод выполнения кода делегата.
dmpas dfb0e87
#1531: контроль количества аргументов вызова.
dmpas b534a43
#1531: Забытая аннотация в тесте.
dmpas File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,99 @@ | ||
| #native | ||
|
|
||
| /////////////////////////////////////////////////////////////////////// | ||
| // Тест класса Действие/Action | ||
| /////////////////////////////////////////////////////////////////////// | ||
|
|
||
| Перем юТест; | ||
|
|
||
| //////////////////////////////////////////////////////////////////// | ||
| // Программный интерфейс | ||
|
|
||
| Функция ПолучитьСписокТестов(ЮнитТестирование) Экспорт | ||
|
|
||
| юТест = ЮнитТестирование; | ||
|
|
||
| ВсеТесты = Новый Массив; | ||
|
|
||
| ВсеТесты.Добавить("ТестДолжен_ВыполнитьДействиеОбъектаТеста_Стэковый"); | ||
| ВсеТесты.Добавить("ТестДолжен_ВыполнитьДействиеОбъектаТеста_Родной"); | ||
|
|
||
| ВсеТесты.Добавить("ТестДолжен_ПроверитьКоличествоПараметров_Стэковый"); | ||
| ВсеТесты.Добавить("ТестДолжен_ПроверитьКоличествоПараметров_Родной"); | ||
|
|
||
| Возврат ВсеТесты; | ||
|
|
||
| КонецФункции | ||
|
|
||
| Процедура ТестДолжен_ВыполнитьДействиеОбъектаТеста(Знач ТипДелегата) | ||
|
|
||
| Делегат = ТестовыйДелегат(ТипДелегата); | ||
| Делегат.Выполнить("123", 456); | ||
|
|
||
| КонецПроцедуры | ||
|
|
||
| Процедура ТестДолжен_ПроверитьКоличествоПараметров(Знач ТипДелегата) | ||
|
|
||
| Делегат = ТестовыйДелегат(ТипДелегата); | ||
|
|
||
| ЕстьОшибка = Ложь; | ||
| Попытка | ||
| Делегат.Выполнить("123"); | ||
| Исключение | ||
| ЕстьОшибка = Истина; | ||
| КонецПопытки; | ||
|
|
||
| юТест.ПроверитьИстину(ЕстьОшибка, "Вызов с недостаточным количеством параметров должен бросать исключение"); | ||
|
|
||
| ЕстьОшибка = Ложь; | ||
| Попытка | ||
| Делегат.Выполнить("123", 456, '00010101'); | ||
| Исключение | ||
| ЕстьОшибка = Истина; | ||
| КонецПопытки; | ||
|
|
||
| юТест.ПроверитьИстину(ЕстьОшибка, "Вызов с избыточным количеством параметров должен бросать исключение"); | ||
|
|
||
| КонецПроцедуры | ||
|
|
||
| Процедура ТестДолжен_ВыполнитьДействиеОбъектаТеста_Стэковый() Экспорт | ||
| ТестДолжен_ВыполнитьДействиеОбъектаТеста("#stack"); | ||
| КонецПроцедуры | ||
|
|
||
| Процедура ТестДолжен_ВыполнитьДействиеОбъектаТеста_Родной() Экспорт | ||
| ТестДолжен_ВыполнитьДействиеОбъектаТеста("#native"); | ||
| КонецПроцедуры | ||
|
|
||
| Процедура ТестДолжен_ПроверитьКоличествоПараметров_Родной() Экспорт | ||
| ТестДолжен_ПроверитьКоличествоПараметров("#native") | ||
| КонецПроцедуры | ||
|
|
||
| Процедура ТестДолжен_ПроверитьКоличествоПараметров_Стэковый() Экспорт | ||
| ТестДолжен_ПроверитьКоличествоПараметров("#stack") | ||
| КонецПроцедуры | ||
|
|
||
| Функция ТестовыйДелегат(Знач ТипДелегата) | ||
|
|
||
| ПутьКСкрипту = юТест.ИмяВременногоФайла("os"); | ||
| ИмяКласса = "Класс" + СтрЗаменить(Новый УникальныйИдентификатор, "-", ""); | ||
|
|
||
| ТекстКласса = ТипДелегата + | ||
| " | ||
| | | ||
| |Процедура Тест(Парам, Парам2) Экспорт | ||
| | Сообщить(Парам + Парам2); | ||
| |КонецПроцедуры"; | ||
|
|
||
| ЗаписьТекста = Новый ЗаписьТекста(ПутьКСкрипту); | ||
| ЗаписьТекста.Записать(ТекстКласса); | ||
| ЗаписьТекста.Закрыть(); | ||
|
|
||
| ПодключитьСценарий(ПутьКСкрипту, ИмяКласса); | ||
|
|
||
| Класс = Новый(ИмяКласса); | ||
|
|
||
| Делегат = Новый Действие(Класс, "Тест"); | ||
|
|
||
| Возврат Делегат; | ||
|
|
||
| КонецФункции |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,99 @@ | ||
| #stack | ||
|
|
||
| /////////////////////////////////////////////////////////////////////// | ||
| // Тест класса Действие/Action | ||
| /////////////////////////////////////////////////////////////////////// | ||
|
|
||
| Перем юТест; | ||
|
|
||
| //////////////////////////////////////////////////////////////////// | ||
| // Программный интерфейс | ||
|
|
||
| Функция ПолучитьСписокТестов(ЮнитТестирование) Экспорт | ||
|
|
||
| юТест = ЮнитТестирование; | ||
|
|
||
| ВсеТесты = Новый Массив; | ||
|
|
||
| ВсеТесты.Добавить("ТестДолжен_ВыполнитьДействиеОбъектаТеста_Стэковый"); | ||
| ВсеТесты.Добавить("ТестДолжен_ВыполнитьДействиеОбъектаТеста_Родной"); | ||
|
|
||
| ВсеТесты.Добавить("ТестДолжен_ПроверитьКоличествоПараметров_Стэковый"); | ||
| ВсеТесты.Добавить("ТестДолжен_ПроверитьКоличествоПараметров_Родной"); | ||
|
|
||
| Возврат ВсеТесты; | ||
|
|
||
| КонецФункции | ||
|
|
||
| Процедура ТестДолжен_ВыполнитьДействиеОбъектаТеста(Знач ТипДелегата) | ||
|
|
||
| Делегат = ТестовыйДелегат(ТипДелегата); | ||
| Делегат.Выполнить("123", 456); | ||
|
|
||
| КонецПроцедуры | ||
|
|
||
| Процедура ТестДолжен_ПроверитьКоличествоПараметров(Знач ТипДелегата) | ||
|
|
||
| Делегат = ТестовыйДелегат(ТипДелегата); | ||
|
|
||
| ЕстьОшибка = Ложь; | ||
| Попытка | ||
| Делегат.Выполнить("123"); | ||
| Исключение | ||
| ЕстьОшибка = Истина; | ||
| КонецПопытки; | ||
|
|
||
| юТест.ПроверитьИстину(ЕстьОшибка, "Вызов с недостаточным количеством параметров должен бросать исключение"); | ||
|
|
||
| ЕстьОшибка = Ложь; | ||
| Попытка | ||
| Делегат.Выполнить("123", 456, '00010101'); | ||
| Исключение | ||
| ЕстьОшибка = Истина; | ||
| КонецПопытки; | ||
|
|
||
| юТест.ПроверитьИстину(ЕстьОшибка, "Вызов с избыточным количеством параметров должен бросать исключение"); | ||
|
|
||
| КонецПроцедуры | ||
|
|
||
| Процедура ТестДолжен_ВыполнитьДействиеОбъектаТеста_Стэковый() Экспорт | ||
| ТестДолжен_ВыполнитьДействиеОбъектаТеста("#stack"); | ||
| КонецПроцедуры | ||
|
|
||
| Процедура ТестДолжен_ВыполнитьДействиеОбъектаТеста_Родной() Экспорт | ||
| ТестДолжен_ВыполнитьДействиеОбъектаТеста("#native"); | ||
| КонецПроцедуры | ||
|
|
||
| Процедура ТестДолжен_ПроверитьКоличествоПараметров_Родной() Экспорт | ||
| ТестДолжен_ПроверитьКоличествоПараметров("#native") | ||
| КонецПроцедуры | ||
|
|
||
| Процедура ТестДолжен_ПроверитьКоличествоПараметров_Стэковый() Экспорт | ||
| ТестДолжен_ПроверитьКоличествоПараметров("#stack") | ||
| КонецПроцедуры | ||
|
|
||
| Функция ТестовыйДелегат(Знач ТипДелегата) | ||
|
|
||
| ПутьКСкрипту = юТест.ИмяВременногоФайла("os"); | ||
| ИмяКласса = "Класс" + СтрЗаменить(Новый УникальныйИдентификатор, "-", ""); | ||
|
|
||
| ТекстКласса = ТипДелегата + | ||
| " | ||
| | | ||
| |Процедура Тест(Парам, Парам2) Экспорт | ||
| | Сообщить(Парам + Парам2); | ||
| |КонецПроцедуры"; | ||
|
|
||
| ЗаписьТекста = Новый ЗаписьТекста(ПутьКСкрипту); | ||
| ЗаписьТекста.Записать(ТекстКласса); | ||
| ЗаписьТекста.Закрыть(); | ||
|
|
||
| ПодключитьСценарий(ПутьКСкрипту, ИмяКласса); | ||
|
|
||
| Класс = Новый(ИмяКласса); | ||
|
|
||
| Делегат = Новый Действие(Класс, "Тест"); | ||
|
|
||
| Возврат Делегат; | ||
|
|
||
| КонецФункции |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Missing default-parameter handling causes incorrect TooFewArgumentsPassed exception.
Lines 50-53 throw
TooFewArgumentsPassed()wheneverargs.Length < parameters.Length, but this ignores parameters with default values. A caller passing fewer arguments than the total parameter count is valid when the omitted parameters have defaults.MachineInstance.SetExecutionFrame(lines 175-184 in the other file) correctly checksparamDef.HasDefaultValuebefore throwingTooFewArgumentsPassed(). This code must do the same, otherwise delegate invocations of methods with optional parameters will fail.🔧 Proposed fix
if (_method.GetBslParameters().Length < args.Length) { throw RuntimeException.TooManyArgumentsPassed(); } -if (_method.GetBslParameters().Length > args.Length) + +var parameters = _method.GetBslParameters(); +for (int i = args.Length; i < parameters.Length; i++) { - // TODO: значения параметров по-умолчанию? - throw RuntimeException.TooFewArgumentsPassed(); + if (!parameters[i].HasDefaultValue) + { + throw RuntimeException.TooFewArgumentsPassed(); + } }📝 Committable suggestion
🤖 Prompt for AI Agents