]U{;      !"#$%&'()*+,-./0123456789:;<=>OExecute IO actions on several threads and return their results in the original T order. It is guaranteed that no action from the input list is executed unless all S the items that precede it in the list have been executed or are executing at that  moment. Number of threads to use :Actions to execute: these will be scheduled left to right >Ordered results of executing the given IO actions in parallel ?@MKeep grabbing items out of the infinite list of worker outputs until we have U recieved word that all of the workers have shut down. This lets us turn a possibly Y infinite list of outputs into a certainly finite one suitable for use with reorderFrom. AIThis function carefully shuffles the input list so it in the total order C defined by the integers paired with the elements. If the list is xs and ! the supplied initial integer is n, it must be the case that:  / sort (map fst xs) == [n..n + (length xs - 1)] JThis function returns items in the lazy result list as soon as it is sure * it has the right item for that position. >>BBBCCC DEFDEFDEEF GHIGHIGHI JKL]Given a number of microseconds and an improving IO action, run that improving IO action only 9 for at most the given period before giving up. See also M. As  , but don'-t bother applying a timeout to the action if Nothing is given : as the number of microseconds to apply the time out for.    Like N2, but does not append a trailing newline if there % is at least one line. For example:  % unlinesConcise ["A", "B"] == "A\nB"  unlinesConcise [] == ""  Whereas:   unlines ["A", "B"] == "A\nB\n"  unlines [] == "" #This is closer to the behaviour of O, which does not append  a trailing space.     PTEvaluates the given list for the given number of microseconds. After the time limit T has been reached, a list is returned consisting of the prefix of the list that was / successfully evaluated within the time limit. This function does not= evaluate the elements of the list: it just ensures that the # list spine arrives in good order. XThe spine of the list is evaluated on the current thread, so if spine evaluation blocks R this function will also block, potentially for longer than the specificed delay. PPQRSTUVWXYZ[\]^_`abcdQ`aQ`aefghijklmnopqrstufghijklfhgghikjjklGiven a C, returns a new random number generator based on that seed and the T actual numeric seed that was used to build that generator, so it can be recreated. FSeed that should be used to create random numbers for generated tests IMaximum number of tests to generate when using something like QuickCheck eMaximum number of unsuitable tests to consider before giving up when using something like QuickCheck !NThe number of microseconds to run tests for before considering them a failure "# !"##" ! ! !"#$%&'()*$%&'()**)$%&'($%&'(%&'()* +OMain test data type: builds up a list of tests to be run. Users should use the R utility functions in e.g. the test-framework-hunit and test-framework-quickcheck ! packages to create instances of .+), and then build them up into testsuites  by using 6 and lists. 8For an example of how to use test-framework, please see   ]http://github.com/batterseapower/test-framework/raw/master/example/Test/Framework/Example.lhs ,-.(A single test of some particular type. /$The name of a type of test, such as  Properties or  Test Cases . Tests of K types of the same names will be grouped together in the test run summary. 08Test names or descriptions. These are shown to the user 1LSomething test-like in its behaviour. The type parameters are the type that P is used for progress reports, the type of the final output of the test and the H data type encapsulating the whole potential to do a test respectively. 234;Something like the result of a test: works in concert with 1. L The type parameters are the type that is used for progress reports and the 4 type of the final output of the test respectively. 561Assemble a number of tests into a cohesive group 7 +,-./01234567 +.-,,-./012323455671  !"#+,-./01234567$451230/+.-,67 v=Records information about the run of a number of tests, such ? as how many tests have been run, how many are pending and how  many have passed or failed. wxyz{|@Records a count of the various kinds of test that have been run }~7The number of tests of all kinds recorded in the given }| DCreate some test statistics that simply records the total number of ? tests to be run, ready to be updated by the actual test runs. 5Displays statistics as a string something like this:   Properties Total  Passed 9 9  Failed 1 1  Total 10 10  vwxyz{| vwxyz{wxyz{| A test that has been executed Top-level runner options  Tests to run Nothing7 signifies that usage information should be displayed.  JustQ simply gives us the contribution to overall options by the command line option. 89:89:89:89: !"#$%&'()*+06789: 451230/+.-,67              ! " # $ % & ' ( )*+,-./01234506789:;7<=><?@ABCDEFGHIJKLMNOPQRS T T U V W X Y Z [\]^\_`\_a bccdefghijklmnopqrstuvwxwyz{|}~test-framework-0.2.3Test.Framework.Providers.APITest.Framework.SeedTest.Framework.OptionsTest.Framework.Runners.OptionsTest.Framework.Runners.Console!Test.Framework.Runners.ThreadPool!Test.Framework.Runners.Processors(Test.Framework.Runners.Console.Utilities*Test.Framework.Runners.Console.ProgressBar%Test.Framework.Runners.Console.ColorsTest.Framework.ImprovingTest.Framework.Utilities'Test.Framework.Runners.TimedConsumption"Test.Framework.Runners.TestPattern$Test.Framework.Runners.Console.TableTest.Framework.Core)Test.Framework.Runners.Console.StatisticsTest.Framework.Runners.CoreTest.Framework ImprovingIO:~> ImprovingFinishedyieldImprovementrunImprovingIOliftIOtimeoutImprovingIOmaybeTimeoutImprovingIOKunKsecondsToMicrosecondsmicrosecondsToPicosecondslistToMaybeLast mappendByorElseonLeftonRightunlinesConcise mapAccumLMpadRightdropLastSeed RandomSeed FixedSeednewSeededStdGennewStdGenWithKnownSeed TestOptions' TestOptions topt_seedtopt_maximum_generated_tests'topt_maximum_unsuitable_generated_tests topt_timeoutCompleteTestOptionsRunnerOptions' RunnerOptions ropt_threadsropt_test_optionsropt_test_patternsCompleteRunnerOptionsTestPlusTestOptions TestGroup TestTypeNameTestNameTestlikerunTest testTypeNameTestResultlike testSucceeded testGroupplusTestOptions defaultMaindefaultMainWithArgsdefaultMainWithOpts WorkerEvent WorkerItemWorkerTermination executeOnPool poolWorkertakeWhileWorkersExist reorderFromprocessorCounthideCursorDuringProgress progressBar colorFail colorPasscolorPassOrFailIIOunIIOreifyListToImprovingbaseSystem.Timeouttimeout Data.ListunlinesunwordsconsumeListInInterval TestPatterntp_categories_only tp_negated tp_match_mode tp_tokensTestPatternMatchMode PathMatchMode TestMatchModeToken LiteralTokenDoubleWildcardToken WildcardToken SlashTokentokenizeparseTestPatterntestPatternMatchesbuildTokenRegexregexEscapeChar pathToString ColumnWidthColumnSeperatorColumnCell SeperatorCellTextCell renderTablefindColumnWidth findCellWidthrenderColumnsWithWidtheitherSideSeperatorisSeperatorColumnisSeperatorCellrenderFirstColumnCellcolumnFinishedcolumnDropHeadTestStatisticsts_total_tests ts_run_teststs_passed_teststs_failed_tests TestCount unTestCounttestCountTestTypestestCountForTypeadjustTestCounttestCountTotalminusTestCountts_pending_teststs_no_failuresinitialTestStatisticsshowFinalTestStatistics coloredNumberRunTest RunTestGrouprunTests filterTests filterTestrunTest' runTests'completeTestOptionsSuppliedRunnerOptionsoptionsDescription interpretArgscompleteRunnerOptions totalRunTeststotalRunTestsList showRunTest showRunTeststestStatisticsProgressBarupdateTestStatisticsconsumeImprovingThingshowImprovingTestResultshowImprovingTestResult' putTestHeader