From be94e2e8bc496b17e41a7c4cf5da9a24095c9d62 Mon Sep 17 00:00:00 2001 From: sfaqer Date: Fri, 11 Aug 2023 19:39:07 +1000 Subject: [PATCH] =?UTF-8?q?1.=20=D0=9C=D0=BE=D0=B4=D1=83=D0=BB=D1=8C=20?= =?UTF-8?q?=D0=90=D1=81=D0=B8=D0=BD=D1=85=D1=80=D0=BE=D0=BD=D0=BD=D0=BE?= =?UTF-8?q?=D1=81=D1=82=D1=8C=D0=A1=D0=BB=D1=83=D0=B6=D0=B5=D0=B1=D0=BD?= =?UTF-8?q?=D1=8B=D0=B9=20=D0=BF=D0=B5=D1=80=D0=B5=D0=B8=D0=BC=D0=B5=D0=BD?= =?UTF-8?q?=D0=BE=D0=B2=D0=B0=D0=BD=20=D0=B2=20=D0=9E=D0=B1=D0=B5=D1=89?= =?UTF-8?q?=D0=B0=D0=BD=D0=B8=D1=8F=D0=A1=D0=BB=D1=83=D0=B6=D0=B5=D0=B1?= =?UTF-8?q?=D0=BD=D1=8B=D0=B9=202.=20=D0=92=20API=20=D0=B4=D0=BE=D0=B1?= =?UTF-8?q?=D0=B0=D0=B2=D0=BB=D0=B5=D0=BD=D0=B0=20=D0=B2=D0=BE=D0=B7=D0=BC?= =?UTF-8?q?=D0=BE=D0=B6=D0=BD=D0=BE=D1=81=D1=82=D1=8C=20=D0=BE=D0=B6=D0=B8?= =?UTF-8?q?=D0=B4=D0=B0=D1=82=D1=8C=20=D0=B7=D0=B0=D0=B2=D0=B5=D1=80=D1=88?= =?UTF-8?q?=D0=B5=D0=BD=D0=B8=D1=8F=20=D0=BC=D0=B0=D1=81=D1=81=D0=B8=D0=B2?= =?UTF-8?q?=D0=B0=20=D0=BE=D0=B1=D0=B5=D1=89=D0=B0=D0=BD=D0=B8=D0=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 12 +++ packagedef | 3 +- ...21\211\320\260\320\275\320\270\320\265.os" | 4 +- ...20\265\320\261\320\275\321\213\320\271.os" | 16 ++++ ...21\211\320\260\320\275\320\270\321\217.os" | 14 +++- ...21\211\320\260\320\275\320\270\321\217.os" | 74 +++++++++++++++++++ 6 files changed, 118 insertions(+), 5 deletions(-) rename "src/internal/\320\234\320\276\320\264\321\203\320\273\320\270/\320\220\321\201\320\270\320\275\321\205\321\200\320\276\320\275\320\275\320\276\321\201\321\202\321\214\320\241\320\273\321\203\320\266\320\265\320\261\320\275\321\213\320\271.os" => "src/internal/\320\234\320\276\320\264\321\203\320\273\320\270/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217\320\241\320\273\321\203\320\266\320\265\320\261\320\275\321\213\320\271.os" (76%) diff --git a/README.md b/README.md index 633eb80..0accfd6 100644 --- a/README.md +++ b/README.md @@ -37,6 +37,18 @@ Функция ВыполнитьДелегат(Действие, Параметры) ``` +#### ОжидатьВсе + +```bsl +// Ожидает исполнение всех переданных обещаний +// +// Параметры: +// Обещания - Массив из Обещание - Обещания которых ожидаем +// Таймаут - Число- Количество миллисекунд по истечении которых будет выброшено исключение +// +Процедура ОжидатьВсе(Обещания, Таймаут = 0) Экспорт +``` + ### Класс Обещание #### Получить diff --git a/packagedef b/packagedef index 36a5d16..af1347b 100644 --- a/packagedef +++ b/packagedef @@ -1,5 +1,5 @@ Описание.Имя("async") - .Версия("0.2.0") + .Версия("0.2.1") .Автор("Кирилл Черненко") .АдресАвтора("https://github.com/sfaqer") .Описание("Фреймворк асинхронного исполнения для OneScript") @@ -13,4 +13,5 @@ .РазработкаЗависитОт("json") .РазработкаЗависитОт("asserts") .ЗависитОт("lambdas", "0.1.3") + .ЗависитОт("fluent", "0.6.1") ; diff --git "a/src/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\320\265.os" "b/src/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\320\265.os" index 4d2b07c..a81d616 100644 --- "a/src/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\320\265.os" +++ "b/src/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\320\265.os" @@ -58,7 +58,7 @@ Результат = Новый Обещание(Алгоритм, ЭтотОбъект); - АсинхронностьСлужебный.ЗапуститьВыполнениеОбещания(Результат); + ОбещанияСлужебный.ЗапуститьВыполнениеОбещания(Результат); Возврат Результат; @@ -88,7 +88,7 @@ Результат = Новый Обещание(Алгоритм, ЭтотОбъект, Истина); - АсинхронностьСлужебный.ЗапуститьВыполнениеОбещания(Результат); + ОбещанияСлужебный.ЗапуститьВыполнениеОбещания(Результат); Возврат Результат; diff --git "a/src/internal/\320\234\320\276\320\264\321\203\320\273\320\270/\320\220\321\201\320\270\320\275\321\205\321\200\320\276\320\275\320\275\320\276\321\201\321\202\321\214\320\241\320\273\321\203\320\266\320\265\320\261\320\275\321\213\320\271.os" "b/src/internal/\320\234\320\276\320\264\321\203\320\273\320\270/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217\320\241\320\273\321\203\320\266\320\265\320\261\320\275\321\213\320\271.os" similarity index 76% rename from "src/internal/\320\234\320\276\320\264\321\203\320\273\320\270/\320\220\321\201\320\270\320\275\321\205\321\200\320\276\320\275\320\275\320\276\321\201\321\202\321\214\320\241\320\273\321\203\320\266\320\265\320\261\320\275\321\213\320\271.os" rename to "src/internal/\320\234\320\276\320\264\321\203\320\273\320\270/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217\320\241\320\273\321\203\320\266\320\265\320\261\320\275\321\213\320\271.os" index d08fcea..ea4feaf 100644 --- "a/src/internal/\320\234\320\276\320\264\321\203\320\273\320\270/\320\220\321\201\320\270\320\275\321\205\321\200\320\276\320\275\320\275\320\276\321\201\321\202\321\214\320\241\320\273\321\203\320\266\320\265\320\261\320\275\321\213\320\271.os" +++ "b/src/internal/\320\234\320\276\320\264\321\203\320\273\320\270/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217\320\241\320\273\321\203\320\266\320\265\320\261\320\275\321\213\320\271.os" @@ -1,3 +1,5 @@ +#Использовать fluent + #Область ОписаниеПеременных Перем Рефлектор; // Для доступа к приватным полям обещания @@ -61,6 +63,20 @@ КонецФункции +Процедура ОжидатьВсе(Обещания, Таймаут) Экспорт + + Задания = ПроцессорыКоллекций.ИзКоллекции(Обещания) + .Обработать("Обещание -> Рефлектор.ПолучитьСвойство(Обещание, ""Задание"")", ЭтотОбъект) + .ВМассив(); + + Результат = ФоновыеЗадания.ОжидатьВсе(Задания, Таймаут); + + Если Не Результат Тогда + ВызватьИсключение "Превышено время ожидания получения результата"; + КонецЕсли; + +КонецПроцедуры + #КонецОбласти Рефлектор = Новый Рефлектор(); diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217.os" index 9619ed8..cbc2ce2 100644 --- "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217.os" +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217.os" @@ -21,7 +21,7 @@ Результат = Новый Обещание(Алгоритм, Параметры); - АсинхронностьСлужебный.ЗапуститьВыполнениеОбещания(Результат); + ОбещанияСлужебный.ЗапуститьВыполнениеОбещания(Результат); Возврат Результат; @@ -40,10 +40,20 @@ Результат = Новый Обещание(Действие, Параметры); - АсинхронностьСлужебный.ЗапуститьВыполнениеОбещания(Результат); + ОбещанияСлужебный.ЗапуститьВыполнениеОбещания(Результат); Возврат Результат; КонецФункции +// Ожидает исполнение всех переданных обещаний +// +// Параметры: +// Обещания - Массив из Обещание - Обещания которых ожидаем +// Таймаут - Число- Количество миллисекунд по истечении которых будет выброшено исключение +// +Процедура ОжидатьВсе(Обещания, Таймаут = 0) Экспорт + ОбещанияСлужебный.ОжидатьВсе(Обещания, Таймаут); +КонецПроцедуры + #КонецОбласти diff --git "a/tests/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217.os" "b/tests/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217.os" index dc6d67d..c6e0a2d 100644 --- "a/tests/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217.os" +++ "b/tests/\320\236\320\261\320\265\321\211\320\260\320\275\320\270\321\217.os" @@ -46,6 +46,80 @@ КонецПроцедуры +&Тест +Процедура ОжидаемВсе() Экспорт + + // Дано + + Параметры = Новый Массив(); + Параметры.Добавить(1); + Параметры.Добавить(2); + + Ждем = Новый Массив(); + + // BSLLS:DuplicatedInsertionIntoCollection-off + // BSLLS:DuplicateStringLiteral-off + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + // BSLLS:DuplicatedInsertionIntoCollection-on + // BSLLS:DuplicateStringLiteral-on + + // Когда + + Обещания.ОжидатьВсе(Ждем); + + // Тогда + + Для каждого Обещание Из Ждем Цикл + + Утверждения.ПроверитьРавенство(Обещание.Состояние(), СостояниеФоновогоЗадания.Завершено); + Утверждения.ПроверитьРавенство(Обещание.Получить(), 3); + + КонецЦикла; + +КонецПроцедуры + +Процедура НеДождалисьВсех() Экспорт + + // Дано + + Параметры = Новый Массив(); + Параметры.Добавить(1); + Параметры.Добавить(2); + + Ждем = Новый Массив(); + + // BSLLS:DuplicatedInsertionIntoCollection-off + // BSLLS:DuplicateStringLiteral-off + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + Ждем.Добавить(Обещания.ВыполнитьЛямбду("(П, В) -> Возврат СложитьСЗадержкой(П, В)", ЭтотОбъект, Параметры)); + // BSLLS:DuplicatedInsertionIntoCollection-on + // BSLLS:DuplicateStringLiteral-on + + // Тогда + + Параметры = Новый Массив; + Параметры.Добавить(Ждем); + Параметры.Добавить(10); + + Ожидаем.Что(Обещания) + .Метод("ОжидатьВсе", Параметры) + .ВыбрасываетИсключение("Превышено время ожидания получения результата"); + +КонецПроцедуры + Функция СложитьСЗадержкой(Первое, Второе) Экспорт Приостановить(100);