ttk 0.1.576
Sign up to get free protection for your applications and to get access to all the features.
- data/AUTHORS +32 -0
- data/COPYING +18 -0
- data/ChangeLog +4629 -0
- data/DATE +1 -0
- data/DESCRIPTION +8 -0
- data/GUIDELINES +84 -0
- data/LGPL +504 -0
- data/NEWS +69 -0
- data/NORM +85 -0
- data/README +206 -0
- data/REVISION +1 -0
- data/Rakefile +120 -0
- data/TODO +23 -0
- data/TODO.old +115 -0
- data/VERSION +5 -0
- data/bin/getopts/ttk.rb +394 -0
- data/bin/getopts/ttkd.rb +150 -0
- data/bin/getopts/ttkm.rb +71 -0
- data/bin/ttk +170 -0
- data/bin/ttkd +73 -0
- data/bin/ttkm +54 -0
- data/doc/html/classes/IO/CutInput.html +159 -0
- data/doc/html/classes/IO/Delegator.html +291 -0
- data/doc/html/classes/IO/Dispatch.html +204 -0
- data/doc/html/classes/IO/Ext.html +118 -0
- data/doc/html/classes/IO/ImplExt.html +149 -0
- data/doc/html/classes/IO/ImplIndent.html +175 -0
- data/doc/html/classes/IO/ImplPrintFile.html +142 -0
- data/doc/html/classes/IO/ImplPrintIO.html +143 -0
- data/doc/html/classes/IO/InputFilter.html +347 -0
- data/doc/html/classes/IO/OutputFilter.html +298 -0
- data/doc/html/classes/NilClass.html +198 -0
- data/doc/html/classes/SafeEval.html +277 -0
- data/doc/html/classes/String.html +245 -0
- data/doc/html/classes/SymTbl.html +146 -0
- data/doc/html/classes/TTK.html +658 -0
- data/doc/html/classes/TTK/AbortStatus.html +211 -0
- data/doc/html/classes/TTK/Daemons.html +142 -0
- data/doc/html/classes/TTK/Daemons/Daemon.html +170 -0
- data/doc/html/classes/TTK/Daemons/Daemon/Logger.html +192 -0
- data/doc/html/classes/TTK/Daemons/Master.html +163 -0
- data/doc/html/classes/TTK/Daemons/Slave.html +158 -0
- data/doc/html/classes/TTK/Dumpers.html +150 -0
- data/doc/html/classes/TTK/Dumpers/Dumper.html +461 -0
- data/doc/html/classes/TTK/Dumpers/Notif.html +208 -0
- data/doc/html/classes/TTK/Dumpers/Xml.html +260 -0
- data/doc/html/classes/TTK/Dumpers/Yaml.html +307 -0
- data/doc/html/classes/TTK/ErrorStatus.html +133 -0
- data/doc/html/classes/TTK/FailStatus.html +195 -0
- data/doc/html/classes/TTK/Fetchers.html +135 -0
- data/doc/html/classes/TTK/Fetchers/Client.html +229 -0
- data/doc/html/classes/TTK/Fetchers/Client/Receiver.html +254 -0
- data/doc/html/classes/TTK/Fetchers/Server.html +256 -0
- data/doc/html/classes/TTK/Fetchers/Server/Sender.html +241 -0
- data/doc/html/classes/TTK/Filters.html +142 -0
- data/doc/html/classes/TTK/Filters/BasicLogger.html +187 -0
- data/doc/html/classes/TTK/Filters/Filter.html +188 -0
- data/doc/html/classes/TTK/Filters/Saver.html +279 -0
- data/doc/html/classes/TTK/Loaders.html +115 -0
- data/doc/html/classes/TTK/Loaders/BaseNode.html +224 -0
- data/doc/html/classes/TTK/Loaders/Loader.html +242 -0
- data/doc/html/classes/TTK/Loaders/OYaml.html +161 -0
- data/doc/html/classes/TTK/Loaders/Yaml.html +157 -0
- data/doc/html/classes/TTK/Loaders/YamlOld.html +155 -0
- data/doc/html/classes/TTK/Logger.html +836 -0
- data/doc/html/classes/TTK/Logger/Path.html +161 -0
- data/doc/html/classes/TTK/Logger/SectionNode.html +925 -0
- data/doc/html/classes/TTK/Logger/Severity.html +306 -0
- data/doc/html/classes/TTK/Logger/ToTTKLog.html +119 -0
- data/doc/html/classes/TTK/Logger/Verbosity.html +278 -0
- data/doc/html/classes/TTK/LoggerFactory.html +204 -0
- data/doc/html/classes/TTK/Monitors.html +132 -0
- data/doc/html/classes/TTK/Monitors/Client.html +261 -0
- data/doc/html/classes/TTK/Monitors/Monitor.html +209 -0
- data/doc/html/classes/TTK/Monitors/Server.html +288 -0
- data/doc/html/classes/TTK/Monitors/Server/Notification.html +118 -0
- data/doc/html/classes/TTK/Monitors/Server/Notifier.html +118 -0
- data/doc/html/classes/TTK/PassStatus.html +168 -0
- data/doc/html/classes/TTK/RunningStatus.html +133 -0
- data/doc/html/classes/TTK/Services.html +161 -0
- data/doc/html/classes/TTK/Services/DRbService.html +217 -0
- data/doc/html/classes/TTK/Services/DRbService/Notification.html +123 -0
- data/doc/html/classes/TTK/Services/DRbService/SubTestable.html +197 -0
- data/doc/html/classes/TTK/Services/FetcherClient.html +190 -0
- data/doc/html/classes/TTK/Services/FetcherServer.html +149 -0
- data/doc/html/classes/TTK/Services/MonitorClient.html +190 -0
- data/doc/html/classes/TTK/Services/MonitorServer.html +149 -0
- data/doc/html/classes/TTK/Services/TesterClient.html +207 -0
- data/doc/html/classes/TTK/Services/TesterMaster.html +193 -0
- data/doc/html/classes/TTK/Services/TesterMaster/Notification.html +123 -0
- data/doc/html/classes/TTK/Services/TesterSlave.html +157 -0
- data/doc/html/classes/TTK/Services/TesterSlave/Notification.html +118 -0
- data/doc/html/classes/TTK/SkipStatus.html +169 -0
- data/doc/html/classes/TTK/StartStatus.html +133 -0
- data/doc/html/classes/TTK/Status.html +373 -0
- data/doc/html/classes/TTK/StatusException.html +161 -0
- data/doc/html/classes/TTK/StatusWithMessage.html +220 -0
- data/doc/html/classes/TTK/Strategies.html +356 -0
- data/doc/html/classes/TTK/Strategies/Abort.html +161 -0
- data/doc/html/classes/TTK/Strategies/Authors.html +170 -0
- data/doc/html/classes/TTK/Strategies/Ball.html +200 -0
- data/doc/html/classes/TTK/Strategies/Block.html +230 -0
- data/doc/html/classes/TTK/Strategies/Bootstrap.html +238 -0
- data/doc/html/classes/TTK/Strategies/Checkout.html +201 -0
- data/doc/html/classes/TTK/Strategies/Clean.html +160 -0
- data/doc/html/classes/TTK/Strategies/Cmd.html +218 -0
- data/doc/html/classes/TTK/Strategies/CmdBase.html +312 -0
- data/doc/html/classes/TTK/Strategies/Collection.html +282 -0
- data/doc/html/classes/TTK/Strategies/Compile.html +199 -0
- data/doc/html/classes/TTK/Strategies/Composite.html +541 -0
- data/doc/html/classes/TTK/Strategies/Composite/Ordered.html +183 -0
- data/doc/html/classes/TTK/Strategies/Configure.html +270 -0
- data/doc/html/classes/TTK/Strategies/DistDelegate.html +192 -0
- data/doc/html/classes/TTK/Strategies/DistDuplicate.html +221 -0
- data/doc/html/classes/TTK/Strategies/DistStrategy.html +224 -0
- data/doc/html/classes/TTK/Strategies/Distribute.html +163 -0
- data/doc/html/classes/TTK/Strategies/Error.html +161 -0
- data/doc/html/classes/TTK/Strategies/Extract.html +179 -0
- data/doc/html/classes/TTK/Strategies/Fail.html +161 -0
- data/doc/html/classes/TTK/Strategies/Fetch.html +400 -0
- data/doc/html/classes/TTK/Strategies/Fetcher.html +276 -0
- data/doc/html/classes/TTK/Strategies/Glob.html +201 -0
- data/doc/html/classes/TTK/Strategies/IOBased.html +400 -0
- data/doc/html/classes/TTK/Strategies/Import.html +215 -0
- data/doc/html/classes/TTK/Strategies/JUnit.html +623 -0
- data/doc/html/classes/TTK/Strategies/KillAll.html +249 -0
- data/doc/html/classes/TTK/Strategies/Make.html +235 -0
- data/doc/html/classes/TTK/Strategies/Make/All.html +120 -0
- data/doc/html/classes/TTK/Strategies/Make/Check.html +120 -0
- data/doc/html/classes/TTK/Strategies/Make/Default.html +155 -0
- data/doc/html/classes/TTK/Strategies/Make/DistCheck.html +120 -0
- data/doc/html/classes/TTK/Strategies/Make/Install.html +120 -0
- data/doc/html/classes/TTK/Strategies/Make/Target.html +179 -0
- data/doc/html/classes/TTK/Strategies/Package.html +271 -0
- data/doc/html/classes/TTK/Strategies/PackageCollection.html +168 -0
- data/doc/html/classes/TTK/Strategies/Pass.html +161 -0
- data/doc/html/classes/TTK/Strategies/Pool.html +306 -0
- data/doc/html/classes/TTK/Strategies/Pool/PoolComponent.html +139 -0
- data/doc/html/classes/TTK/Strategies/ProbabilityThreshold.html +187 -0
- data/doc/html/classes/TTK/Strategies/Proxy.html +211 -0
- data/doc/html/classes/TTK/Strategies/RUnit.html +355 -0
- data/doc/html/classes/TTK/Strategies/RemoteCmd.html +213 -0
- data/doc/html/classes/TTK/Strategies/SignalCmd.html +269 -0
- data/doc/html/classes/TTK/Strategies/Sleep.html +193 -0
- data/doc/html/classes/TTK/Strategies/SqlQuery.html +248 -0
- data/doc/html/classes/TTK/Strategies/Strategy.html +2847 -0
- data/doc/html/classes/TTK/Strategies/Strategy/AssertEval.html +233 -0
- data/doc/html/classes/TTK/Strategies/Strategy/AttributedClass.html +107 -0
- data/doc/html/classes/TTK/Strategies/Strategy/AttributedClass/Attribute.html +246 -0
- data/doc/html/classes/TTK/Strategies/Strategy/Failure.html +121 -0
- data/doc/html/classes/TTK/Strategies/Stub.html +179 -0
- data/doc/html/classes/TTK/Strategies/SubCmd.html +243 -0
- data/doc/html/classes/TTK/Strategies/Suite.html +182 -0
- data/doc/html/classes/TTK/Strategies/Test.html +310 -0
- data/doc/html/classes/TTK/Strategies/Tester.html +218 -0
- data/doc/html/classes/TTK/Streams.html +116 -0
- data/doc/html/classes/TTK/Streams/Diff.html +148 -0
- data/doc/html/classes/TTK/Streams/Stream.html +295 -0
- data/doc/html/classes/TTK/SymTbl.html +266 -0
- data/doc/html/classes/TTK/TTKException.html +118 -0
- data/doc/html/classes/TTK/TTKModule.html +145 -0
- data/doc/html/classes/TTK/Testers.html +156 -0
- data/doc/html/classes/TTK/Testers/Master.html +304 -0
- data/doc/html/classes/TTK/Testers/Slave.html +120 -0
- data/doc/html/classes/TTK/Testers/Tester.html +547 -0
- data/doc/html/classes/TTK/Testers/Tester/Config.html +310 -0
- data/doc/html/classes/TTK/Testers/Tester/Notification.html +123 -0
- data/doc/html/classes/TTK/Testers/Tester/Notifier.html +118 -0
- data/doc/html/classes/TTK/Testers/Tester/QueryNode.html +341 -0
- data/doc/html/classes/TTK/Testers/Tester/RemoteStatus.html +165 -0
- data/doc/html/classes/TTK/Testers/Tester/RunningTask.html +262 -0
- data/doc/html/classes/TTK/Testers/Tester/Score.html +198 -0
- data/doc/html/classes/TTK/TimeoutAbortStatus.html +161 -0
- data/doc/html/classes/TTK/Tools.html +111 -0
- data/doc/html/classes/TTK/Tools/HostDispatcher.html +246 -0
- data/doc/html/classes/TTK/Weights.html +160 -0
- data/doc/html/classes/TTK/Weights/WExpr.html +326 -0
- data/doc/html/classes/TTK/Weights/WFloat.html +149 -0
- data/doc/html/classes/TTK/Weights/WMin.html +148 -0
- data/doc/html/classes/TTK/Weights/Weight.html +624 -0
- data/doc/html/created.rid +1 -0
- data/doc/html/files/AUTHORS.html +198 -0
- data/doc/html/files/NEWS.html +236 -0
- data/doc/html/files/README.html +435 -0
- data/doc/html/files/TODO.html +128 -0
- data/doc/html/files/lib/ttk/Tools/HostDispatcher_rb.html +126 -0
- data/doc/html/files/lib/ttk/Tools/SafeEval_rb.html +119 -0
- data/doc/html/files/lib/ttk/Tools/cut_output_rb.html +126 -0
- data/doc/html/files/lib/ttk/Tools/io/delegator_rb.html +127 -0
- data/doc/html/files/lib/ttk/Tools/io/dispatch_rb.html +127 -0
- data/doc/html/files/lib/ttk/Tools/io/ext_rb.html +126 -0
- data/doc/html/files/lib/ttk/Tools/io/filters_rb.html +127 -0
- data/doc/html/files/lib/ttk/daemons/Daemon_rb.html +126 -0
- data/doc/html/files/lib/ttk/daemons/Master_rb.html +119 -0
- data/doc/html/files/lib/ttk/daemons/Slave_rb.html +119 -0
- data/doc/html/files/lib/ttk/daemons/daemon/logger_rb.html +126 -0
- data/doc/html/files/lib/ttk/dumpers/Dumper_rb.html +119 -0
- data/doc/html/files/lib/ttk/dumpers/Notif_rb.html +119 -0
- data/doc/html/files/lib/ttk/dumpers/Xml_rb.html +126 -0
- data/doc/html/files/lib/ttk/dumpers/Yaml_rb.html +119 -0
- data/doc/html/files/lib/ttk/fetchers/Client_rb.html +126 -0
- data/doc/html/files/lib/ttk/fetchers/Server_rb.html +126 -0
- data/doc/html/files/lib/ttk/fetchers/client/receiver_rb.html +127 -0
- data/doc/html/files/lib/ttk/fetchers/server/sender_rb.html +127 -0
- data/doc/html/files/lib/ttk/filters/BasicLogger_rb.html +126 -0
- data/doc/html/files/lib/ttk/filters/Filter_rb.html +119 -0
- data/doc/html/files/lib/ttk/filters/Saver_rb.html +119 -0
- data/doc/html/files/lib/ttk/loaders/Loader_rb.html +119 -0
- data/doc/html/files/lib/ttk/loaders/OYaml_rb.html +126 -0
- data/doc/html/files/lib/ttk/loaders/YamlOld_rb.html +126 -0
- data/doc/html/files/lib/ttk/loaders/Yaml_rb.html +126 -0
- data/doc/html/files/lib/ttk/logger/path_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger/section_node_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger/severity_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger/to_ttk_log_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger/verbosity_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger_factory_rb.html +119 -0
- data/doc/html/files/lib/ttk/logger_rb.html +131 -0
- data/doc/html/files/lib/ttk/monitors/Client_rb.html +119 -0
- data/doc/html/files/lib/ttk/monitors/Monitor_rb.html +127 -0
- data/doc/html/files/lib/ttk/monitors/Server_rb.html +126 -0
- data/doc/html/files/lib/ttk/services/DRbService/sub_testable_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/DRbService_rb.html +126 -0
- data/doc/html/files/lib/ttk/services/FetcherClient_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/FetcherServer_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/MonitorClient_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/MonitorServer_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/TesterClient_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/TesterMaster_rb.html +119 -0
- data/doc/html/files/lib/ttk/services/TesterSlave_rb.html +119 -0
- data/doc/html/files/lib/ttk/status_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Abort_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Authors_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Ball_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Block_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Bootstrap_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Checkout_rb.html +127 -0
- data/doc/html/files/lib/ttk/strategies/Clean_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/CmdBase_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Cmd_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Collection_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Compile_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Composite_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Configure_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/DistDelegate_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/DistDuplicate_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/DistStrategy_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Distribute_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Error_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Extract_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/Fail_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Fetch_rb.html +127 -0
- data/doc/html/files/lib/ttk/strategies/Fetcher_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/Glob_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/IOBased_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Import_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/JUnit_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/KillAll_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Make_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/PackageCollection_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/Package_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Pass_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Pool_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/ProbabilityThreshold_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Proxy_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/RUnit_rb.html +127 -0
- data/doc/html/files/lib/ttk/strategies/RemoteCmd_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/SignalCmd_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Sleep_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/SqlQuery_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/Strategy/assert_eval_rb.html +127 -0
- data/doc/html/files/lib/ttk/strategies/Strategy_rb.html +131 -0
- data/doc/html/files/lib/ttk/strategies/Streams/Diff_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Streams/Stream_rb.html +126 -0
- data/doc/html/files/lib/ttk/strategies/Stub_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/SubCmd_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Suite_rb.html +119 -0
- data/doc/html/files/lib/ttk/strategies/Test_rb.html +127 -0
- data/doc/html/files/lib/ttk/strategies/Tester_rb.html +126 -0
- data/doc/html/files/lib/ttk/symtbl_rb.html +126 -0
- data/doc/html/files/lib/ttk/testers/Master_rb.html +119 -0
- data/doc/html/files/lib/ttk/testers/Slave_rb.html +119 -0
- data/doc/html/files/lib/ttk/testers/Tester_rb.html +131 -0
- data/doc/html/files/lib/ttk/testers/tester/config_rb.html +126 -0
- data/doc/html/files/lib/ttk/testers/tester/notifier_rb.html +119 -0
- data/doc/html/files/lib/ttk/testers/tester/query_node_rb.html +126 -0
- data/doc/html/files/lib/ttk/testers/tester/remote_status_rb.html +119 -0
- data/doc/html/files/lib/ttk/testers/tester/running_task_rb.html +119 -0
- data/doc/html/files/lib/ttk/testers/tester/score_rb.html +119 -0
- data/doc/html/files/lib/ttk/weights/WExpr_rb.html +119 -0
- data/doc/html/files/lib/ttk/weights/WFloat_rb.html +119 -0
- data/doc/html/files/lib/ttk/weights/WMin_rb.html +119 -0
- data/doc/html/files/lib/ttk/weights/Weight_rb.html +126 -0
- data/doc/html/files/lib/ttk_rb.html +146 -0
- data/doc/html/files/lib/ttkd_rb.html +131 -0
- data/doc/html/files/template/README.html +160 -0
- data/doc/html/files/test/examples/README.html +190 -0
- data/doc/html/fr_class_index.html +186 -0
- data/doc/html/fr_file_index.html +147 -0
- data/doc/html/fr_method_index.html +581 -0
- data/doc/html/index.html +24 -0
- data/doc/html/rdoc-style.css +208 -0
- data/lib/ttk.rb +111 -0
- data/lib/ttk/Tools/HostDispatcher.rb +44 -0
- data/lib/ttk/Tools/SafeEval.rb +64 -0
- data/lib/ttk/Tools/cut_output.rb +35 -0
- data/lib/ttk/Tools/io/delegator.rb +88 -0
- data/lib/ttk/Tools/io/dispatch.rb +31 -0
- data/lib/ttk/Tools/io/ext.rb +70 -0
- data/lib/ttk/Tools/io/filters.rb +71 -0
- data/lib/ttk/daemons/Daemon.rb +34 -0
- data/lib/ttk/daemons/Master.rb +34 -0
- data/lib/ttk/daemons/Slave.rb +29 -0
- data/lib/ttk/daemons/daemon/logger.rb +57 -0
- data/lib/ttk/dumpers/Dumper.rb +81 -0
- data/lib/ttk/dumpers/Notif.rb +33 -0
- data/lib/ttk/dumpers/Xml.rb +112 -0
- data/lib/ttk/dumpers/Yaml.rb +159 -0
- data/lib/ttk/fetchers/Client.rb +41 -0
- data/lib/ttk/fetchers/Server.rb +49 -0
- data/lib/ttk/fetchers/client/receiver.rb +62 -0
- data/lib/ttk/fetchers/server/sender.rb +69 -0
- data/lib/ttk/filters/BasicLogger.rb +30 -0
- data/lib/ttk/filters/Filter.rb +24 -0
- data/lib/ttk/filters/Saver.rb +60 -0
- data/lib/ttk/loaders/Loader.rb +123 -0
- data/lib/ttk/loaders/OYaml.rb +60 -0
- data/lib/ttk/loaders/Yaml.rb +74 -0
- data/lib/ttk/loaders/YamlOld.rb +65 -0
- data/lib/ttk/logger.rb +237 -0
- data/lib/ttk/logger/path.rb +23 -0
- data/lib/ttk/logger/section_node.rb +214 -0
- data/lib/ttk/logger/severity.rb +62 -0
- data/lib/ttk/logger/to_ttk_log.rb +83 -0
- data/lib/ttk/logger/verbosity.rb +61 -0
- data/lib/ttk/logger_factory.rb +50 -0
- data/lib/ttk/monitors/Client.rb +61 -0
- data/lib/ttk/monitors/Monitor.rb +50 -0
- data/lib/ttk/monitors/Server.rb +73 -0
- data/lib/ttk/services/DRbService.rb +45 -0
- data/lib/ttk/services/DRbService/sub_testable.rb +41 -0
- data/lib/ttk/services/FetcherClient.rb +31 -0
- data/lib/ttk/services/FetcherServer.rb +23 -0
- data/lib/ttk/services/MonitorClient.rb +31 -0
- data/lib/ttk/services/MonitorServer.rb +23 -0
- data/lib/ttk/services/TesterClient.rb +38 -0
- data/lib/ttk/services/TesterMaster.rb +40 -0
- data/lib/ttk/services/TesterSlave.rb +31 -0
- data/lib/ttk/status.rb +190 -0
- data/lib/ttk/strategies/Abort.rb +24 -0
- data/lib/ttk/strategies/Authors.rb +43 -0
- data/lib/ttk/strategies/Ball.rb +68 -0
- data/lib/ttk/strategies/Block.rb +95 -0
- data/lib/ttk/strategies/Bootstrap.rb +52 -0
- data/lib/ttk/strategies/Checkout.rb +53 -0
- data/lib/ttk/strategies/Clean.rb +29 -0
- data/lib/ttk/strategies/Cmd.rb +55 -0
- data/lib/ttk/strategies/CmdBase.rb +103 -0
- data/lib/ttk/strategies/Collection.rb +131 -0
- data/lib/ttk/strategies/Compile.rb +56 -0
- data/lib/ttk/strategies/Composite.rb +173 -0
- data/lib/ttk/strategies/Configure.rb +64 -0
- data/lib/ttk/strategies/DistDelegate.rb +45 -0
- data/lib/ttk/strategies/DistDuplicate.rb +64 -0
- data/lib/ttk/strategies/DistStrategy.rb +42 -0
- data/lib/ttk/strategies/Distribute.rb +39 -0
- data/lib/ttk/strategies/Error.rb +23 -0
- data/lib/ttk/strategies/Extract.rb +45 -0
- data/lib/ttk/strategies/Fail.rb +26 -0
- data/lib/ttk/strategies/Fetch.rb +124 -0
- data/lib/ttk/strategies/Fetcher.rb +74 -0
- data/lib/ttk/strategies/Glob.rb +48 -0
- data/lib/ttk/strategies/IOBased.rb +156 -0
- data/lib/ttk/strategies/Import.rb +45 -0
- data/lib/ttk/strategies/JUnit.rb +205 -0
- data/lib/ttk/strategies/KillAll.rb +59 -0
- data/lib/ttk/strategies/Make.rb +94 -0
- data/lib/ttk/strategies/Package.rb +128 -0
- data/lib/ttk/strategies/PackageCollection.rb +72 -0
- data/lib/ttk/strategies/Pass.rb +24 -0
- data/lib/ttk/strategies/Pool.rb +99 -0
- data/lib/ttk/strategies/ProbabilityThreshold.rb +42 -0
- data/lib/ttk/strategies/Proxy.rb +42 -0
- data/lib/ttk/strategies/RUnit.rb +170 -0
- data/lib/ttk/strategies/RemoteCmd.rb +48 -0
- data/lib/ttk/strategies/SignalCmd.rb +85 -0
- data/lib/ttk/strategies/Sleep.rb +36 -0
- data/lib/ttk/strategies/SqlQuery.rb +120 -0
- data/lib/ttk/strategies/Strategy.rb +606 -0
- data/lib/ttk/strategies/Strategy/assert_eval.rb +53 -0
- data/lib/ttk/strategies/Streams/Diff.rb +60 -0
- data/lib/ttk/strategies/Streams/Stream.rb +133 -0
- data/lib/ttk/strategies/Stub.rb +35 -0
- data/lib/ttk/strategies/SubCmd.rb +58 -0
- data/lib/ttk/strategies/Suite.rb +118 -0
- data/lib/ttk/strategies/Test.rb +88 -0
- data/lib/ttk/strategies/Tester.rb +59 -0
- data/lib/ttk/symtbl.rb +115 -0
- data/lib/ttk/testers/Master.rb +69 -0
- data/lib/ttk/testers/Slave.rb +19 -0
- data/lib/ttk/testers/Tester.rb +134 -0
- data/lib/ttk/testers/tester/config.rb +65 -0
- data/lib/ttk/testers/tester/notifier.rb +24 -0
- data/lib/ttk/testers/tester/query_node.rb +91 -0
- data/lib/ttk/testers/tester/remote_status.rb +29 -0
- data/lib/ttk/testers/tester/running_task.rb +47 -0
- data/lib/ttk/testers/tester/score.rb +34 -0
- data/lib/ttk/weights/WExpr.rb +68 -0
- data/lib/ttk/weights/WFloat.rb +23 -0
- data/lib/ttk/weights/WMin.rb +22 -0
- data/lib/ttk/weights/Weight.rb +85 -0
- data/lib/ttkd.rb +51 -0
- data/ruby_ex/abstract.rb +246 -0
- data/ruby_ex/abstract_node.rb +85 -0
- data/ruby_ex/array_each_pair.rb +18 -0
- data/ruby_ex/ask.rb +101 -0
- data/ruby_ex/attributed_class.rb +304 -0
- data/ruby_ex/cache.rb +373 -0
- data/ruby_ex/checkout.rb +12 -0
- data/ruby_ex/config_file.rb +96 -0
- data/ruby_ex/const_regexp.rb +59 -0
- data/ruby_ex/daemon.rb +134 -0
- data/ruby_ex/diff.rb +667 -0
- data/ruby_ex/dlogger.rb +62 -0
- data/ruby_ex/drb/dispatcher.rb +252 -0
- data/ruby_ex/drb/dispatcher_server_test.rb +29 -0
- data/ruby_ex/drb/drb_observable.rb +97 -0
- data/ruby_ex/drb/drb_observable_pool.rb +27 -0
- data/ruby_ex/drb/drb_service.rb +43 -0
- data/ruby_ex/drb/drb_undumped_attributes.rb +55 -0
- data/ruby_ex/drb/drb_undumped_indexed_object.rb +54 -0
- data/ruby_ex/drb/insecure_protected_methods.rb +103 -0
- data/ruby_ex/drb/session_client_test.rb +40 -0
- data/ruby_ex/drb/session_manager.rb +246 -0
- data/ruby_ex/drb/session_server.rb +53 -0
- data/ruby_ex/dtime.rb +143 -0
- data/ruby_ex/dumpable_proc.rb +63 -0
- data/ruby_ex/exception.rb +32 -0
- data/ruby_ex/filetype.rb +229 -0
- data/ruby_ex/fileutils_ex.rb +44 -0
- data/ruby_ex/fold.rb +58 -0
- data/ruby_ex/generate_id.rb +31 -0
- data/ruby_ex/inactive_timeout.rb +137 -0
- data/ruby_ex/indexed_node.rb +66 -0
- data/ruby_ex/io_marshal.rb +100 -0
- data/ruby_ex/ioo.rb +194 -0
- data/ruby_ex/labeled_node.rb +63 -0
- data/ruby_ex/logger_observer.rb +23 -0
- data/ruby_ex/md5sum.rb +66 -0
- data/ruby_ex/mktemp.rb +208 -0
- data/ruby_ex/module/attr_once.rb +36 -0
- data/ruby_ex/module/autoload_tree.rb +68 -0
- data/ruby_ex/module/hierarchy.rb +335 -0
- data/ruby_ex/module/instance_method_visibility.rb +73 -0
- data/ruby_ex/module_ex.rb +11 -0
- data/ruby_ex/node.rb +80 -0
- data/ruby_ex/object_monitor.rb +145 -0
- data/ruby_ex/object_monitor_activity.rb +33 -0
- data/ruby_ex/observable.rb +140 -0
- data/ruby_ex/observable_pool.rb +293 -0
- data/ruby_ex/orderedhash.rb +252 -0
- data/ruby_ex/pathname_ex.rb +113 -0
- data/ruby_ex/pp_hierarchy.rb +29 -0
- data/ruby_ex/pseudo_cache.rb +190 -0
- data/ruby_ex/queue.rb +56 -0
- data/ruby_ex/safe_eval.rb +348 -0
- data/ruby_ex/service_manager.rb +121 -0
- data/ruby_ex/session/administrable.rb +120 -0
- data/ruby_ex/session/client.rb +153 -0
- data/ruby_ex/session/const.rb +18 -0
- data/ruby_ex/session/dispatcher.rb +184 -0
- data/ruby_ex/session/error.rb +21 -0
- data/ruby_ex/session/fetchable.rb +57 -0
- data/ruby_ex/session/fetcher.rb +62 -0
- data/ruby_ex/session/hookable.rb +26 -0
- data/ruby_ex/session/profile.rb +110 -0
- data/ruby_ex/session/server.rb +582 -0
- data/ruby_ex/session/test/administrable_test.rb +337 -0
- data/ruby_ex/session/test/basic_test.rb +523 -0
- data/ruby_ex/session/test/dispatcher_test.rb +409 -0
- data/ruby_ex/session/test/fetchable_test.rb +119 -0
- data/ruby_ex/session/test/sub_server_test.rb +188 -0
- data/ruby_ex/spring.rb +136 -0
- data/ruby_ex/spring_set.rb +137 -0
- data/ruby_ex/symtbl.rb +106 -0
- data/ruby_ex/synflow.rb +474 -0
- data/ruby_ex/test/unit/ui/yaml/testrunner.rb +164 -0
- data/ruby_ex/thread_mutex.rb +10 -0
- data/ruby_ex/timeout_ex.rb +81 -0
- data/ruby_ex/top_down.rb +73 -0
- data/ruby_ex/trace.rb +26 -0
- data/ruby_ex/uri/druby.rb +81 -0
- data/ruby_ex/uri/file.rb +39 -0
- data/ruby_ex/uri/ftp_ex.rb +37 -0
- data/ruby_ex/uri/http_ex.rb +43 -0
- data/ruby_ex/uri/svn.rb +101 -0
- data/ruby_ex/uri_ex.rb +35 -0
- data/ruby_ex/version.rb +66 -0
- data/ruby_ex/yaml/basenode_ext.rb +63 -0
- data/ruby_ex/yaml/transform.rb +447 -0
- data/ruby_ex/yaml/yregexpath.rb +76 -0
- data/test/all/TestTAssert/first.yml +65 -0
- data/test/all/TestTAssert/segfault.yml +31 -0
- data/test/all/dist-suite-indirect-nested.yml +15 -0
- data/test/all/dist-suite-nested-3.yml +16 -0
- data/test/all/dist-suite-nested-in-pool.yml +51 -0
- data/test/all/dist-suite-nested.yml +28 -0
- data/test/all/no_suite.yml +18 -0
- data/test/all/pipeline-timeout.yml +21 -0
- data/test/all/remote_cmd.yml +23 -0
- data/test/all/remote_dispatcher.yml +26 -0
- data/test/all/suite_timeout.yml +32 -0
- data/test/all/weight.yml +113 -0
- data/test/all/xunit/junit/MultiRight/Foo/Foo.java +11 -0
- data/test/all/xunit/junit/MultiRight/Foo/FooTest.java +15 -0
- data/test/all/xunit/junit/MultiRight/MultiRight.java +13 -0
- data/test/all/xunit/junit/MultiRight/MultiRightTest.java +12 -0
- data/test/all/xunit/junit/MultiRight/bar/Bar.java +11 -0
- data/test/all/xunit/junit/MultiRight/bar/BarTest.java +21 -0
- data/test/all/xunit/junit/MultiRight/build.sh +7 -0
- data/test/all/xunit/junit/SimpleException/SimpleExceptionTest.java +11 -0
- data/test/all/xunit/junit/SimpleException/build.sh +4 -0
- data/test/all/xunit/junit/build.sh +9 -0
- data/test/all/xunit/junit/multibar.yml +6 -0
- data/test/all/xunit/junit/multifoo.yml +6 -0
- data/test/all/xunit/junit/multiright.yml +8 -0
- data/test/all/xunit/junit/simple_exception.yml +6 -0
- data/test/examples-suite.yml +10 -0
- data/test/examples/README +68 -0
- data/test/examples/cache/simple.yml +33 -0
- data/test/examples/sql/basic.yml +26 -0
- data/test/examples/students-suite.yml +11 -0
- data/test/examples/students/ball.yml +13 -0
- data/test/examples/students/glob_stud.yml +23 -0
- data/test/examples/students/mini-lib.yml +73 -0
- data/test/examples/students/pool_stud.yml +35 -0
- data/test/examples/students/stud.yml +25 -0
- data/test/ressources/ball/20040804-exam_a1-zapngo-tessar_m.tar.gz +0 -0
- data/test/ressources/ball/Makefile +24 -0
- data/test/ressources/ball/bar_p-mini-lib.tar.bz2 +0 -0
- data/test/ressources/ball/bar_p-mini-lib/Makefile +20 -0
- data/test/ressources/ball/bar_p-mini-lib/my_strlen.c +13 -0
- data/test/ressources/ball/foo_s-mini-lib.tar.bz2 +0 -0
- data/test/ressources/ball/foo_s-mini-lib/Makefile +20 -0
- data/test/ressources/ball/foo_s-mini-lib/configure +2 -0
- data/test/ressources/ball/foo_s-mini-lib/my_strlen.c +10 -0
- data/test/ressources/ball/hello.tar.bz2 +0 -0
- data/test/ressources/ball/hello.tar.gz +0 -0
- data/test/ressources/ball/hello/Makefile +14 -0
- data/test/ressources/ball/hello/hello.c +7 -0
- data/test/ressources/ball/jack-exit.tar.bz2 +0 -0
- data/test/ressources/ball/jack-exit/Makefile +14 -0
- data/test/ressources/ball/jack-exit/exit.c +16 -0
- data/test/ressources/ball/joe-exit.tar.bz2 +0 -0
- data/test/ressources/ball/joe-exit/Makefile +14 -0
- data/test/ressources/ball/joe-exit/exit.c +8 -0
- data/test/ressources/ball/joe_i-mini-lib.tar.bz2 +0 -0
- data/test/ressources/ball/joe_i-mini-lib/Makefile +20 -0
- data/test/ressources/ball/joe_i-mini-lib/configure +2 -0
- data/test/ressources/ball/joe_i-mini-lib/my_strlen.c +10 -0
- data/test/ressources/ball/john-exit.tar.bz2 +0 -0
- data/test/ressources/ball/john-exit/Makefile +14 -0
- data/test/ressources/ball/john-exit/exit.c +6 -0
- data/test/ressources/ball/qux_j-mini-lib.tar.bz2 +0 -0
- data/test/ressources/ball/qux_j-mini-lib/Makefile +20 -0
- data/test/ressources/ball/qux_j-mini-lib/my_strlen.c +12 -0
- data/test/ressources/mini-lib/Makefile +9 -0
- data/test/ressources/mini-lib/strlen.c +15 -0
- data/test/ressources/package/pkg_foo.tar.gz +0 -0
- data/test/ressources/package/pkg_foo/Makefile +20 -0
- data/test/ressources/package/pkg_foo/bootstrap +3 -0
- data/test/ressources/package/pkg_foo/configure +3 -0
- data/test/ressources/package/pkg_foo/foo.sh +2 -0
- data/test/ressources/runit/bad.rb +30 -0
- data/test/ressources/runit/error.rb +6 -0
- data/test/ressources/runit/good.rb +30 -0
- data/test/ressources/text/1.txt +4 -0
- data/test/runit/dumpers/xml_test.rb +75 -0
- data/test/runit/dumpers/yaml_test.rb +68 -0
- data/test/runit/fetchers/fetchers_test.rb +48 -0
- data/test/runit/loaders/OYaml_test.rb +35 -0
- data/test/runit/logger/section_node_test.rb +125 -0
- data/test/runit/logger/severity_test.rb +41 -0
- data/test/runit/logger/verbosity_test.rb +49 -0
- data/test/runit/logger_test.rb +295 -0
- data/test/runit/strategies/Strategy/assert_eval_test.rb +196 -0
- data/test/ttk-check +26 -0
- data/test/ttk-dist-suite.yml +44 -0
- data/test/ttk-dist/cat/file.in +3 -0
- data/test/ttk-dist/cat/file.out +3 -0
- data/test/ttk-dist/dist-abort.yml +51 -0
- data/test/ttk-dist/dist-cat.yml +38 -0
- data/test/ttk-dist/dist-delegate.yml +56 -0
- data/test/ttk-dist/dist-dispatch.yml +28 -0
- data/test/ttk-dist/dist-error.yml +10 -0
- data/test/ttk-dist/dist-fail.yml +9 -0
- data/test/ttk-dist/dist-nested-pass.yml +11 -0
- data/test/ttk-dist/dist-pass.yml +8 -0
- data/test/ttk-dist/dist-ribute.yml +31 -0
- data/test/ttk-dist/dist-suite.yml +18 -0
- data/test/ttk-dist/local-fetch.yml +17 -0
- data/test/ttk-dist/tester.yml +36 -0
- data/test/ttk-minimal-suite.yml +12 -0
- data/test/ttk-minimal/author.yml +14 -0
- data/test/ttk-minimal/base.yml +137 -0
- data/test/ttk-minimal/block.yml +15 -0
- data/test/ttk-minimal/cat.yml +19 -0
- data/test/ttk-minimal/diff.yml +29 -0
- data/test/ttk-minimal/env_cmd.yml +54 -0
- data/test/ttk-minimal/exit.yml +17 -0
- data/test/ttk-minimal/fatal.yml +32 -0
- data/test/ttk-minimal/glob.yml +13 -0
- data/test/ttk-minimal/import.yml +33 -0
- data/test/ttk-minimal/killall.yml +36 -0
- data/test/ttk-minimal/pkg.yml +18 -0
- data/test/ttk-minimal/pool.yml +44 -0
- data/test/ttk-minimal/probability_threshold.yml +39 -0
- data/test/ttk-minimal/runit.yml +25 -0
- data/test/ttk-minimal/signal_cmd.yml +24 -0
- data/test/ttk-minimal/sub.yml +9 -0
- data/test/ttk-minimal/test.yml +26 -0
- data/test/ttk-minimal/timeout.yml +24 -0
- data/test/ttk-minimal/unit_test.yml +13 -0
- data/test/ttk-minimal/wc.yml +28 -0
- metadata +801 -0
@@ -0,0 +1,606 @@
|
|
1
|
+
# Author:: The TTK Team.
|
2
|
+
# Copyright:: Copyright (c) 2004, 2005 TTK team. All rights reserved.
|
3
|
+
# License:: LGPL
|
4
|
+
# $Id: Strategy.rb 575 2005-04-14 10:22:30Z polrop $
|
5
|
+
|
6
|
+
|
7
|
+
require 'set'
|
8
|
+
require 'timeout'
|
9
|
+
require 'synflow'
|
10
|
+
require 'thread_mutex'
|
11
|
+
|
12
|
+
require 'attributed_class'
|
13
|
+
|
14
|
+
module TTK
|
15
|
+
|
16
|
+
# FIXME: explain here how to write a new strategy
|
17
|
+
module Strategies
|
18
|
+
|
19
|
+
# This is the base class for anything _testable_. It provides some basics
|
20
|
+
# attributes like the name of the test.
|
21
|
+
class Strategy
|
22
|
+
include Abstract
|
23
|
+
include AttributedClass
|
24
|
+
|
25
|
+
require 'ttk/strategies/Strategy/assert_eval'
|
26
|
+
|
27
|
+
class AttributedClass::Attribute
|
28
|
+
alias :initialize_without_expand :initialize
|
29
|
+
def initialize ( name, desc, *a, &b )
|
30
|
+
my, our = a.partition { |x| x == :dont_expand }
|
31
|
+
@expand = my.empty?
|
32
|
+
initialize_without_expand(name, desc, *our, &b)
|
33
|
+
end
|
34
|
+
|
35
|
+
def expand?
|
36
|
+
@expand
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
|
41
|
+
#
|
42
|
+
# Exceptions
|
43
|
+
#
|
44
|
+
|
45
|
+
# Warn: do not raise this exception it's almost deprecated.
|
46
|
+
class Failure < TTKException
|
47
|
+
end
|
48
|
+
|
49
|
+
|
50
|
+
#
|
51
|
+
# Accessors
|
52
|
+
#
|
53
|
+
|
54
|
+
attr_reader :status, :symtbl
|
55
|
+
|
56
|
+
|
57
|
+
#
|
58
|
+
# Constructor
|
59
|
+
#
|
60
|
+
|
61
|
+
# Create a new Strategy with the given optional document.
|
62
|
+
def initialize ( &block )
|
63
|
+
@status = StartStatus.new
|
64
|
+
@symbols = {}
|
65
|
+
initialize_attributes
|
66
|
+
@save = nil
|
67
|
+
@reject = Set.new
|
68
|
+
block[self] if block_given?
|
69
|
+
end
|
70
|
+
|
71
|
+
#
|
72
|
+
# Methods
|
73
|
+
#
|
74
|
+
|
75
|
+
# Runs this test, proceding like this:
|
76
|
+
# - pre_assertion
|
77
|
+
# - prologue
|
78
|
+
# - run_impl
|
79
|
+
# - assertion
|
80
|
+
# - post_assertion
|
81
|
+
# - epilogue
|
82
|
+
def run ( log=@symtbl[:log] )
|
83
|
+
@log = log
|
84
|
+
initialize_flow_factory if @symtbl[:flow_factory].nil?
|
85
|
+
flow = @symtbl[:flow]
|
86
|
+
flow << :prologue
|
87
|
+
|
88
|
+
@status = RunningStatus.new
|
89
|
+
@thread = Thread.current
|
90
|
+
|
91
|
+
aborted = nil
|
92
|
+
|
93
|
+
saved_path_size = @log.path_size
|
94
|
+
begin
|
95
|
+
begin
|
96
|
+
|
97
|
+
# Pre assertion
|
98
|
+
pre_assertion_failed = nil
|
99
|
+
begin
|
100
|
+
unless r = pre_assertion()
|
101
|
+
pre_assertion_failed = "Pre assertion failed (#{r.inspect})"
|
102
|
+
end
|
103
|
+
rescue Exception => ex
|
104
|
+
pre_assertion_failed = ex
|
105
|
+
end
|
106
|
+
if pre_assertion_failed
|
107
|
+
@log.new_node(to_s)
|
108
|
+
@symtbl[:flow] << :error
|
109
|
+
skip(pre_assertion_failed)
|
110
|
+
end
|
111
|
+
|
112
|
+
begin
|
113
|
+
prologue()
|
114
|
+
# @log.flow_id = flow.i
|
115
|
+
|
116
|
+
# Catch all other exceptions and wrapped them in an error.
|
117
|
+
rescue Exception => ex
|
118
|
+
raise_error(ex)
|
119
|
+
end
|
120
|
+
|
121
|
+
msg = "abort `%name' with timeout #{@timeout}s"
|
122
|
+
specific_abort = TimeoutAbortStatus.new(flow, msg)
|
123
|
+
|
124
|
+
begin
|
125
|
+
flow << :begin_run_impl
|
126
|
+
skip_if_cached
|
127
|
+
Timeout.timeout(@timeout, specific_abort) do
|
128
|
+
run_impl()
|
129
|
+
end
|
130
|
+
ensure
|
131
|
+
flow << :end_run_impl
|
132
|
+
end
|
133
|
+
|
134
|
+
# Post assertion
|
135
|
+
post_assertion_failed = nil
|
136
|
+
begin
|
137
|
+
unless r = post_assertion()
|
138
|
+
post_assertion_failed = "Post assertion failed (#{r.inspect})"
|
139
|
+
end
|
140
|
+
rescue Exception => ex
|
141
|
+
post_assertion_failed = ex
|
142
|
+
end
|
143
|
+
fail(post_assertion_failed) if post_assertion_failed
|
144
|
+
|
145
|
+
|
146
|
+
# Assertion
|
147
|
+
assertion()
|
148
|
+
|
149
|
+
|
150
|
+
raise_error('no status given')
|
151
|
+
|
152
|
+
# Forward StatusException
|
153
|
+
rescue StatusException => ex
|
154
|
+
st = ex.status
|
155
|
+
# Put the exception in `aborted' if it dosen't concern me and abort.
|
156
|
+
if st.is_a? TimeoutAbortStatus
|
157
|
+
aborted = ex if st != specific_abort
|
158
|
+
st.message.gsub!('%name', @name.to_s)
|
159
|
+
end
|
160
|
+
raise ex
|
161
|
+
|
162
|
+
# Convert the Failure exception with `fail' (Warn: almost deprecated).
|
163
|
+
rescue Failure => ex
|
164
|
+
fail(ex)
|
165
|
+
|
166
|
+
# Catch all others exceptions and wrapped them in an error.
|
167
|
+
rescue Exception => ex
|
168
|
+
raise_error(ex)
|
169
|
+
end
|
170
|
+
|
171
|
+
# Threat Status exceptions
|
172
|
+
rescue StatusException => ex
|
173
|
+
begin
|
174
|
+
|
175
|
+
flow << :epilogue
|
176
|
+
@status = ex.status
|
177
|
+
# Call the specific hook (pass_hook, failed_hook...).
|
178
|
+
send(ex.status.hook_name)
|
179
|
+
epilogue() unless pre_assertion_failed
|
180
|
+
|
181
|
+
rescue SynFlow::Error => ex
|
182
|
+
display_unexpected_synflow_exc ex, :epilogue
|
183
|
+
|
184
|
+
rescue Exception => ex
|
185
|
+
display_unexpected_exc ex
|
186
|
+
end
|
187
|
+
|
188
|
+
rescue Exception => ex
|
189
|
+
display_unexpected_exc ex
|
190
|
+
end
|
191
|
+
|
192
|
+
begin
|
193
|
+
@status.to_ttk_log(@log) unless @reject.include?(:status)
|
194
|
+
@status.weight *= @weight
|
195
|
+
(@log.path_size - saved_path_size).times { |i| @log.up }
|
196
|
+
if cache = @symtbl[:cache]
|
197
|
+
cache[@symtbl[:pathname]] =
|
198
|
+
{
|
199
|
+
:status => @status,
|
200
|
+
:symtbl => @symtbl.local
|
201
|
+
}
|
202
|
+
end
|
203
|
+
@reject.clear if defined? @reject
|
204
|
+
clean_instance_variables
|
205
|
+
flow << :finish
|
206
|
+
rescue SynFlow::Error => ex
|
207
|
+
display_unexpected_synflow_exc ex, :finish
|
208
|
+
rescue Exception => ex
|
209
|
+
display_unexpected_exc ex
|
210
|
+
end
|
211
|
+
raise aborted unless aborted.nil?
|
212
|
+
return @status
|
213
|
+
|
214
|
+
end
|
215
|
+
|
216
|
+
alias call run
|
217
|
+
|
218
|
+
#
|
219
|
+
# Custom accessors
|
220
|
+
#
|
221
|
+
|
222
|
+
def wclass=(other)
|
223
|
+
if other.is_a?(Class)
|
224
|
+
@wclass = other
|
225
|
+
else
|
226
|
+
@wclass = TTK::Weights.const_get(other.to_s)
|
227
|
+
end
|
228
|
+
end
|
229
|
+
|
230
|
+
#
|
231
|
+
# Assign
|
232
|
+
#
|
233
|
+
|
234
|
+
# Assign an attribute safely from a key:String and a value.
|
235
|
+
def assign_one(key, val, silent=false)
|
236
|
+
return if [:strategy].include? key.to_sym
|
237
|
+
meth = key.to_s + '='
|
238
|
+
if !val.nil?
|
239
|
+
if respond_to?(meth) or respond_to?(:method_missing)
|
240
|
+
send(meth, val)
|
241
|
+
elsif not silent
|
242
|
+
@log.log_warn { "Attribute #{key} not found for #{self.class}"}
|
243
|
+
end
|
244
|
+
end
|
245
|
+
end
|
246
|
+
protected :assign_one
|
247
|
+
|
248
|
+
# This can be overrided to specify which attribute is assign at last.
|
249
|
+
def assign_at_last
|
250
|
+
nil
|
251
|
+
end
|
252
|
+
protected :assign_at_last
|
253
|
+
|
254
|
+
# Assign a +hsh+ keeping at last the attribute referenced by
|
255
|
+
# _assign_at_last_.
|
256
|
+
def assign(hsh)
|
257
|
+
last = assign_at_last
|
258
|
+
hsh.each_pair { |key, val| assign_one(key, val) if key.to_sym != last }
|
259
|
+
assign_one(last, hsh[last]) if hsh.has_key? last
|
260
|
+
end
|
261
|
+
|
262
|
+
#
|
263
|
+
# Reject
|
264
|
+
#
|
265
|
+
|
266
|
+
def reject ( *att )
|
267
|
+
@reject += att.map! { |a| a.to_sym }
|
268
|
+
end
|
269
|
+
|
270
|
+
def initialize_flow_factory
|
271
|
+
factory = SynFlowFactory.new
|
272
|
+
factory <<
|
273
|
+
{
|
274
|
+
:start_st => {
|
275
|
+
:prologue => :prologue_st,
|
276
|
+
:not_running? => :start_st,
|
277
|
+
:end_run_impl => :after_run_st,
|
278
|
+
# :abort => :start_st,
|
279
|
+
:error => :error_st
|
280
|
+
},
|
281
|
+
|
282
|
+
:prologue_st => {
|
283
|
+
:begin_run_impl => :run_impl_st,
|
284
|
+
:error => :error_st
|
285
|
+
},
|
286
|
+
|
287
|
+
:run_impl_st => {
|
288
|
+
:prologue => :prologue_st,
|
289
|
+
:end_run_impl => :after_run_st,
|
290
|
+
:abort => :abort_st,
|
291
|
+
:error => :error_st
|
292
|
+
},
|
293
|
+
|
294
|
+
:after_run_st => {
|
295
|
+
:epilogue => :epilogue_st,
|
296
|
+
:error => :error_st
|
297
|
+
},
|
298
|
+
|
299
|
+
:epilogue_st => {
|
300
|
+
:finish => :start_st,
|
301
|
+
:error => :error_st
|
302
|
+
},
|
303
|
+
|
304
|
+
:abort_st => {
|
305
|
+
:end_run_impl => :after_run_abort_st,
|
306
|
+
:abort => :abort_st,
|
307
|
+
:error => :error_st
|
308
|
+
},
|
309
|
+
|
310
|
+
:after_run_abort_st => {
|
311
|
+
:epilogue => :epilogue_abort_st,
|
312
|
+
:abort => :after_run_abort_st,
|
313
|
+
:error => :error_st
|
314
|
+
},
|
315
|
+
|
316
|
+
:epilogue_abort_st => {
|
317
|
+
:finish => :start_st,
|
318
|
+
:error => :error_st
|
319
|
+
},
|
320
|
+
|
321
|
+
:error_st => {
|
322
|
+
:prologue => :prologue_st,
|
323
|
+
:begin_run_impl => :run_impl_st,
|
324
|
+
:end_run_impl => :after_run_st,
|
325
|
+
:epilogue => :epilogue_st,
|
326
|
+
:finish => :start_st,
|
327
|
+
:no_running? => :error_st,
|
328
|
+
:error => :error_st,
|
329
|
+
:abort => :abort_st
|
330
|
+
},
|
331
|
+
}
|
332
|
+
factory.initial = :start_st
|
333
|
+
@symtbl[:flow_factory] = factory
|
334
|
+
@symtbl[:flow] = factory.new_flow
|
335
|
+
end
|
336
|
+
|
337
|
+
def skip_if_cached
|
338
|
+
if cache = @symtbl[:use_cache]
|
339
|
+
me = cache[@symtbl[:pathname]]
|
340
|
+
if me and @symtbl[:cache_proc][self, me[:status]]
|
341
|
+
@symtbl.local.merge!(me[:symtbl])
|
342
|
+
skip(@wclass.new(me[:status].weight))
|
343
|
+
end
|
344
|
+
end
|
345
|
+
end
|
346
|
+
|
347
|
+
def clean_instance_variables
|
348
|
+
attrs = Set.new(self.class.attributes.map { |a| "@#{a.name}" })
|
349
|
+
vars = Set.new(instance_variables)
|
350
|
+
exceptions = Set.new(%w[ @status @thread ])
|
351
|
+
(vars - attrs - exceptions).each do |var|
|
352
|
+
remove_instance_variable var
|
353
|
+
end
|
354
|
+
end
|
355
|
+
|
356
|
+
def check_assertion ( header, assertion )
|
357
|
+
bind = {}
|
358
|
+
code = ''
|
359
|
+
case assertion
|
360
|
+
when String
|
361
|
+
return true if assertion.empty?
|
362
|
+
when Hash
|
363
|
+
return true if assertion.empty?
|
364
|
+
bind = assertion[:files] unless assertion[:files].nil?
|
365
|
+
code = assertion[:assert] unless assertion[:assert].nil?
|
366
|
+
when Array
|
367
|
+
return true if assertion.empty?
|
368
|
+
assertion.all? { |a| check_assertion(header, a) }
|
369
|
+
else
|
370
|
+
code = assertion.to_s
|
371
|
+
end
|
372
|
+
@assert_eval.run(code, bind, "(#@name:#{header})")
|
373
|
+
end
|
374
|
+
protected :check_assertion
|
375
|
+
|
376
|
+
|
377
|
+
def pre_assertion
|
378
|
+
@assert_eval = AssertEval.new
|
379
|
+
check_assertion('pre-assertion: ', @pre_assertion)
|
380
|
+
end
|
381
|
+
protected :pre_assertion
|
382
|
+
|
383
|
+
|
384
|
+
# Display test attributes. Attributes displayed and their order is
|
385
|
+
# specified by the class attribute _attributes_.
|
386
|
+
def prologue
|
387
|
+
if @symtbl[:loader].nil?
|
388
|
+
raise ArgumentError, 'no loader in the symtbl'
|
389
|
+
end
|
390
|
+
@save = {}
|
391
|
+
res = OHash.new
|
392
|
+
check_attributes
|
393
|
+
each_attribute do |attr, val|
|
394
|
+
next if val.nil?
|
395
|
+
name = attr.name
|
396
|
+
if attr.expand? and new_val = val.symtbl_gsub(@symtbl)
|
397
|
+
@save[name] = val
|
398
|
+
val = new_val
|
399
|
+
send("#{name}=", val)
|
400
|
+
end
|
401
|
+
if attr.visible? and not @reject.include? name
|
402
|
+
res[name] = val unless val == attr.default or name == :name
|
403
|
+
end
|
404
|
+
end
|
405
|
+
@symbols.each do |k, v|
|
406
|
+
@symtbl[k] = v
|
407
|
+
end
|
408
|
+
unless @reject.include? :name
|
409
|
+
if @symtbl[:pathname].nil?
|
410
|
+
@symtbl[:pathname] = ('/' + self.name).to_sym
|
411
|
+
else
|
412
|
+
@symtbl[:pathname] = :"#{@symtbl[:pathname]}/#{self.name}"
|
413
|
+
end
|
414
|
+
@log.new_node(self.name) unless @reject.include? :name
|
415
|
+
end
|
416
|
+
unless @symtbl[:tester].nil?
|
417
|
+
@log[:tester] = "#{@symtbl[:tester].config[:tester_name]} " +
|
418
|
+
"[#{@symtbl[:tester].config[:tester_type]}] " +
|
419
|
+
"{#{@symtbl[:tester].uri.host}:" +
|
420
|
+
"#{@symtbl[:tester].uri.port}}"
|
421
|
+
end
|
422
|
+
res.to_ttk_log(@log)
|
423
|
+
end
|
424
|
+
protected :prologue
|
425
|
+
|
426
|
+
|
427
|
+
# Compute really the test, only this method can be time checked.
|
428
|
+
def run_impl
|
429
|
+
end
|
430
|
+
protected :run_impl
|
431
|
+
|
432
|
+
|
433
|
+
# Exploit the results and assert when you want
|
434
|
+
def assertion
|
435
|
+
end
|
436
|
+
protected :assertion
|
437
|
+
|
438
|
+
|
439
|
+
def post_assertion
|
440
|
+
@assert_eval ||= AssertEval.new
|
441
|
+
check_assertion('post-assertions: ', @post_assertion)
|
442
|
+
end
|
443
|
+
protected :post_assertion
|
444
|
+
|
445
|
+
|
446
|
+
# Display conclusions.
|
447
|
+
# Here you can finish some tasks even when the test fails.
|
448
|
+
# Exceptions are absolutly forbidden in this method.
|
449
|
+
def epilogue
|
450
|
+
unless @save.nil?
|
451
|
+
@save.each { |k,v| send("#{k}=", v) }
|
452
|
+
@save.clear
|
453
|
+
end
|
454
|
+
end
|
455
|
+
protected :epilogue
|
456
|
+
|
457
|
+
# Here you can do some tasks when the test failed.
|
458
|
+
def failed_hook
|
459
|
+
end
|
460
|
+
protected :failed_hook
|
461
|
+
|
462
|
+
# Here you can do some tasks when an error occur during the test.
|
463
|
+
def error_hook
|
464
|
+
end
|
465
|
+
protected :error_hook
|
466
|
+
|
467
|
+
# Here you can do some tasks when the test is aborted.
|
468
|
+
def abort_hook
|
469
|
+
end
|
470
|
+
protected :abort_hook
|
471
|
+
|
472
|
+
# Here you can do some task when the test is skiped.
|
473
|
+
def skip_hook
|
474
|
+
end
|
475
|
+
protected :skip_hook
|
476
|
+
|
477
|
+
# Here you can do some tasks when the test is passed.
|
478
|
+
def pass_hook
|
479
|
+
end
|
480
|
+
protected :pass_hook
|
481
|
+
|
482
|
+
|
483
|
+
|
484
|
+
#
|
485
|
+
# Assertions
|
486
|
+
#
|
487
|
+
|
488
|
+
def raise_status ( status )
|
489
|
+
@thread.raise(status)
|
490
|
+
end
|
491
|
+
protected :raise_status
|
492
|
+
|
493
|
+
def raise_status_custom ( status_class, *args )
|
494
|
+
weight, message = args.partition { |x| x.is_a? Weights::Weight }
|
495
|
+
if weight.size > 1 or message.size > 1
|
496
|
+
raise ArgumentError, 'too much arguments'
|
497
|
+
end
|
498
|
+
raise_status status_class.new(weight[0], message[0])
|
499
|
+
end
|
500
|
+
protected :raise_status_custom
|
501
|
+
|
502
|
+
# Force the test to pass
|
503
|
+
def pass
|
504
|
+
raise_status PassStatus.new
|
505
|
+
end
|
506
|
+
|
507
|
+
# Skip the test
|
508
|
+
def skip ( *args )
|
509
|
+
raise_status_custom SkipStatus, *args
|
510
|
+
end
|
511
|
+
|
512
|
+
# Force an Error status
|
513
|
+
def raise_error ( message=nil )
|
514
|
+
@symtbl[:flow] << :error
|
515
|
+
raise_status ErrorStatus.new(message)
|
516
|
+
end
|
517
|
+
|
518
|
+
# Force the test to fail
|
519
|
+
def fail ( *args )
|
520
|
+
raise_status_custom FailStatus, *args
|
521
|
+
end
|
522
|
+
|
523
|
+
# Abort the test explicitly.
|
524
|
+
def abort ( message='abort explicitly' )
|
525
|
+
@symtbl[:flow] << :abort # FIXME
|
526
|
+
raise_status AbortStatus.new(@symtbl[:flow], message)
|
527
|
+
end
|
528
|
+
|
529
|
+
|
530
|
+
#
|
531
|
+
# Build methods
|
532
|
+
#
|
533
|
+
|
534
|
+
def testify ( aLoader=nil )
|
535
|
+
self
|
536
|
+
end
|
537
|
+
|
538
|
+
def to_s
|
539
|
+
@name || @log.path.to_s || super
|
540
|
+
end
|
541
|
+
|
542
|
+
def timeout=(other)
|
543
|
+
if other >= 0
|
544
|
+
@timeout = other
|
545
|
+
else
|
546
|
+
raise(ArgumentError, "`#{other}' - timeout delay must be >= 0")
|
547
|
+
end
|
548
|
+
end
|
549
|
+
|
550
|
+
def running?
|
551
|
+
defined? @status and @status.is_a? RunningStatus
|
552
|
+
end
|
553
|
+
|
554
|
+
def display_unexpected_exc ( exc )
|
555
|
+
STDERR.puts 'unexpected exception'
|
556
|
+
STDERR.puts exc.long_pp
|
557
|
+
end
|
558
|
+
|
559
|
+
def display_unexpected_synflow_exc ( exc, arg )
|
560
|
+
STDERR.puts "unexpected synflow exception (#{arg})"
|
561
|
+
end
|
562
|
+
|
563
|
+
# FIXME: I'm not well dumped
|
564
|
+
def symbols= ( symbols )
|
565
|
+
symbols.each do |k, v|
|
566
|
+
@symbols[k] = v
|
567
|
+
end
|
568
|
+
end
|
569
|
+
|
570
|
+
def strategy
|
571
|
+
self.class
|
572
|
+
end
|
573
|
+
|
574
|
+
def strategy= ( aClass )
|
575
|
+
if aClass != Strategy and aClass != self.class
|
576
|
+
raise ArgumentError, "Cannot change the strategy class " +
|
577
|
+
"of a test (#{aClass} != #{self.class})"
|
578
|
+
end
|
579
|
+
end
|
580
|
+
|
581
|
+
def symtbl= ( aSymtbl )
|
582
|
+
@symtbl = aSymtbl
|
583
|
+
@log ||= @symtbl[:log]
|
584
|
+
end
|
585
|
+
|
586
|
+
attribute :name, 'test name', :invisible, :mandatory
|
587
|
+
attribute :strategy, 'the strategy class', Class, Strategy, :mandatory
|
588
|
+
attribute :wclass, 'a class to control weights', Class, Weights::Default
|
589
|
+
attribute :weight, 'a sort of coefficient. See wclass', 1
|
590
|
+
attribute :fatal, 'if the test fail all the suite fail', false
|
591
|
+
attribute :timeout, 'a duration (in seconds) before failure', 0
|
592
|
+
attribute :symbols, 'some user defined symbols' do {} end
|
593
|
+
attribute :pre_assertion, 'ruby code to assert environment condition ' +
|
594
|
+
'which must return true/false',
|
595
|
+
:invisible do [] end
|
596
|
+
attribute :post_assertion, 'ruby code to assert environment condition ' +
|
597
|
+
'which must return true/false',
|
598
|
+
:invisible do [] end
|
599
|
+
|
600
|
+
end # class Strategy
|
601
|
+
|
602
|
+
end # module Strategies
|
603
|
+
|
604
|
+
end # module TTK
|
605
|
+
|
606
|
+
|