2017-12-28 10:39:47 -05:00
|
|
|
module Tests.Writers.Powerpoint (tests) where
|
|
|
|
|
2018-01-25 15:27:54 -05:00
|
|
|
import Tests.Writers.OOXML (ooxmlTest)
|
2017-12-28 10:39:47 -05:00
|
|
|
import Text.Pandoc
|
|
|
|
import Test.Tasty
|
2018-02-19 20:04:39 -05:00
|
|
|
import System.FilePath
|
2019-10-08 09:22:46 -07:00
|
|
|
import Text.DocTemplates (ToContext(toVal), Context(..))
|
|
|
|
import qualified Data.Map as M
|
|
|
|
import Data.Text (pack)
|
2021-08-10 17:20:53 +01:00
|
|
|
import Data.List (unzip4)
|
2018-02-19 20:04:39 -05:00
|
|
|
|
|
|
|
-- templating is important enough, and can break enough things, that
|
|
|
|
-- we want to run all our tests with both default formatting and a
|
|
|
|
-- template.
|
|
|
|
|
2021-08-10 17:20:53 +01:00
|
|
|
modifyPptxName :: FilePath -> String -> FilePath
|
|
|
|
modifyPptxName fp suffix =
|
|
|
|
addExtension (dropExtension fp ++ suffix) "pptx"
|
2018-02-19 20:04:39 -05:00
|
|
|
|
2021-08-10 17:20:53 +01:00
|
|
|
pptxTests :: String -> WriterOptions -> FilePath -> FilePath -> (TestTree, TestTree, TestTree, TestTree)
|
2018-02-19 20:04:39 -05:00
|
|
|
pptxTests name opts native pptx =
|
|
|
|
let referenceDoc = "pptx/reference_depth.pptx"
|
2021-08-10 17:20:53 +01:00
|
|
|
movedLayoutsReferenceDoc = "pptx/reference_moved_layouts.pptx"
|
|
|
|
deletedLayoutsReferenceDoc = "pptx/reference_deleted_layouts.pptx"
|
2018-02-19 20:04:39 -05:00
|
|
|
in
|
|
|
|
( ooxmlTest
|
|
|
|
writePowerpoint
|
|
|
|
name
|
|
|
|
opts{writerReferenceDoc=Nothing}
|
|
|
|
native
|
|
|
|
pptx
|
|
|
|
, ooxmlTest
|
|
|
|
writePowerpoint
|
|
|
|
name
|
|
|
|
opts{writerReferenceDoc=Just referenceDoc}
|
|
|
|
native
|
2021-08-10 17:20:53 +01:00
|
|
|
(modifyPptxName pptx "_templated")
|
|
|
|
, ooxmlTest
|
|
|
|
writePowerpoint
|
|
|
|
name
|
|
|
|
opts{writerReferenceDoc=Just movedLayoutsReferenceDoc}
|
|
|
|
native
|
|
|
|
(modifyPptxName pptx "_moved_layouts")
|
|
|
|
, ooxmlTest
|
|
|
|
writePowerpoint
|
|
|
|
name
|
|
|
|
opts{writerReferenceDoc=Just deletedLayoutsReferenceDoc}
|
|
|
|
native
|
|
|
|
(modifyPptxName pptx "_deleted_layouts")
|
2018-02-19 20:04:39 -05:00
|
|
|
)
|
|
|
|
|
2021-08-10 17:20:53 +01:00
|
|
|
groupPptxTests :: [(TestTree, TestTree, TestTree, TestTree)] -> [TestTree]
|
2018-02-19 20:04:39 -05:00
|
|
|
groupPptxTests pairs =
|
2021-08-10 17:20:53 +01:00
|
|
|
let (noRefs, refs, movedLayouts, deletedLayouts) = unzip4 pairs
|
2018-02-19 20:04:39 -05:00
|
|
|
in
|
|
|
|
[ testGroup "Default slide formatting" noRefs
|
|
|
|
, testGroup "With `--reference-doc` pptx file" refs
|
2021-08-10 17:20:53 +01:00
|
|
|
, testGroup "With layouts in reference doc moved" movedLayouts
|
|
|
|
, testGroup "With layouts in reference doc deleted" deletedLayouts
|
2018-02-19 20:04:39 -05:00
|
|
|
]
|
2018-01-22 09:02:20 -05:00
|
|
|
|
2017-12-28 10:39:47 -05:00
|
|
|
|
|
|
|
tests :: [TestTree]
|
2018-02-19 20:04:39 -05:00
|
|
|
tests = groupPptxTests [ pptxTests "Inline formatting"
|
|
|
|
def
|
|
|
|
"pptx/inline_formatting.native"
|
|
|
|
"pptx/inline_formatting.pptx"
|
|
|
|
, pptxTests "Slide breaks (default slide-level)"
|
|
|
|
def
|
|
|
|
"pptx/slide_breaks.native"
|
|
|
|
"pptx/slide_breaks.pptx"
|
|
|
|
, pptxTests "slide breaks (slide-level set to 1)"
|
|
|
|
def{ writerSlideLevel = Just 1 }
|
|
|
|
"pptx/slide_breaks.native"
|
|
|
|
"pptx/slide_breaks_slide_level_1.pptx"
|
2018-02-27 09:34:24 -05:00
|
|
|
, pptxTests "lists"
|
|
|
|
def
|
|
|
|
"pptx/lists.native"
|
|
|
|
"pptx/lists.pptx"
|
2019-08-27 01:16:21 -04:00
|
|
|
, pptxTests "start ordered list at specified num"
|
|
|
|
def
|
|
|
|
"pptx/start_numbering_at.native"
|
|
|
|
"pptx/start_numbering_at.pptx"
|
2018-02-27 09:34:24 -05:00
|
|
|
, pptxTests "tables"
|
|
|
|
def
|
|
|
|
"pptx/tables.native"
|
|
|
|
"pptx/tables.pptx"
|
2018-02-19 20:04:39 -05:00
|
|
|
, pptxTests "table of contents"
|
|
|
|
def{ writerTableOfContents = True }
|
|
|
|
"pptx/slide_breaks.native"
|
|
|
|
"pptx/slide_breaks_toc.pptx"
|
|
|
|
, pptxTests "end notes"
|
|
|
|
def
|
|
|
|
"pptx/endnotes.native"
|
|
|
|
"pptx/endnotes.pptx"
|
|
|
|
, pptxTests "end notes, with table of contents"
|
|
|
|
def { writerTableOfContents = True }
|
|
|
|
"pptx/endnotes.native"
|
|
|
|
"pptx/endnotes_toc.pptx"
|
|
|
|
, pptxTests "images"
|
|
|
|
def
|
|
|
|
"pptx/images.native"
|
|
|
|
"pptx/images.pptx"
|
|
|
|
, pptxTests "two-column layout"
|
|
|
|
def
|
|
|
|
"pptx/two_column.native"
|
|
|
|
"pptx/two_column.pptx"
|
|
|
|
, pptxTests "speaker notes"
|
|
|
|
def
|
|
|
|
"pptx/speaker_notes.native"
|
|
|
|
"pptx/speaker_notes.pptx"
|
2018-03-21 10:05:05 -04:00
|
|
|
, pptxTests "speaker notes after a separating block"
|
|
|
|
def
|
|
|
|
"pptx/speaker_notes_afterseps.native"
|
|
|
|
"pptx/speaker_notes_afterseps.pptx"
|
2019-03-30 22:52:31 -04:00
|
|
|
, pptxTests "speaker notes after a separating header"
|
|
|
|
def
|
|
|
|
"pptx/speaker_notes_afterheader.native"
|
|
|
|
"pptx/speaker_notes_afterheader.pptx"
|
2019-03-31 17:05:45 -04:00
|
|
|
, pptxTests "speaker notes after metadata"
|
|
|
|
def
|
|
|
|
"pptx/speaker_notes_after_metadata.native"
|
|
|
|
"pptx/speaker_notes_after_metadata.pptx"
|
2018-02-27 09:09:45 -05:00
|
|
|
, pptxTests "remove empty slides"
|
|
|
|
def
|
|
|
|
"pptx/remove_empty_slides.native"
|
|
|
|
"pptx/remove_empty_slides.pptx"
|
2018-10-20 09:00:23 -04:00
|
|
|
, pptxTests "raw ooxml"
|
|
|
|
def
|
|
|
|
"pptx/raw_ooxml.native"
|
|
|
|
"pptx/raw_ooxml.pptx"
|
Improve writing metadata for docx, pptx and odt (#5252)
* docx writer: support custom properties. Solves the writer part of #3024.
Also supports additional core properties: `subject`, `lang`, `category`,
`description`.
* odt writer: improve standard properties, including the following core properties:
`generator` (Pandoc/VERSION), `description`, `subject`, `keywords`,
`initial-creator` (from authors), `creation-date` (actual creation date).
Also fix date.
* pptx writer: support custom properties. Also supports additional core
properties: `subject`, `category`, `description`.
* Includes golden tests.
* MANUAL: document metadata support for docx, odt, pptx writers
2019-01-26 16:14:35 -08:00
|
|
|
, pptxTests "metadata, custom properties"
|
|
|
|
def
|
|
|
|
"pptx/document-properties.native"
|
|
|
|
"pptx/document-properties.pptx"
|
|
|
|
, pptxTests "metadata, short description"
|
|
|
|
def
|
|
|
|
"pptx/document-properties-short-desc.native"
|
|
|
|
"pptx/document-properties-short-desc.pptx"
|
2019-06-14 17:42:06 +02:00
|
|
|
, pptxTests "inline code and code blocks"
|
|
|
|
def
|
|
|
|
"pptx/code.native"
|
|
|
|
"pptx/code.pptx"
|
|
|
|
, pptxTests "inline code and code blocks, custom formatting"
|
2019-10-08 09:22:46 -07:00
|
|
|
def { writerVariables = Context $ M.fromList
|
|
|
|
[(pack "monofont", toVal $ pack "Consolas")] }
|
2019-06-14 17:42:06 +02:00
|
|
|
"pptx/code.native"
|
|
|
|
"pptx/code-custom.pptx"
|
2018-02-19 20:04:39 -05:00
|
|
|
]
|