[      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ Safe-Inferred[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. \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. ]IThis 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. ^_`[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 a\][^`_[a\] Safe-Inferredbbb  Safe-Inferredcdecdecde  Safe-Inferredfghfghfgh Noneiii  Safe-Inferred ]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 j. 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. kl m nop  kl m nop  Safe-InferredLike q2, 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 r, which does not append  a trailing space.    Nonestuvwxyz{|}~ stuvwxzy{~}| Safe-InferredTEvaluates 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.  Safe-Inferred  Safe-InferredGiven 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.      Safe-Inferred#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 &EMaximum size of generated tests when using something like QuickCheck 'FMaximum depth of generated tests when using something like SmallCheck (NThe number of microseconds to run tests for before considering them a failure !"#$%&'()* !"#$%&'()* *)!"#$%&'(!"#$%&'()*None+,-./0123456789:+,-./0123456789:7:9865+,-./01234+ ,-./01234567:98 Safe-Inferred=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 I 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 >'Convenience for creating tests from an  action, with cleanup ? Add some options to child tests @1Assemble a number of tests into a cohesive group A&A single test of some particular type B$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. C8Test names or descriptions. These are shown to the user DLSomething 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. G;Something like the result of a test: works in concert with D. 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. I1Assemble a number of tests into a cohesive group J Add some options to child tests K'Convenience for creating tests from an  action L'Convenience for creating tests from an < action, with a cleanup handler for when tests are finished M]Mark all tests in this portion of the tree as mutually exclusive, so only one runs at a time ;<=>?@ABCDEFGHIJKLM;<=>?@ABCDEFGHIJKLM ;<=A@?>BCDEFGHIJKLM Safe-Inferred=  !"#$%&'()*;<=>?@ABCDEFGHIJKLM.GHDEFCB=A@?>IJKL;<M  NoneNN class simplifies folding a =. You need to specify A the important semantic actions by instantiating this class, and  S1 will take care of recursion and test filtering. OHow to handle a single test PHow to skip a test that doesn't satisfy the pattern Q'How to handle an IO test (created with L) RHow to run a test group @A test that has been executed or is in the process of execution SRun the test tree using a N NOPQRTop-level runner options  Tests to run S?skip the tests that do not match any of these patterns, unless  the list is empty NOPQRS NOPQRSNone+,-./0123456789:NOPQRSNOPQRSNone=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. @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. None5Displays statistics as a string something like this:   Properties Total  Passed 9 9  Failed 1 1  Total 10 10 None  NoneAAn overall description of the test suite run. This is currently C styled after the JUnit xml. It contains records that are not yet C used, however, it provides a sensible structure to populate as we C are able, and the serialiazation code behaves as though these are  filled. )The number of tests that triggered error % conditions (unanticipated failures) 3Count of tests that invalidated stated assertions. /Count of tests that were provided but not run. &The hostname that ran the test suite. The name of the test suite. $The total number of tests provided. -The total execution time for the test suite. 7The time stamp that identifies when this run happened. Included for completness w/ junit. #holdover from Junit spec. Could be ( used to specify the module under test. 4detailed description and results for each test run.  Serializes a  value to a . Maps a  value to an XML Element  None=Generates a description of the complete test run, given some A initial over-all test statistics and the list of tests that was  run. AThis is only specific to the XML code because the console output  Runner doesn'/t need this level of detail to produce summary < information, and the per-test details are generated during  execution. AThis could be done better by using a State monad in the notifier  defined within  issueTests. NoneTNothing7 signifies that usage information should be displayed.  JustQ simply gives us the contribution to overall options by the command line option. UCOptions understood by test-framework. This can be used to add more # options to the tester executable. V2Parse the specified command line arguments into a 6 and some remaining arguments, $ or return a reason as to why we can't. W A version of V$ that ends the process if it fails. Y A version of X1 that lets you ignore the command line arguments  in favour of another list of s. Z A version of X1 that lets you ignore the command line arguments ! in favour of an explicit set of 6. %Print out a list of available tests. TUVWXYZTUVWXYZXYZTUVW TUVWXYZNone. !"#$%&'()*+,-./0123456789:=CIJKLMTUVWXYZGHDEFCB=A@?>IJKL;<M        ! " # $ % & & ' ( ) * + , - . / 0 1 23456789:;<=>?@A:BCDEFGHIJKLCMNOPQRSTUVSWXYZ[\]^_`abcdefghijklmnopqrstuvw x x y z { | }~  ~~3~test-framework-0.8.0.1Test.Framework.Providers.APITest.Framework.Runners.OptionsTest.Framework.SeedTest.Framework.OptionsTest.Framework.Runners.APITest.Framework.Runners.Console!Test.Framework.Runners.ThreadPool(Test.Framework.Runners.Console.Utilities*Test.Framework.Runners.Console.ProgressBar%Test.Framework.Runners.Console.Colors!Test.Framework.Runners.ProcessorsTest.Framework.ImprovingTest.Framework.Utilities"Test.Framework.Runners.TestPattern'Test.Framework.Runners.TimedConsumption$Test.Framework.Runners.Console.TableTest.Framework.CoreTest.Framework.Runners.Core!Test.Framework.Runners.Statistics)Test.Framework.Runners.Console.Statistics"Test.Framework.Runners.Console.Run&Test.Framework.Runners.XML.JUnitWriterTest.Framework.Runners.XMLTest.Framework ImprovingIO:~> ImprovingFinishedbimapImproving improvingLastconsumeImprovingyieldImprovementtunnelImprovingIOrunImprovingIOliftIOtimeoutImprovingIOmaybeTimeoutImprovingIOKunKsecondsToMicrosecondsmicrosecondsToPicosecondslistToMaybeLast mappendByorElseonLeftonRightunlinesConcise mapAccumLMpadRightdropLast TestPatternSeed RandomSeed FixedSeednewSeededStdGennewStdGenWithKnownSeed TestOptions' TestOptions topt_seedtopt_maximum_generated_tests'topt_maximum_unsuitable_generated_teststopt_maximum_test_sizetopt_maximum_test_depth topt_timeoutCompleteTestOptionsRunnerOptions' RunnerOptions ropt_threadsropt_test_optionsropt_test_patternsropt_xml_outputropt_xml_nestedropt_color_moderopt_hide_successesropt_list_onlyCompleteRunnerOptions ColorMode ColorAlways ColorNever ColorAutoMutuallyExcludedMETestBuildTestBracketedPlusTestOptions TestGroup TestTypeNameTestNameTestlikerunTest testTypeNameTestResultlike testSucceeded testGroupplusTestOptions buildTestbuildTestBracketedmutuallyExclusive TestRunner runSimpleTestskipTest runIOTestrunGroup runTestTreeSuppliedRunnerOptionsoptionsDescription interpretArgsinterpretArgsOrExit defaultMaindefaultMainWithArgsdefaultMainWithOpts executeOnPooltakeWhileWorkersExist reorderFrom WorkerEvent WorkerItemWorkerTermination poolWorkerhideCursorDuringProgress progressBar colorFail colorPasscolorPassOrFailprocessorCountbaseSystem.TimeouttimeoutIIOunIIOreifyListToImproving$fMonadImprovingIO$fFunctorImprovingIO $fFunctor:~> Data.Listunlinesunwordstp_categories_only tp_negated tp_match_mode tp_tokensTestPatternMatchMode PathMatchMode TestMatchModeToken LiteralTokenDoubleWildcardToken WildcardToken SlashTokentokenizeparseTestPatterntestPatternMatchesbuildTokenRegexregexEscapeChar pathToString$fReadTestPatternconsumeListInInterval ColumnWidthColumnSeperatorColumnCell SeperatorCellTextCell renderTablefindColumnWidth findCellWidthrenderColumnsWithWidtheitherSideSeperatorisSeperatorColumnisSeperatorCellrenderFirstColumnCellcolumnFinishedcolumnDropHead $fReadSeed $fShowSeed$fMonoidTestOptions'$fMonoidRunnerOptions'ghc-prim GHC.TypesIO$fTestlikeirMutuallyExcludedRunTest StdRunnerrun FinishedTest RunningTest SomeImproving RunTestGrouprunTests runTests'completeTestOptions$fTestRunnerStdRunnerTestStatistics TestCounttestCountTotalinitialTestStatisticsts_total_tests ts_run_teststs_passed_teststs_failed_tests unTestCounttestCountTestTypestestCountForTypeadjustTestCountminusTestCountts_pending_teststs_no_failuresupdateTestStatistics totalRunTeststotalRunTestsListgatherStatistics$fMonoidTestStatistics$fMonoidTestCountshowFinalTestStatistics coloredNumbershowRunTestsTop showRunTest showRunTeststestStatisticsProgressBarshowImprovingTestResultshowImprovingTestResultProgress showImprovingTestResultProgress' possiblyPlain putTestHeaderRunDescriptionerrors failedCountskippedhostname suiteName testCounttime timeStamprunIdpackagetests serializeGHC.BaseStringtoXmlmorphFlatTestCasemorphNestedTestCasemorphOneTestCase mergeResults produceReport listTestscompleteRunnerOptions$fFunctorArgDescr$fFunctorOptDescr