2017-12-28 16:39:47 +01:00
|
|
|
module Tests.Writers.Powerpoint (tests) where
|
|
|
|
|
2018-01-25 21:27:54 +01:00
|
|
|
import Tests.Writers.OOXML (ooxmlTest)
|
2017-12-28 16:39:47 +01:00
|
|
|
import Text.Pandoc
|
|
|
|
import Test.Tasty
|
2018-02-20 02:04:39 +01:00
|
|
|
import System.FilePath
|
2019-10-08 18:22:46 +02:00
|
|
|
import Text.DocTemplates (ToContext(toVal), Context(..))
|
|
|
|
import qualified Data.Map as M
|
|
|
|
import Data.Text (pack)
|
2021-08-10 18:20:53 +02:00
|
|
|
import Data.List (unzip4)
|
2018-02-20 02:04:39 +01: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 18:20:53 +02:00
|
|
|
modifyPptxName :: FilePath -> String -> FilePath
|
|
|
|
modifyPptxName fp suffix =
|
2021-08-25 15:35:19 +02:00
|
|
|
addExtension (takeDirectory fp ++ suffix) "pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
|
2021-08-10 18:20:53 +02:00
|
|
|
pptxTests :: String -> WriterOptions -> FilePath -> FilePath -> (TestTree, TestTree, TestTree, TestTree)
|
2018-02-20 02:04:39 +01:00
|
|
|
pptxTests name opts native pptx =
|
2021-08-25 15:35:19 +02:00
|
|
|
let referenceDoc = "pptx/reference-depth.pptx"
|
|
|
|
movedLayoutsReferenceDoc = "pptx/reference-moved-layouts.pptx"
|
|
|
|
deletedLayoutsReferenceDoc = "pptx/reference-deleted-layouts.pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
in
|
|
|
|
( ooxmlTest
|
|
|
|
writePowerpoint
|
|
|
|
name
|
|
|
|
opts{writerReferenceDoc=Nothing}
|
|
|
|
native
|
|
|
|
pptx
|
|
|
|
, ooxmlTest
|
|
|
|
writePowerpoint
|
|
|
|
name
|
|
|
|
opts{writerReferenceDoc=Just referenceDoc}
|
|
|
|
native
|
2021-08-25 15:35:19 +02:00
|
|
|
(modifyPptxName pptx "/templated")
|
2021-08-10 18:20:53 +02:00
|
|
|
, ooxmlTest
|
|
|
|
writePowerpoint
|
|
|
|
name
|
|
|
|
opts{writerReferenceDoc=Just movedLayoutsReferenceDoc}
|
|
|
|
native
|
2021-08-25 15:35:19 +02:00
|
|
|
(modifyPptxName pptx "/moved-layouts")
|
2021-08-10 18:20:53 +02:00
|
|
|
, ooxmlTest
|
|
|
|
writePowerpoint
|
|
|
|
name
|
|
|
|
opts{writerReferenceDoc=Just deletedLayoutsReferenceDoc}
|
|
|
|
native
|
2021-08-25 15:35:19 +02:00
|
|
|
(modifyPptxName pptx "/deleted-layouts")
|
2018-02-20 02:04:39 +01:00
|
|
|
)
|
|
|
|
|
2021-08-10 18:20:53 +02:00
|
|
|
groupPptxTests :: [(TestTree, TestTree, TestTree, TestTree)] -> [TestTree]
|
2018-02-20 02:04:39 +01:00
|
|
|
groupPptxTests pairs =
|
2021-08-10 18:20:53 +02:00
|
|
|
let (noRefs, refs, movedLayouts, deletedLayouts) = unzip4 pairs
|
2018-02-20 02:04:39 +01:00
|
|
|
in
|
|
|
|
[ testGroup "Default slide formatting" noRefs
|
|
|
|
, testGroup "With `--reference-doc` pptx file" refs
|
2021-08-10 18:20:53 +02:00
|
|
|
, testGroup "With layouts in reference doc moved" movedLayouts
|
|
|
|
, testGroup "With layouts in reference doc deleted" deletedLayouts
|
2018-02-20 02:04:39 +01:00
|
|
|
]
|
2018-01-22 15:02:20 +01:00
|
|
|
|
2017-12-28 16:39:47 +01:00
|
|
|
|
|
|
|
tests :: [TestTree]
|
2018-02-20 02:04:39 +01:00
|
|
|
tests = groupPptxTests [ pptxTests "Inline formatting"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/inline-formatting/input.native"
|
|
|
|
"pptx/inline-formatting/output.pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
, pptxTests "Slide breaks (default slide-level)"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/slide-breaks/input.native"
|
|
|
|
"pptx/slide-breaks/output.pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
, pptxTests "slide breaks (slide-level set to 1)"
|
|
|
|
def{ writerSlideLevel = Just 1 }
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/slide-breaks/input.native"
|
|
|
|
"pptx/slide-breaks-slide-level-1/output.pptx"
|
2018-02-27 15:34:24 +01:00
|
|
|
, pptxTests "lists"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/lists/input.native"
|
|
|
|
"pptx/lists/output.pptx"
|
2019-08-27 07:16:21 +02:00
|
|
|
, pptxTests "start ordered list at specified num"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/start-numbering-at/input.native"
|
|
|
|
"pptx/start-numbering-at/output.pptx"
|
2018-02-27 15:34:24 +01:00
|
|
|
, pptxTests "tables"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/tables/input.native"
|
|
|
|
"pptx/tables/output.pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
, pptxTests "table of contents"
|
|
|
|
def{ writerTableOfContents = True }
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/slide-breaks/input.native"
|
|
|
|
"pptx/slide-breaks-toc/output.pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
, pptxTests "end notes"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/endnotes/input.native"
|
|
|
|
"pptx/endnotes/output.pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
, pptxTests "end notes, with table of contents"
|
|
|
|
def { writerTableOfContents = True }
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/endnotes/input.native"
|
|
|
|
"pptx/endnotes-toc/output.pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
, pptxTests "images"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/images/input.native"
|
|
|
|
"pptx/images/output.pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
, pptxTests "two-column layout"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/two-column/input.native"
|
|
|
|
"pptx/two-column/output.pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
, pptxTests "speaker notes"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/speaker-notes/input.native"
|
|
|
|
"pptx/speaker-notes/output.pptx"
|
2018-03-21 15:05:05 +01:00
|
|
|
, pptxTests "speaker notes after a separating block"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/speaker-notes-afterseps/input.native"
|
|
|
|
"pptx/speaker-notes-afterseps/output.pptx"
|
2019-03-31 04:52:31 +02:00
|
|
|
, pptxTests "speaker notes after a separating header"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/speaker-notes-afterheader/input.native"
|
|
|
|
"pptx/speaker-notes-afterheader/output.pptx"
|
2019-03-31 23:05:45 +02:00
|
|
|
, pptxTests "speaker notes after metadata"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/speaker-notes-after-metadata/input.native"
|
|
|
|
"pptx/speaker-notes-after-metadata/output.pptx"
|
2018-02-27 15:09:45 +01:00
|
|
|
, pptxTests "remove empty slides"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/remove-empty-slides/input.native"
|
|
|
|
"pptx/remove-empty-slides/output.pptx"
|
2018-10-20 15:00:23 +02:00
|
|
|
, pptxTests "raw ooxml"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/raw-ooxml/input.native"
|
|
|
|
"pptx/raw-ooxml/output.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-27 01:14:35 +01:00
|
|
|
, pptxTests "metadata, custom properties"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/document-properties/input.native"
|
|
|
|
"pptx/document-properties/output.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-27 01:14:35 +01:00
|
|
|
, pptxTests "metadata, short description"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/document-properties-short-desc/input.native"
|
|
|
|
"pptx/document-properties-short-desc/output.pptx"
|
2019-06-14 17:42:06 +02:00
|
|
|
, pptxTests "inline code and code blocks"
|
|
|
|
def
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/code/input.native"
|
|
|
|
"pptx/code/output.pptx"
|
2019-06-14 17:42:06 +02:00
|
|
|
, pptxTests "inline code and code blocks, custom formatting"
|
2019-10-08 18:22:46 +02:00
|
|
|
def { writerVariables = Context $ M.fromList
|
|
|
|
[(pack "monofont", toVal $ pack "Consolas")] }
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/code/input.native"
|
|
|
|
"pptx/code-custom/output.pptx"
|
2021-08-20 15:40:09 +02:00
|
|
|
, pptxTests ("Using slide level 0, if the first thing on "
|
|
|
|
<> "a slide is a h1 it's used as the "
|
|
|
|
<> "slide title")
|
|
|
|
def { writerSlideLevel = Just 0 }
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/slide-level-0/h1-with-image/input.native"
|
|
|
|
"pptx/slide-level-0/h1-with-image/output.pptx"
|
2021-08-20 15:40:09 +02:00
|
|
|
, pptxTests ("Using slide level 0, if the first thing on "
|
|
|
|
<> "a slide is a h2 it's used as the "
|
|
|
|
<> "slide title")
|
|
|
|
def { writerSlideLevel = Just 0 }
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/slide-level-0/h2-with-image/input.native"
|
|
|
|
"pptx/slide-level-0/h2-with-image/output.pptx"
|
2021-08-20 15:40:09 +02:00
|
|
|
, pptxTests ("Using slide level 0, if the first thing on "
|
|
|
|
<> "a slide is a heading it's used as the "
|
|
|
|
<> "slide title (works with a table)")
|
|
|
|
def { writerSlideLevel = Just 0 }
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/slide-level-0/h1-with-table/input.native"
|
|
|
|
"pptx/slide-level-0/h1-with-table/output.pptx"
|
2021-08-20 15:40:09 +02:00
|
|
|
, pptxTests ("Using slide level 0, if the first thing on "
|
|
|
|
<> "a slide is a heading it's used as the "
|
pptx: Add support for more layouts
Until now, the pptx writer only supported four slide layouts: “Title
Slide” (used for the automatically generated metadata slide), “Section
Header” (used for headings above the slide level), “Two Column” (used
when there’s a columns div containing at least two column divs), and
“Title and Content” (used for all other slides).
This commit adds support for three more layouts: Comparison, Content
with Caption, and Blank.
- Support “Comparison” slide layout
This layout is used when a slide contains at least two columns, at
least one of which contains some text followed by some non-text (e.g.
an image or table). The text in each column is inserted into the
“body” placeholder for that column, and the non-text is inserted into
the ObjType placeholder. Any extra content after the non-text is
overlaid on top of the preceding content, rather than dropping it
completely (as currently happens for the two-column layout).
+ Accept straightforward test changes
Adding the new layout means the “-deleted-layouts” tests have an
additional layout added to the master and master rels.
+ Add new tests for the comparison layout
+ Add new tests to pandoc.cabal
- Support “Content with Caption” slide layout
This layout is used when a slide’s body contains some text, followed by
non-text (e.g. and image or a table). Before now, in this case the image
or table would break onto a new slide: to get that output again, users
can add a horizontal rule before the image or table.
+ Accept straightforward tests
The “-deleted-layouts” tests all have an extra layout and relationship
in the master for the Content with Caption layout.
+ Accept remove-empty-slides test
Empty slides are still removed, but the Content with Caption layout is
now used.
+ Change slide-level-0/h1-h2-with-text description
This test now triggers the content with caption layout, giving a
different (but still correct) result.
+ Add new tests for the new layout
+ Add new tests to the cabal file
- Support “Blank” slide layout
This layout is used when a slide contains only blank content (e.g.
non-breaking spaces). No content is inserted into any placeholders in
the layout.
Fixes #5097.
+ Accept straightforward test changes
Blank layout now copied over from reference doc as well, when
layouts have been deleted.
+ Add some new tests
A slide should use the blank layout if:
- It contains only speaker notes
- It contains only an empty heading with a body of nbsps
- It contains only a heading containing only nbsps
- Change ContentType -> Placeholder
This type was starting to have a constructor for each placeholder on
each slide (e.g. `ComparisonUpperLeftContent`). I’ve changed it
instead to identify a placeholder by type and index, as I think that’s
clearer and less redundant.
- Describe layout-choosing logic in manual
2021-08-19 16:53:21 +02:00
|
|
|
<> "slide title (content with caption layout)")
|
2021-08-20 15:40:09 +02:00
|
|
|
def { writerSlideLevel = Just 0 }
|
2021-08-25 15:35:19 +02:00
|
|
|
"pptx/slide-level-0/h1-h2-with-table/input.native"
|
|
|
|
"pptx/slide-level-0/h1-h2-with-table/output.pptx"
|
pptx: Add support for more layouts
Until now, the pptx writer only supported four slide layouts: “Title
Slide” (used for the automatically generated metadata slide), “Section
Header” (used for headings above the slide level), “Two Column” (used
when there’s a columns div containing at least two column divs), and
“Title and Content” (used for all other slides).
This commit adds support for three more layouts: Comparison, Content
with Caption, and Blank.
- Support “Comparison” slide layout
This layout is used when a slide contains at least two columns, at
least one of which contains some text followed by some non-text (e.g.
an image or table). The text in each column is inserted into the
“body” placeholder for that column, and the non-text is inserted into
the ObjType placeholder. Any extra content after the non-text is
overlaid on top of the preceding content, rather than dropping it
completely (as currently happens for the two-column layout).
+ Accept straightforward test changes
Adding the new layout means the “-deleted-layouts” tests have an
additional layout added to the master and master rels.
+ Add new tests for the comparison layout
+ Add new tests to pandoc.cabal
- Support “Content with Caption” slide layout
This layout is used when a slide’s body contains some text, followed by
non-text (e.g. and image or a table). Before now, in this case the image
or table would break onto a new slide: to get that output again, users
can add a horizontal rule before the image or table.
+ Accept straightforward tests
The “-deleted-layouts” tests all have an extra layout and relationship
in the master for the Content with Caption layout.
+ Accept remove-empty-slides test
Empty slides are still removed, but the Content with Caption layout is
now used.
+ Change slide-level-0/h1-h2-with-text description
This test now triggers the content with caption layout, giving a
different (but still correct) result.
+ Add new tests for the new layout
+ Add new tests to the cabal file
- Support “Blank” slide layout
This layout is used when a slide contains only blank content (e.g.
non-breaking spaces). No content is inserted into any placeholders in
the layout.
Fixes #5097.
+ Accept straightforward test changes
Blank layout now copied over from reference doc as well, when
layouts have been deleted.
+ Add some new tests
A slide should use the blank layout if:
- It contains only speaker notes
- It contains only an empty heading with a body of nbsps
- It contains only a heading containing only nbsps
- Change ContentType -> Placeholder
This type was starting to have a constructor for each placeholder on
each slide (e.g. `ComparisonUpperLeftContent`). I’ve changed it
instead to identify a placeholder by type and index, as I think that’s
clearer and less redundant.
- Describe layout-choosing logic in manual
2021-08-19 16:53:21 +02:00
|
|
|
, pptxTests ("comparison layout used when two columns "
|
|
|
|
<> "contain text plus non-text")
|
|
|
|
def
|
|
|
|
"pptx/comparison/both-columns/input.native"
|
|
|
|
"pptx/comparison/both-columns/output.pptx"
|
|
|
|
, pptxTests ("comparison layout used even when only one "
|
|
|
|
<> "column contains text plus non-text")
|
|
|
|
def
|
|
|
|
"pptx/comparison/one-column/input.native"
|
|
|
|
"pptx/comparison/one-column/output.pptx"
|
|
|
|
, pptxTests ("extra text in one column in comparison "
|
|
|
|
<> "layout gets overlaid")
|
|
|
|
def
|
|
|
|
"pptx/comparison/extra-text/input.native"
|
|
|
|
"pptx/comparison/extra-text/output.pptx"
|
|
|
|
, pptxTests ("extra image in one column in comparison "
|
|
|
|
<> "layout gets overlaid")
|
|
|
|
def
|
|
|
|
"pptx/comparison/extra-image/input.native"
|
|
|
|
"pptx/comparison/extra-image/output.pptx"
|
|
|
|
, pptxTests "comparison not used if the non-text comes first"
|
|
|
|
def
|
|
|
|
"pptx/comparison/non-text-first/input.native"
|
|
|
|
"pptx/comparison/non-text-first/output.pptx"
|
|
|
|
, pptxTests ("Heading, text and an image on the same "
|
|
|
|
<> "slide uses the Content with Caption "
|
|
|
|
<> "layout")
|
|
|
|
def
|
|
|
|
"pptx/content-with-caption/heading-text-image/input.native"
|
|
|
|
"pptx/content-with-caption/heading-text-image/output.pptx"
|
|
|
|
, pptxTests ("Text and an image on the same "
|
|
|
|
<> "slide uses the Content with Caption "
|
|
|
|
<> "layout")
|
|
|
|
def
|
|
|
|
"pptx/content-with-caption/text-image/input.native"
|
|
|
|
"pptx/content-with-caption/text-image/output.pptx"
|
|
|
|
, pptxTests ("If the image comes first, Content with "
|
|
|
|
<> "Caption is not used")
|
|
|
|
def
|
|
|
|
"pptx/content-with-caption/image-text/input.native"
|
|
|
|
"pptx/content-with-caption/image-text/output.pptx"
|
|
|
|
, pptxTests ("If a slide contains only speaker notes, the "
|
|
|
|
<> "Blank layout is used")
|
|
|
|
def
|
|
|
|
"pptx/blanks/just-speaker-notes/input.native"
|
|
|
|
"pptx/blanks/just-speaker-notes/output.pptx"
|
|
|
|
, pptxTests ("If a slide contains only an empty heading "
|
|
|
|
<> "with a body of only non-breaking spaces"
|
|
|
|
<> ", the Blank layout is used")
|
|
|
|
def
|
|
|
|
"pptx/blanks/nbsp-in-body/input.native"
|
|
|
|
"pptx/blanks/nbsp-in-body/output.pptx"
|
|
|
|
, pptxTests ("If a slide contains only a heading "
|
|
|
|
<> "containing only non-breaking spaces, "
|
|
|
|
<> "the Blank layout is used")
|
|
|
|
def
|
|
|
|
"pptx/blanks/nbsp-in-heading/input.native"
|
|
|
|
"pptx/blanks/nbsp-in-heading/output.pptx"
|
2018-02-20 02:04:39 +01:00
|
|
|
]
|