update( 'DocumentationViewer', 'link_base', 'dev/docs/' ); $this->entity = new DocumentationEntity('DocumentationParserTest'); $this->entity->setPath(DOCSVIEWER_PATH . '/tests/docs/en/'); $this->entity->setVersion('2.4'); $this->entity->setLanguage('en'); $this->entityAlt = new DocumentationEntity('DocumentationParserParserTest'); $this->entityAlt->setPath(DOCSVIEWER_PATH . '/tests/docs-parser/en/'); $this->entityAlt->setVersion('2.4'); $this->entityAlt->setLanguage('en'); $this->page = new DocumentationPage( $this->entity, 'test.md', DOCSVIEWER_PATH . '/tests/docs/en/test.md' ); $this->subPage = new DocumentationPage( $this->entity, 'subpage.md', DOCSVIEWER_PATH. '/tests/docs/en/subfolder/subpage.md' ); $this->subSubPage = new DocumentationPage( $this->entity, 'subsubpage.md', DOCSVIEWER_PATH. '/tests/docs/en/subfolder/subsubfolder/subsubpage.md' ); $this->filePage = new DocumentationPage( $this->entityAlt, 'file-download.md', DOCSVIEWER_PATH . '/tests/docs-parser/en/file-download.md' ); $this->metaDataPage = new DocumentationPage( $this->entityAlt, 'MetaDataTest.md', DOCSVIEWER_PATH . '/tests/docs-parser/en/MetaDataTest.md' ); $this->indexPage = new DocumentationPage( $this->entity, 'index.md', DOCSVIEWER_PATH. '/tests/docs/en/index.md' ); $manifest = new DocumentationManifest(true); } public function testRewriteCodeBlocks() { $codePage = new DocumentationPage( $this->entityAlt, 'CodeSnippets.md', DOCSVIEWER_PATH . '/tests/docs-parser/en/CodeSnippets.md' ); $result = DocumentationParser::rewrite_code_blocks( $codePage->getMarkdown() ); $expected = << ``` code block <% without formatting prefix %> ``` Paragraph with a segment of <% foo %> ``` code block that has a line in it ``` This is a yaml block ```yaml foo: bar baz: qux ``` This is a yaml block with tab in that new line ```yaml foo: bar baz: qux ``` HTML; $this->assertEquals($expected, $result, 'Code blocks support line breaks'); $result = DocumentationParser::rewrite_code_blocks( $this->page->getMarkdown() ); $expected = <<assertContains($expected, $result, 'Custom code blocks with ::: prefix'); $expected = <<assertContains($expected, $result, 'Traditional markdown code blocks'); $expected = <<assertContains($expected, $result, 'Backtick code blocks'); $expected = <<assertContains($expected, $result, 'Backtick with newlines'); } public function testRelativeLinks() { // index.md $result = DocumentationParser::rewrite_relative_links( $this->indexPage->getMarkdown(), $this->indexPage ); $this->assertContains( '[link: subfolder index](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/subfolder/)', $result ); // test.md $result = DocumentationParser::rewrite_relative_links( $this->page->getMarkdown(), $this->page ); $this->assertContains( '[link: subfolder index](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/subfolder/)', $result ); $this->assertContains( '[link: subfolder page](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/subfolder/subpage/)', $result ); $this->assertContains( '[link: http](http://silverstripe.org)', $result ); $this->assertContains( '[link: with anchor](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/test/#anchor)', $result ); $this->assertContains( '[link: relative anchor](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/test/#relative-anchor)', $result ); $result = DocumentationParser::rewrite_relative_links( $this->subPage->getMarkdown(), $this->subPage ); // @todo this should redirect to /subpage/ $this->assertContains( '[link: relative](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/subfolder/subpage.md/)', $result ); $this->assertContains( '[link: absolute index](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/)', $result ); // @todo this should redirect to / $this->assertContains( '[link: absolute index with name](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/index/)', $result ); $this->assertContains( '[link: relative index](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/)', $result ); $this->assertContains( '[link: relative parent page](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/test/)', $result ); $this->assertContains( '[link: absolute parent page](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/test/)', $result ); $result = DocumentationParser::rewrite_relative_links( $this->subSubPage->getMarkdown(), $this->subSubPage ); $this->assertContains( '[link: absolute index](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/)', $result ); $this->assertContains( '[link: relative index](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/subfolder/)', $result ); $this->assertContains( '[link: relative parent page](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/subfolder/subpage/)', $result ); $this->assertContains( '[link: relative grandparent page](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/test/)', $result ); $this->assertContains( '[link: absolute page](' . Director::baseURL() . 'dev/docs/en/documentationparsertest/2.4/test/)', $result ); } public function testGenerateHtmlId() { $this->assertEquals('title-one', DocumentationParser::generate_html_id('title one')); $this->assertEquals('title-one', DocumentationParser::generate_html_id('Title one')); $this->assertEquals('title-and-one', DocumentationParser::generate_html_id('Title & One')); $this->assertEquals('title-and-one', DocumentationParser::generate_html_id('Title & One')); $this->assertEquals('title-one', DocumentationParser::generate_html_id(' Title one ')); $this->assertEquals('title-one', DocumentationParser::generate_html_id('Title--one')); } public function testImageRewrites() { $result = DocumentationParser::rewrite_image_links( $this->subPage->getMarkdown(), $this->subPage ); $expected = Controller::join_links( Director::absoluteBaseURL(), DOCSVIEWER_DIR, '/tests/docs/en/subfolder/_images/image.png' ); $this->assertContains( sprintf('[relative image link](%s)', $expected), $result ); $this->assertContains( sprintf( '[parent image link](%s)', Controller::join_links( Director::absoluteBaseURL(), DOCSVIEWER_DIR, '/tests/docs/en/_images/image.png' ) ), $result ); $expected = Controller::join_links( Director::absoluteBaseURL(), DOCSVIEWER_DIR, '/tests/docs/en/_images/image.png' ); $this->assertContains( sprintf('[absolute image link](%s)', $expected), $result ); } public function testApiLinks() { // $this->page is test.md, the documentation page being parsed by rewrite_api_links $parsed_page = DocumentationParser::rewrite_api_links($this->page->getMarkdown(), $this->page); // version of documentation page $page_version = $this->page->getVersion(); // expected url format resulting from rewriting api shortcode links $html_format = '%s'; // test cases: non-backtick enclosed api links and the expected html resulting from rewriting them // note that api links enclosed in backticks are left unchanged $test_cases = array( array('`[api:DataObject]`','`[api:DataObject]`'), array('`[api:DataObject::$defaults]`','`[api:DataObject::$defaults]`'), array('`[api:DataObject::populateDefaults()]`','`[api:DataObject::populateDefaults()]`'), array('`[Title](api:DataObject)`','`[Title](api:DataObject)`'), array('`[Title](api:DataObject::$defaults)`','`[Title](api:DataObject::$defaults)`'), array('`[Title](api:DataObject::populateDefaults())`','`[Title](api:DataObject::populateDefaults())`'), array('[api:DataObject]', sprintf($html_format, 'DataObject', 'DataObject')), array('[api:DataObject::$defaults]',sprintf($html_format, 'DataObject::$defaults', 'DataObject::$defaults')), array('[api:DataObject::populateDefaults()]',sprintf($html_format, 'DataObject::populateDefaults()', 'DataObject::populateDefaults()')), array('[Title](api:DataObject)',sprintf($html_format, 'DataObject', 'Title')), array('[Title](api:DataObject::$defaults)',sprintf($html_format, 'DataObject::$defaults', 'Title')), array('[Title](api:DataObject::populateDefaults())',sprintf($html_format, 'DataObject::populateDefaults()', 'Title')) ); foreach ($test_cases as $test_case) { $expected_html = $test_case[1]; $this->assertContains($expected_html, $parsed_page); } } public function testHeadlineAnchors() { $result = DocumentationParser::rewrite_heading_anchors( $this->page->getMarkdown(), $this->page ); /* # Heading one {#Heading-one} # Heading with custom anchor {#custom-anchor} {#Heading-with-custom-anchor-custom-anchor} ## Heading two {#Heading-two} ### Heading three {#Heading-three} ## Heading duplicate {#Heading-duplicate} ## Heading duplicate {#Heading-duplicate-2} ## Heading duplicate {#Heading-duplicate-3} */ $this->assertContains('# Heading one {#heading-one}', $result); $this->assertContains('# Heading with custom anchor {#custom-anchor}', $result); $this->assertNotContains('# Heading with custom anchor {#custom-anchor} {#heading', $result); $this->assertContains('# Heading two {#heading-two}', $result); $this->assertContains('# Heading three {#heading-three}', $result); $this->assertContains('## Heading duplicate {#heading-duplicate}', $result); $this->assertContains('## Heading duplicate {#heading-duplicate-2}', $result); $this->assertContains('## Heading duplicate {#heading-duplicate-3}', $result); } public function testRetrieveMetaData() { $this->metaDataPage->getMarkdown(true); $this->assertEquals('Foo Bar\'s Test page.', $this->metaDataPage->getTitle()); $this->assertEquals('A long intro that splits over many lines', $this->metaDataPage->getIntroduction()); $this->assertEquals('Foo Bar Test page description', $this->metaDataPage->getSummary()); $parsed = DocumentationParser::parse($this->metaDataPage); $expected = <<Content HTML; $this->assertEquals($parsed, $expected, 'Metadata block removed, parsed correctly'); } public function testRetrieveMetaDataYamlBlock() { $page = new DocumentationPage( $this->entityAlt, 'MetaDataYamlBlockTest.md', DOCSVIEWER_PATH . '/tests/docs-parser/en/MetaDataYamlBlockTest.md' ); $page->getMarkdown(true); $this->assertEquals('Foo Bar\'s Test page.', $page->getTitle()); $this->assertEquals('This is the page\'s description', $page->getSummary()); $parsed = DocumentationParser::parse($page); $expected = <<Content

Content goes here.


randomblock: ignored

HTML; $this->assertEquals($parsed, $expected, 'YAML metadata block removed, parsed correctly'); } public function testRewritingRelativeLinksToFiles() { $parsed = DocumentationParser::parse($this->filePage); $this->assertContains( DOCSVIEWER_DIR .'/tests/docs-parser/en/_images/external_link.png', $parsed ); $this->assertContains( DOCSVIEWER_DIR .'/tests/docs-parser/en/_images/test.tar.gz', $parsed ); } }