12f083884Ss.makeev_local // The MIT License (MIT) 22f083884Ss.makeev_local // 32f083884Ss.makeev_local // Copyright (c) 2015 Sergey Makeev, Vadim Slyusarev 42f083884Ss.makeev_local // 52f083884Ss.makeev_local // Permission is hereby granted, free of charge, to any person obtaining a copy 62f083884Ss.makeev_local // of this software and associated documentation files (the "Software"), to deal 72f083884Ss.makeev_local // in the Software without restriction, including without limitation the rights 82f083884Ss.makeev_local // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 92f083884Ss.makeev_local // copies of the Software, and to permit persons to whom the Software is 102f083884Ss.makeev_local // furnished to do so, subject to the following conditions: 112f083884Ss.makeev_local // 122f083884Ss.makeev_local // The above copyright notice and this permission notice shall be included in 132f083884Ss.makeev_local // all copies or substantial portions of the Software. 142f083884Ss.makeev_local // 152f083884Ss.makeev_local // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 162f083884Ss.makeev_local // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 172f083884Ss.makeev_local // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 182f083884Ss.makeev_local // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 192f083884Ss.makeev_local // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 202f083884Ss.makeev_local // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 212f083884Ss.makeev_local // THE SOFTWARE. 222f083884Ss.makeev_local 232f083884Ss.makeev_local #include "Tests.h" 242f083884Ss.makeev_local #include <UnitTest++.h> 252f083884Ss.makeev_local #include <MTScheduler.h> 262f083884Ss.makeev_local 272f083884Ss.makeev_local SUITE(SimpleTests) 282f083884Ss.makeev_local { 292f083884Ss.makeev_local //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// 302f083884Ss.makeev_local struct SimpleTask 312f083884Ss.makeev_local { 32*b23bdf5aSs.makeev_local MT_DECLARE_TASK(SimpleTask, MT::StackRequirements::STANDARD, MT::TaskPriority::NORMAL, MT::Color::Blue); 332f083884Ss.makeev_local 342f083884Ss.makeev_local static const int sourceData = 0xFF33FF; 352f083884Ss.makeev_local int resultData; 362f083884Ss.makeev_local 372f083884Ss.makeev_local SimpleTask() : resultData(0) {} 382f083884Ss.makeev_local 392f083884Ss.makeev_local void Do(MT::FiberContext&) 402f083884Ss.makeev_local { 412f083884Ss.makeev_local resultData = sourceData; 422f083884Ss.makeev_local } 432f083884Ss.makeev_local 442f083884Ss.makeev_local int GetSourceData() 452f083884Ss.makeev_local { 462f083884Ss.makeev_local return sourceData; 472f083884Ss.makeev_local } 482f083884Ss.makeev_local }; 492f083884Ss.makeev_local 502f083884Ss.makeev_local // Checks one simple task 512f083884Ss.makeev_local TEST(RunOneSimpleTask) 522f083884Ss.makeev_local { 532f083884Ss.makeev_local MT::TaskScheduler scheduler; 542f083884Ss.makeev_local 552f083884Ss.makeev_local SimpleTask task; 562f083884Ss.makeev_local scheduler.RunAsync(MT::TaskGroup::Default(), &task, 1); 572f083884Ss.makeev_local 582f083884Ss.makeev_local CHECK(scheduler.WaitAll(1000)); 592f083884Ss.makeev_local CHECK_EQUAL(task.GetSourceData(), task.resultData); 602f083884Ss.makeev_local } 612f083884Ss.makeev_local //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// 622f083884Ss.makeev_local 632f083884Ss.makeev_local //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// 642f083884Ss.makeev_local struct ALotOfTasks 652f083884Ss.makeev_local { 66*b23bdf5aSs.makeev_local MT_DECLARE_TASK(ALotOfTasks, MT::StackRequirements::STANDARD, MT::TaskPriority::NORMAL, MT::Color::Blue); 672f083884Ss.makeev_local 682f083884Ss.makeev_local MT::Atomic32<int32>* counter; 692f083884Ss.makeev_local 702f083884Ss.makeev_local void Do(MT::FiberContext&) 712f083884Ss.makeev_local { 722f083884Ss.makeev_local counter->IncFetch(); 732f083884Ss.makeev_local MT::Thread::SpinSleepMilliSeconds(1); 742f083884Ss.makeev_local } 752f083884Ss.makeev_local }; 762f083884Ss.makeev_local 772f083884Ss.makeev_local // Checks one simple task 782f083884Ss.makeev_local TEST(ALotOfTasks) 792f083884Ss.makeev_local { 802f083884Ss.makeev_local 812f083884Ss.makeev_local MT::TaskScheduler scheduler; 822f083884Ss.makeev_local 832f083884Ss.makeev_local MT::Atomic32<int32> counter; 842f083884Ss.makeev_local 852f083884Ss.makeev_local static const int TASK_COUNT = 1000; 862f083884Ss.makeev_local 872f083884Ss.makeev_local ALotOfTasks tasks[TASK_COUNT]; 882f083884Ss.makeev_local 892f083884Ss.makeev_local for (size_t i = 0; i < MT_ARRAY_SIZE(tasks); ++i) 902f083884Ss.makeev_local tasks[i].counter = &counter; 912f083884Ss.makeev_local 922f083884Ss.makeev_local scheduler.RunAsync(MT::TaskGroup::Default(), &tasks[0], MT_ARRAY_SIZE(tasks)); 932f083884Ss.makeev_local 942f083884Ss.makeev_local int timeout = (TASK_COUNT / scheduler.GetWorkersCount()) * 2000; 952f083884Ss.makeev_local 962f083884Ss.makeev_local CHECK(scheduler.WaitGroup(MT::TaskGroup::Default(), timeout)); 972f083884Ss.makeev_local CHECK_EQUAL(TASK_COUNT, counter.Load()); 982f083884Ss.makeev_local } 992f083884Ss.makeev_local //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// 1002f083884Ss.makeev_local } 101