+<?php
+
+namespace Tests\Entity;
+
+use BookStack\Entities\Tools\Markdown\HtmlToMarkdown;
+use Tests\TestCase;
+
+class MarkdownToHtmlTest extends TestCase
+{
+ public function test_basic_formatting_conversion()
+ {
+ $this->assertConversion(
+ '<h1>Dogcat</h1><p>Some <strong>bold</strong> text</p>',
+ "# Dogcat\n\nSome **bold** text"
+ );
+ }
+
+ public function test_callouts_remain_html()
+ {
+ $this->assertConversion(
+ '<h1>Dogcat</h1><p class="callout info">Some callout text</p><p>Another line</p>',
+ "# Dogcat\n\n<p class=\"callout info\">Some callout text</p>\n\nAnother line"
+ );
+ }
+
+ public function test_wysiwyg_code_format_handled_cleanly()
+ {
+ $this->assertConversion(
+ '<h1>Dogcat</h1>' . "\r\n" . '<pre id="bkmrk-var-a-%3D-%27cat%27%3B"><code class="language-JavaScript">var a = \'cat\';</code></pre><p>Another line</p>',
+ "# Dogcat\n\n```JavaScript\nvar a = 'cat';\n```\n\nAnother line"
+ );
+ }
+
+ public function test_tasklist_checkboxes_are_handled()
+ {
+ $this->assertConversion(
+ '<ul><li><input type="checkbox" checked="checked">Item A</li><li><input type="checkbox">Item B</li></ul>',
+ "- [x] Item A\n- [ ] Item B"
+ );
+ }
+
+ protected function assertConversion(string $html, string $expectedMarkdown, bool $partialMdMatch = false)
+ {
+ $markdown = (new HtmlToMarkdown($html))->convert();
+
+ if ($partialMdMatch) {
+ static::assertStringContainsString($expectedMarkdown, $markdown);
+ } else {
+ static::assertEquals($expectedMarkdown, $markdown);
+ }
+ }
+
+}