2011-01-13 22:31:04 -08:00
|
|
|
{-# OPTIONS_GHC -fno-warn-orphans #-}
|
2011-12-13 14:29:07 -08:00
|
|
|
{-# LANGUAGE TypeSynonymInstances, FlexibleInstances, ScopedTypeVariables #-}
|
2011-01-13 22:31:04 -08:00
|
|
|
-- provides Arbitrary instance for Pandoc types
|
|
|
|
module Tests.Arbitrary ()
|
|
|
|
where
|
|
|
|
import Test.QuickCheck.Gen
|
|
|
|
import Test.QuickCheck.Arbitrary
|
|
|
|
import Control.Monad (liftM, liftM2)
|
2011-02-04 18:32:30 -08:00
|
|
|
import Text.Pandoc.Definition
|
|
|
|
import Text.Pandoc.Shared (normalize, escapeURI)
|
2011-01-22 12:18:23 -08:00
|
|
|
import Text.Pandoc.Builder
|
2011-01-13 22:31:04 -08:00
|
|
|
|
|
|
|
realString :: Gen String
|
2011-02-04 18:32:30 -08:00
|
|
|
realString = resize 8 $ listOf $ frequency [ (9, elements [' '..'\127'])
|
|
|
|
, (1, elements ['\128'..'\9999']) ]
|
2011-01-13 22:31:04 -08:00
|
|
|
|
2011-02-04 18:32:30 -08:00
|
|
|
arbAttr :: Gen Attr
|
|
|
|
arbAttr = do
|
|
|
|
id' <- elements ["","loc"]
|
|
|
|
classes <- elements [[],["haskell"],["c","numberLines"]]
|
|
|
|
keyvals <- elements [[],[("start","22")],[("a","11"),("b_2","a b c")]]
|
|
|
|
return (id',classes,keyvals)
|
2011-01-13 22:31:04 -08:00
|
|
|
|
2011-01-22 12:18:23 -08:00
|
|
|
instance Arbitrary Inlines where
|
2011-12-13 14:29:07 -08:00
|
|
|
arbitrary = liftM (fromList :: [Inline] -> Inlines) arbitrary
|
2011-01-22 12:18:23 -08:00
|
|
|
|
|
|
|
instance Arbitrary Blocks where
|
2011-12-13 14:29:07 -08:00
|
|
|
arbitrary = liftM (fromList :: [Block] -> Blocks) arbitrary
|
2011-01-22 12:18:23 -08:00
|
|
|
|
2011-01-13 22:31:04 -08:00
|
|
|
instance Arbitrary Inline where
|
2011-07-31 08:47:11 -07:00
|
|
|
arbitrary = resize 3 $ arbInline 2
|
2011-01-13 22:31:04 -08:00
|
|
|
|
2011-02-04 18:32:30 -08:00
|
|
|
arbInlines :: Int -> Gen [Inline]
|
|
|
|
arbInlines n = listOf1 (arbInline n) `suchThat` (not . startsWithSpace)
|
|
|
|
where startsWithSpace (Space:_) = True
|
|
|
|
startsWithSpace _ = False
|
|
|
|
|
2011-01-13 22:31:04 -08:00
|
|
|
-- restrict to 3 levels of nesting max; otherwise we get
|
|
|
|
-- bogged down in indefinitely large structures
|
|
|
|
arbInline :: Int -> Gen Inline
|
|
|
|
arbInline n = frequency $ [ (60, liftM Str realString)
|
|
|
|
, (60, return Space)
|
2011-02-04 18:32:30 -08:00
|
|
|
, (10, liftM2 Code arbAttr realString)
|
|
|
|
, (5, elements [ RawInline "html" "<a id=\"eek\">"
|
2011-01-23 10:55:56 -08:00
|
|
|
, RawInline "latex" "\\my{command}" ])
|
2011-01-13 22:31:04 -08:00
|
|
|
] ++ [ x | x <- nesters, n > 1]
|
2011-02-04 18:32:30 -08:00
|
|
|
where nesters = [ (10, liftM Emph $ arbInlines (n-1))
|
|
|
|
, (10, liftM Strong $ arbInlines (n-1))
|
|
|
|
, (10, liftM Strikeout $ arbInlines (n-1))
|
|
|
|
, (10, liftM Superscript $ arbInlines (n-1))
|
|
|
|
, (10, liftM Subscript $ arbInlines (n-1))
|
|
|
|
-- , (10, liftM SmallCaps $ arbInlines (n-1))
|
2011-01-13 22:31:04 -08:00
|
|
|
, (10, do x1 <- arbitrary
|
2011-02-04 18:32:30 -08:00
|
|
|
x2 <- arbInlines (n-1)
|
2011-01-13 22:31:04 -08:00
|
|
|
return $ Quoted x1 x2)
|
|
|
|
, (10, do x1 <- arbitrary
|
|
|
|
x2 <- realString
|
|
|
|
return $ Math x1 x2)
|
2011-02-04 18:32:30 -08:00
|
|
|
, (10, do x1 <- arbInlines (n-1)
|
2011-01-13 22:31:04 -08:00
|
|
|
x3 <- realString
|
2011-02-04 18:32:30 -08:00
|
|
|
x2 <- liftM escapeURI realString
|
2011-01-13 22:31:04 -08:00
|
|
|
return $ Link x1 (x2,x3))
|
2011-02-04 18:32:30 -08:00
|
|
|
, (10, do x1 <- arbInlines (n-1)
|
2011-01-13 22:31:04 -08:00
|
|
|
x3 <- realString
|
2011-02-04 18:32:30 -08:00
|
|
|
x2 <- liftM escapeURI realString
|
2011-01-13 22:31:04 -08:00
|
|
|
return $ Image x1 (x2,x3))
|
2011-02-04 18:32:30 -08:00
|
|
|
, (2, liftM Note $ resize 3 $ listOf1 $ arbBlock (n-1))
|
2011-01-13 22:31:04 -08:00
|
|
|
]
|
|
|
|
|
|
|
|
instance Arbitrary Block where
|
2011-07-31 08:47:11 -07:00
|
|
|
arbitrary = resize 3 $ arbBlock 2
|
2011-01-13 22:31:04 -08:00
|
|
|
|
|
|
|
arbBlock :: Int -> Gen Block
|
2011-02-04 18:32:30 -08:00
|
|
|
arbBlock n = frequency $ [ (10, liftM Plain $ arbInlines (n-1))
|
|
|
|
, (15, liftM Para $ arbInlines (n-1))
|
|
|
|
, (5, liftM2 CodeBlock arbAttr realString)
|
2011-01-23 10:55:56 -08:00
|
|
|
, (2, elements [ RawBlock "html"
|
|
|
|
"<div>\n*&*\n</div>"
|
|
|
|
, RawBlock "latex"
|
|
|
|
"\\begin[opt]{env}\nhi\n{\\end{env}"
|
|
|
|
])
|
2011-01-13 22:31:04 -08:00
|
|
|
, (5, do x1 <- choose (1 :: Int, 6)
|
2011-02-04 18:32:30 -08:00
|
|
|
x2 <- arbInlines (n-1)
|
2012-10-29 22:45:52 -07:00
|
|
|
return (Header x1 nullAttr x2))
|
2011-01-13 22:31:04 -08:00
|
|
|
, (2, return HorizontalRule)
|
|
|
|
] ++ [x | x <- nesters, n > 0]
|
2011-02-04 18:32:30 -08:00
|
|
|
where nesters = [ (5, liftM BlockQuote $ listOf1 $ arbBlock (n-1))
|
|
|
|
, (5, do x2 <- arbitrary
|
|
|
|
x3 <- arbitrary
|
|
|
|
x1 <- arbitrary `suchThat` (> 0)
|
|
|
|
x4 <- listOf1 $ listOf1 $ arbBlock (n-1)
|
|
|
|
return $ OrderedList (x1,x2,x3) x4 )
|
2011-01-29 10:02:12 -08:00
|
|
|
, (5, liftM BulletList $ (listOf1 $ listOf1 $ arbBlock (n-1)))
|
2011-02-04 18:32:30 -08:00
|
|
|
, (5, do items <- listOf1 $ do
|
|
|
|
x1 <- listOf1 $ listOf1 $ arbBlock (n-1)
|
|
|
|
x2 <- arbInlines (n-1)
|
|
|
|
return (x2,x1)
|
|
|
|
return $ DefinitionList items)
|
2011-01-13 22:31:04 -08:00
|
|
|
, (2, do rs <- choose (1 :: Int, 4)
|
|
|
|
cs <- choose (1 :: Int, 4)
|
2011-02-04 18:32:30 -08:00
|
|
|
x1 <- arbInlines (n-1)
|
2011-01-13 22:31:04 -08:00
|
|
|
x2 <- vector cs
|
|
|
|
x3 <- vectorOf cs $ elements [0, 0.25]
|
|
|
|
x4 <- vectorOf cs $ listOf $ arbBlock (n-1)
|
|
|
|
x5 <- vectorOf rs $ vectorOf cs
|
|
|
|
$ listOf $ arbBlock (n-1)
|
|
|
|
return (Table x1 x2 x3 x4 x5))
|
|
|
|
]
|
|
|
|
|
|
|
|
instance Arbitrary Pandoc where
|
2011-01-22 12:28:30 -08:00
|
|
|
arbitrary = resize 8 $ liftM normalize
|
|
|
|
$ liftM2 Pandoc arbitrary arbitrary
|
2011-01-13 22:31:04 -08:00
|
|
|
|
|
|
|
{-
|
|
|
|
instance Arbitrary CitationMode where
|
|
|
|
arbitrary
|
|
|
|
= do x <- choose (0 :: Int, 2)
|
|
|
|
case x of
|
|
|
|
0 -> return AuthorInText
|
|
|
|
1 -> return SuppressAuthor
|
|
|
|
2 -> return NormalCitation
|
|
|
|
_ -> error "FATAL ERROR: Arbitrary instance, logic bug"
|
|
|
|
|
|
|
|
instance Arbitrary Citation where
|
|
|
|
arbitrary
|
|
|
|
= do x1 <- liftM (filter (`notElem` ",;]@ \t\n")) arbitrary
|
|
|
|
x2 <- arbitrary
|
|
|
|
x3 <- arbitrary
|
|
|
|
x4 <- arbitrary
|
|
|
|
x5 <- arbitrary
|
|
|
|
x6 <- arbitrary
|
|
|
|
return (Citation x1 x2 x3 x4 x5 x6)
|
|
|
|
-}
|
|
|
|
|
|
|
|
instance Arbitrary MathType where
|
|
|
|
arbitrary
|
|
|
|
= do x <- choose (0 :: Int, 1)
|
|
|
|
case x of
|
|
|
|
0 -> return DisplayMath
|
|
|
|
1 -> return InlineMath
|
|
|
|
_ -> error "FATAL ERROR: Arbitrary instance, logic bug"
|
|
|
|
|
|
|
|
instance Arbitrary QuoteType where
|
|
|
|
arbitrary
|
|
|
|
= do x <- choose (0 :: Int, 1)
|
|
|
|
case x of
|
|
|
|
0 -> return SingleQuote
|
|
|
|
1 -> return DoubleQuote
|
|
|
|
_ -> error "FATAL ERROR: Arbitrary instance, logic bug"
|
|
|
|
|
|
|
|
instance Arbitrary Meta where
|
|
|
|
arbitrary
|
|
|
|
= do x1 <- arbitrary
|
|
|
|
x2 <- liftM (filter (not . null)) arbitrary
|
|
|
|
x3 <- arbitrary
|
|
|
|
return (Meta x1 x2 x3)
|
|
|
|
|
|
|
|
instance Arbitrary Alignment where
|
|
|
|
arbitrary
|
|
|
|
= do x <- choose (0 :: Int, 3)
|
|
|
|
case x of
|
|
|
|
0 -> return AlignLeft
|
|
|
|
1 -> return AlignRight
|
|
|
|
2 -> return AlignCenter
|
|
|
|
3 -> return AlignDefault
|
|
|
|
_ -> error "FATAL ERROR: Arbitrary instance, logic bug"
|
|
|
|
|
|
|
|
instance Arbitrary ListNumberStyle where
|
|
|
|
arbitrary
|
|
|
|
= do x <- choose (0 :: Int, 6)
|
|
|
|
case x of
|
|
|
|
0 -> return DefaultStyle
|
|
|
|
1 -> return Example
|
|
|
|
2 -> return Decimal
|
|
|
|
3 -> return LowerRoman
|
|
|
|
4 -> return UpperRoman
|
|
|
|
5 -> return LowerAlpha
|
|
|
|
6 -> return UpperAlpha
|
|
|
|
_ -> error "FATAL ERROR: Arbitrary instance, logic bug"
|
|
|
|
|
|
|
|
instance Arbitrary ListNumberDelim where
|
|
|
|
arbitrary
|
|
|
|
= do x <- choose (0 :: Int, 3)
|
|
|
|
case x of
|
|
|
|
0 -> return DefaultDelim
|
|
|
|
1 -> return Period
|
|
|
|
2 -> return OneParen
|
|
|
|
3 -> return TwoParens
|
|
|
|
_ -> error "FATAL ERROR: Arbitrary instance, logic bug"
|
|
|
|
|