diff --git a/tests/RunTests.hs b/tests/RunTests.hs index 3645b9dfe..483064997 100644 --- a/tests/RunTests.hs +++ b/tests/RunTests.hs @@ -60,6 +60,12 @@ lhsWriterFormats = [ "markdown" , "html+lhs" ] +lhsReaderFormats :: [String] +lhsReaderFormats = [ "markdown+lhs" + , "rst+lhs" + , "latex+lhs" + ] + main :: IO () main = do r1s <- mapM runWriterTest writerFormats @@ -83,7 +89,8 @@ main = do r11 <- runTest "native reader" ["-r", "native", "-w", "native", "-s"] "testsuite.native" "testsuite.native" r12s <- mapM runLhsWriterTest lhsWriterFormats - let results = r1s ++ [r2, r3, r4, r5, r6, r7, r7a, r8, r9, r10, r11] ++ r12s + r13s <- mapM runLhsReaderTest lhsReaderFormats + let results = r1s ++ [r2, r3, r4, r5, r6, r7, r7a, r8, r9, r10, r11] ++ r12s ++ r13s if all id results then do putStrLn "\nAll tests passed." @@ -102,6 +109,10 @@ runLhsWriterTest :: String -> IO Bool runLhsWriterTest format = runTest ("(lhs) " ++ format ++ " writer") ["-r", "native", "-s", "-w", format] "lhs-test.native" ("lhs-test" <.> format) +runLhsReaderTest :: String -> IO Bool +runLhsReaderTest format = + runTest ("(lhs) " ++ format ++ " reader") ["-r", format, "-w", "html+lhs"] ("lhs-test" <.> format) "lhs-test.fragment.html+lhs" + runWriterTest :: String -> IO Bool runWriterTest format = do r1 <- runTest (format ++ " writer") ["-r", "native", "-s", "-w", format] "testsuite.native" ("writer" <.> format) diff --git a/tests/lhs-test.fragment.html+lhs b/tests/lhs-test.fragment.html+lhs new file mode 100644 index 000000000..2a0683850 --- /dev/null +++ b/tests/lhs-test.fragment.html+lhs @@ -0,0 +1,47 @@ +<h1 id="lhs-test" +>lhs test</h1 +><p +><code + >unsplit</code + > is an arrow that takes a pair of values and combines them to return a single value:</p +><pre class="sourceCode literatehaskell" +><code + ><span class="Char Special" + >></span + ><span class="Function FunctionDefinition" + > unsplit ::</span + ><span class="Normal NormalText" + > (Arrow a) => (b -> c -> d) -> a (b, c) d</span + ><br + /><span class="Char Special" + >></span + ><span class="Normal NormalText" + > unsplit = arr . </span + ><span class="Function" + >uncurry</span + ><span class="Normal NormalText" + > </span + ><br + /><span class="Char Special" + >></span + ><span class="Normal NormalText" + > </span + ><span class="Comment" + >-- arr (\op (x,y) -> x `op` y) </span + ><br + /></code + ></pre +><p +><code + >(***)</code + > combines two arrows into a new arrow by running the two arrows on a pair of values (one arrow on the first item of the pair and one arrow on the second item of the pair).</p +><pre +><code + >f *** g = first f >>> second g +</code + ></pre +><blockquote +><p + >Here is a block quote section.</p + ></blockquote +>