refactor(pandoc): rewrite tests for pandoc applyMetas

This commit is contained in:
Steffen Jost 2022-09-05 15:24:56 +02:00
parent 475eb600bb
commit 58cc35d118

View File

@ -15,22 +15,30 @@ import Text.Pandoc.Arbitrary ()
-- Instance Arbitrary Meta is somewhat useless, as it always generates the same 3 keys.
newtype ArbitraryMeta = ArbitraryMeta { unArbitraryMeta :: Meta }
deriving newtype (Eq, Ord, Semigroup, Monoid, Show, Read)
deriving newtype (Eq, Ord, Semigroup, Monoid, Show, Read, Typable, Data, Generic)
newtype ArbitraryPandoc = ArbitraryPandoc { unArbitraryPandoc :: Pandoc }
deriving newtype (Eq, Ord, Show, Read, Typable, Data, Generic)
instance Arbitrary ArbitraryMeta where
arbitrary
= do (x1 :: Inlines) <- arbitrary
(x2 :: [Inlines]) <- filter (not . Fold.null) <$> arbitrary
(x3 :: Inlines) <- arbitrary
(x4 :: [(Text, Text)]) <- filter (not . T.null . fst) <$> arbitrary
(x5 :: [(Text, Bool)]) <- filter (not . T.null . fst) <$> arbitrary
return $ ArbitraryMeta
$ setMeta "title" x1
$ setMeta "author" x2
$ setMeta "date" x3
$ applyMetas (fmap (second Just) x4)
$ applyMetas (fmap (second Just) x5)
nullMeta
arbitrary = do
(x1 :: Inlines) <- arbitrary
(x2 :: [Inlines]) <- filter (not . Fold.null) <$> arbitrary
(x3 :: Inlines) <- arbitrary
(x4 :: [(Text, Text)]) <- filter (not . T.null . fst) <$> arbitrary
(x5 :: [(Text, Bool)]) <- filter (not . T.null . fst) <$> arbitrary
return $ ArbitraryMeta
$ setMeta "title" x1
$ setMeta "author" x2
$ setMeta "date" x3
$ applyMetas (fmap (second Just) x4)
$ applyMetas (fmap (second Just) x5)
nullMeta
instance Arbitrary ArbitraryPandoc where
arbitrary = do
meta <- arbitrary
ArbitraryPandoc . Pandoc (unArbitraryMeta meta) <$> arbitrary
-- For Lens Check _Meta required:
@ -47,49 +55,47 @@ spec = do
describe "applyMetas" $ do
it "should actually set values" $ do
(ml, abMetaOriginal, blocks) <- generate arbitrary
(metaList, apd) <- generate arbitrary
let
metaOriginal = unArbitraryMeta abMetaOriginal
pd = Pandoc metaOriginal blocks
mlKeys = Set.fromList $ fst <$> ml
(Pandoc newMeta _) = applyMetas (fmap (Just . MetaString) <$> ml) pd
ml' = [(k,t) | (k, MetaString t) <- mlist newMeta, Set.member k mlKeys]
ml `shouldMatchList` ml'
pd = unArbitraryPandoc apd
(Pandoc metaNew _) = applyMetas (second (Just . MetaString) <$> metaList) pd
mlKeys = Set.fromList $ fst <$> metaList
metaList' = [(k,t) | (k, MetaString t) <- mlist metaNew, Set.member k mlKeys]
metaList' `shouldMatchList` metaList
it "should preserve untouched settings" $ do
(ml, abMetaOriginal, blocks) <- generate arbitrary
(metaList, apd) <- generate arbitrary
let
metaOriginal = unArbitraryMeta abMetaOriginal
pd = Pandoc metaOriginal blocks
nullKeys = Set.fromList [k | (k, Nothing) <- ml]
(Pandoc newMeta _) = applyMetas (fmap (fmap MetaString) <$> ml) pd
oldm = [(k,t) | (k, t) <- mlist metaOriginal , Set.member k nullKeys]
newm = [(k,t) | (k, t) <- mlist newMeta , Set.member k nullKeys]
pd@(Pandoc metaOriginal _) = unArbitraryPandoc apd
changedKeys = Set.fromList [k | (k, Just _) <- metaList]
(Pandoc metaNew _) = applyMetas (second (fmap MetaString) <$> metaList) pd
oldm = [(k,t) | (k,t) <- mlist metaOriginal , Set.notMember k changedKeys]
newm = [(k,t) | (k,t) <- mlist metaNew , Set.notMember k changedKeys]
oldm `shouldMatchList` newm
describe "addMeta" $ do
it "should possibly overwrite existing settings" $ do
(abMetaOverwrite, abMetaOriginal, blocks) <- generate arbitrary
let
metaOverwrite = unArbitraryMeta abMetaOverwrite
metaOriginal = unArbitraryMeta abMetaOriginal
pd = Pandoc metaOriginal blocks
(abMetaOverwrite, apd) <- generate arbitrary
let
metaOverwrite = unArbitraryMeta abMetaOverwrite
pd@(Pandoc metaOriginal _) = unArbitraryPandoc apd
(Pandoc newMeta _) = addMeta metaOverwrite pd
(unMeta metaOverwrite `Map.isSubmapOf` unMeta newMeta) `shouldBe` True
it "should preserve untouched settings" $ do
(abMetaOverwrite, abMetaOriginal, blocks) <- generate arbitrary
(abMetaOverwrite, apd) <- generate arbitrary
let
metaOverwrite = unArbitraryMeta abMetaOverwrite
metaOriginal = unArbitraryMeta abMetaOriginal
pd = Pandoc metaOriginal blocks
pd@(Pandoc metaOriginal _) = unArbitraryPandoc apd
(Pandoc newMeta _) = addMeta metaOverwrite pd
((unMeta metaOriginal `Map.difference` unMeta metaOverwrite) `Map.isSubmapOf` unMeta newMeta) `shouldBe` True
it "should preserve document blocks" $ do
(metaOverwrite, pd) <- generate arbitrary
(abMetaOverwrite, apd) <- generate arbitrary
let
(Pandoc _ oldBlocks) = pd
(Pandoc _ newBlocks) = addMeta (unArbitraryMeta metaOverwrite) pd
metaOverwrite = unArbitraryMeta abMetaOverwrite
pd@(Pandoc _ oldBlocks) = unArbitraryPandoc apd
(Pandoc _ newBlocks) = addMeta metaOverwrite pd
newBlocks `shouldBe` oldBlocks
-- describe "_Meta" . it "is a lens" . property $ isLens _Meta