diff options
author | Florian Zschocke <f.zschocke+git@gmail.com> | 2021-12-04 15:15:50 +0100 |
---|---|---|
committer | Florian Zschocke <f.zschocke+git@gmail.com> | 2021-12-04 15:15:50 +0100 |
commit | b6eccdd716ae35f093797e0935a0021c13f5e73a (patch) | |
tree | 7052cd0e47abb11fb242da6aff920ed083b19a61 | |
parent | 373aa4b3251745d9bb402b9fdcf7f6778cc06d02 (diff) | |
parent | 1f0ddcebfc2edc89a929461f81143262a176a2ad (diff) | |
download | gitblit-b6eccdd716ae35f093797e0935a0021c13f5e73a.tar.gz gitblit-b6eccdd716ae35f093797e0935a0021c13f5e73a.zip |
Merge branch 'fix-864' into master
Merge fix for issue #864.
-rw-r--r-- | src/main/java/com/gitblit/wicket/MarkupProcessor.java | 5 | ||||
-rw-r--r-- | src/test/java/com/gitblit/wicket/MarkupProcessorTest.java | 734 |
2 files changed, 734 insertions, 5 deletions
diff --git a/src/main/java/com/gitblit/wicket/MarkupProcessor.java b/src/main/java/com/gitblit/wicket/MarkupProcessor.java index 300039bc..15e54332 100644 --- a/src/main/java/com/gitblit/wicket/MarkupProcessor.java +++ b/src/main/java/com/gitblit/wicket/MarkupProcessor.java @@ -391,11 +391,6 @@ public class MarkupProcessor { private String getWicketUrl(Class<? extends Page> pageClass, final String repositoryName, final String commitId, final String document) { String fsc = settings.getString(Keys.web.forwardSlashCharacter, "/"); String encodedPath = document.replace(' ', '-'); - try { - encodedPath = URLEncoder.encode(encodedPath, "UTF-8"); - } catch (UnsupportedEncodingException e) { - logger.error(null, e); - } encodedPath = encodedPath.replace("/", fsc).replace("%2F", fsc); String url = RequestCycle.get().urlFor(pageClass, WicketUtils.newPathParameter(repositoryName, commitId, encodedPath)).toString(); diff --git a/src/test/java/com/gitblit/wicket/MarkupProcessorTest.java b/src/test/java/com/gitblit/wicket/MarkupProcessorTest.java new file mode 100644 index 00000000..a57f1fdb --- /dev/null +++ b/src/test/java/com/gitblit/wicket/MarkupProcessorTest.java @@ -0,0 +1,734 @@ +package com.gitblit.wicket; + +import static org.junit.Assert.*; + +import java.io.IOException; +import java.util.Collections; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +import com.gitblit.manager.IManager; +import com.gitblit.manager.IPluginManager; +import com.gitblit.manager.IRuntimeManager; +import com.gitblit.models.PluginRegistry; +import com.gitblit.tests.mock.MockGitblitContext; +import com.gitblit.tests.mock.MockRuntimeManager; +import org.apache.wicket.util.tester.WicketTester; +import org.jsoup.Jsoup; +import org.jsoup.nodes.Document; +import org.junit.Before; +import org.junit.Test; + +import com.gitblit.Keys; +import com.gitblit.tests.mock.MemorySettings; +import com.gitblit.utils.JSoupXssFilter; +import com.gitblit.wicket.MarkupProcessor.MarkupDocument; +import ro.fortsoft.pf4j.PluginState; +import ro.fortsoft.pf4j.PluginWrapper; +import ro.fortsoft.pf4j.Version; + +public class MarkupProcessorTest +{ + private WicketTester tester; + private MockGitblitContext gbctx; + + @Before + public void setUp() + { + IRuntimeManager rm = new MockRuntimeManager(getSettings()); + gbctx = new MockGitblitContext(); + gbctx.addManager(rm); + tester = new WicketTester(new GitBlitWebApp(null, null, + rm, + getPluginManager(), + null, null, null, + null, null, null, + null, null, null)); + } + + + + /* + * The unit tests for MarkupProcessor have two major goals. + * One is to check that links are rendered correctly, and + * the second one is that XSS protection is working. + * + * The proper rendering of markup for the various Wiki/Markdown + * languages is not in focus. This, as a secondary goal, the Wiki/Md + * syntax rendering can be tested to make sure that when switching to + * a new or updated wiki syntax library nothing breaks and the pages + * are still rendered correctly. + * Or, to make sure things actually render correctly, because currently + * they don't as cen be seen with reference images and wiki links, + * for example. + */ + + + + @Test + public void testParseMdRepoRelativeLink() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a page](file.md)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/file.md", href); + } + + @Test + public void testParseMdRepoRelativeLinkSubfolder() + { + String psep ="%2F"; + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a file](folder/file.md)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/folder"+psep+"file.md", href); + } + + @Test + public void testParseMdRepoRelativeLinkSubSubfolder() + { + String psep ="%2F"; + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a file](sub/folder/file.md)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/sub"+psep+"folder"+psep+"file.md", href); + } + + @Test + public void testParseMdRepoRelativeLinkUtf8() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a page](日本語.md)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/%E6%97%A5%E6%9C%AC%E8%AA%9E.md", href); + } + + @Test + public void testParseMdRepoRelativeLinkSubfolderUtf8() + { + String psep ="%2F"; + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a file](folder/receitas_de_culinária/file.md)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/folder"+psep+"receitas_de_culin%C3%A1ria"+psep+"file.md", href); + } + + + @Test + public void testParseMdExternalLink() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a website](http://example.com/page.html)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","http://example.com/page.html", href); + } + + @Test + public void testParseMdExternalLinkBare() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: <http://example.com/page.html>"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","http://example.com/page.html", href); + } + + + // We leave it up to the document author to write working links in the document + @Test + public void testParseMdExternalLinkUtf8() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [Japanese](http://example.com/lang/日本語.html)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","http://example.com/lang/日本語.html", href); + } + + + + @Test + public void testParseMdRepoRelativeRefLink() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a page][1]\n\n[1]: file.md"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/file.md", href); + } + + @Test + public void testParseMdRepoRelativeRefLinkSubfolder() + { + String psep ="%2F"; + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a file][file]\n\n[file]: folder/file.md"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/folder"+psep+"file.md", href); + } + + @Test + public void testParseMdRepoRelativeRefLinkSubSubfolder() + { + String psep ="%2F"; + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a file][l1] \n\n[l1]: sub/folder/file.md"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/sub"+psep+"folder"+psep+"file.md", href); + } + + @Test + public void testParseMdRepoRelativeRefLinkUtf8() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a page][x]\n\n[x]: 日本語.md"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/%65%E5%67%2C%8A%Ee.md", href); + } + + @Test + public void testParseMdRepoRelativeRefLinkSubfolderUtf8() + { + String psep ="%2F"; + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a file][xy]\n\n[xy]: folder/receitas_de_culinária/file.md"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/folder"+psep+"receitas_de_culin%C3%A1ria"+psep+"file.md", href); + } + + + @Test + public void testParseMdExternalRefLink() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [a website][ex]\n\n[ex]: http://example.com/page.html"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","http://example.com/page.html", href); + } + + + + + + /* + * Apparently wiki style links currently do not work in Markdown. + + @Test + public void testParseMdWikiLink() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "link: [[page]]"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/testrepo/12345abcde/page", href); + } + */ + + + @Test + public void testParseMdRepoRelativeImage() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "image: ![a graphic](graphic.gif)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/graphic.gif", ref); + + markup = "image: ![a graphic](graphic.gif \"Some graphic\")"; + mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + doc = Jsoup.parseBodyFragment(mdoc.html); + ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/graphic.gif", ref); + } + + @Test + public void testParseMdRepoRelativeImageUtf8() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "image: ![look the dog](ドッグ.gif)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/%E3%83%89%E3%83%83%E3%82%B0.gif", ref); + + markup = "image: ![look the dog](ドッグ.gif \"シーバ\")"; + mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + doc = Jsoup.parseBodyFragment(mdoc.html); + ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/%E3%83%89%E3%83%83%E3%82%B0.gif", ref); + } + + @Test + public void testParseMdRepoRelativeImageSubfolder() + { + String psep ="!"; + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "image: ![a graphic](results/graphic.gif)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/results"+psep+"graphic.gif", ref); + + markup = "image: ![a graphic](results/graphic.gif \"Some graphic\")"; + mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + doc = Jsoup.parseBodyFragment(mdoc.html); + ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/results"+psep+"graphic.gif", ref); + } + + @Test + public void testParseMdRepoRelativeImageSubfolderUtf8() + { + String psep ="!"; + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "image: ![a cat](folder/картинки/cat.jpg)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/folder"+psep+"%D0%BA%D0%B0%D1%80%D1%82%D0%B8%D0%BD%D0%BA%D0%B8"+psep+"cat.jpg", ref); + + markup = "image: ![a cat](folder/картинки/cat.jpg \"Кошка\")"; + mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + doc = Jsoup.parseBodyFragment(mdoc.html); + ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/folder"+psep+"%D0%BA%D0%B0%D1%80%D1%82%D0%B8%D0%BD%D0%BA%D0%B8"+psep+"cat.jpg", ref); + } + + + @Test + public void testParseMdExternalImage() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "image: ![a cat](http://example.com/cats/meow.jpg)"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","http://example.com/cats/meow.jpg", ref); + + markup = "image: ![a cat](http://example.com/cats/meow.jpg \"Miau\")"; + mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + doc = Jsoup.parseBodyFragment(mdoc.html); + ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","http://example.com/cats/meow.jpg", ref); + } + + + + + + + @Test + public void testParseMdRepoRelativeRefImage() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "image: ![a graphic][1]\n\n[1]: graphic.gif"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/graphic.gif", ref); + + markup = "image: ![a graphic][2]\n\n[2]: graphic.gif \"Some graphic\""; + mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + doc = Jsoup.parseBodyFragment(mdoc.html); + ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/graphic.gif", ref); + } + + @Test + public void testParseMdRepoRelativeRefImageUtf8() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "image: ![look the dog][1]\n\n[1]: ドッグ.gif"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/%E3%83%89%E3%83%83%E3%82%B0.gif", ref); + + markup = "image: ![look the dog][1]\n\n[1]: ドッグ.gif \"シーバ\""; + mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + doc = Jsoup.parseBodyFragment(mdoc.html); + ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/%E3%83%89%E3%83%83%E3%82%B0.gif", ref); + } + + @Test + public void testParseMdRepoRelativeRefImageSubfolder() + { + String psep ="!"; + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "image: ![a cat][cat]\n\n[cat]: folder/cat.jpg"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/folder"+psep+"cat.jpg", ref); + + markup = "image: ![a cat][cat]\n\n[cat]: folder/cat.jpg \"Кошка\""; + mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + doc = Jsoup.parseBodyFragment(mdoc.html); + ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/folder"+psep+"cat.jpg", ref); + } + + @Test + public void testParseMdRepoRelativeRefImageSubfolderUtf8() + { + String psep ="!"; + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "image: ![a cat][i1]\n\n[i1]: folder/картинки/cat.jpg"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/folder"+psep+"%D0%BA%D0%B0%D1%80%D1%82%D0%B8%D0%BD%D0%BA%D0%B8"+psep+"cat.jpg", ref); + + markup = "image: ![a cat][i1]\n\n[i1]: folder/картинки/cat.jpg \"Кошка\""; + mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + doc = Jsoup.parseBodyFragment(mdoc.html); + ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","../raw/testrepo/12345abcde/folder"+psep+"%D0%BA%D0%B0%D1%80%D1%82%D0%B8%D0%BD%D0%BA%D0%B8"+psep+"cat.jpg", ref); + } + + + @Test + public void testParseMdExternalRefImage() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String markup = "image: ![a cat][1]\n\n[1]: http://example.com/cats/meow.jpg"; + MarkupDocument mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","http://example.com/cats/meow.jpg", ref); + + markup = "image: ![a cat][1]\n\n[1]: http://example.com/cats/meow.jpg \"Miau\""; + mdoc = mp.parse("testrepo", "12345abcde", "main.md", markup); + doc = Jsoup.parseBodyFragment(mdoc.html); + ref = doc.getElementsByAttribute("src").attr("src"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect image src rendered","http://example.com/cats/meow.jpg", ref); + } + + + + + + @Test + public void testParseMediaWikiRepoRelativeLink() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String psep = "%2F"; + String markup = "link: [[document]]"; + MarkupDocument mdoc = mp.parse("wikirepo", "12345abcde", "main.mw", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("href").attr("href"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect link href rendered","doc/wikirepo/12345abcde/wiki"+ psep + "document", ref); + + } + + @Test + public void testParseMediaWikiRepoRelativeLinkUtf8() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String psep = "%2F"; + String markup = "link: [[日本語]]"; + MarkupDocument mdoc = mp.parse("wikirepo", "12345abcde", "main.mw", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","doc/wikirepo/12345abcde/wiki" + psep + "%E6%97%A5%E6%9C%AC%E8%AA%9E", href); + } + + + @Test + public void testParseMediaWikiExternalLink() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String psep = "%2F"; + String markup = "link: [http://example.com/some/document.html document]"; + MarkupDocument mdoc = mp.parse("wikirepo", "12345abcde", "main.mw", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("href").attr("href"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect link href rendered","http://example.com/some/document.html", ref); + + } + + @Test + public void testParseMediaWikiExternalLinkNumbered() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String psep = "%2F"; + String markup = "link: [http://example.com/some/document.html]"; + MarkupDocument mdoc = mp.parse("wikirepo", "12345abcde", "main.mw", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("href").attr("href"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect link href rendered","http://example.com/some/document.html", ref); + + } + + @Test + public void testParseMediaWikiExternalLinkBare() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String psep = "%2F"; + String markup = "link: http://example.com/some/document.html"; + MarkupDocument mdoc = mp.parse("wikirepo", "12345abcde", "main.mw", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String ref = doc.getElementsByAttribute("href").attr("href"); + assertFalse("No reference attribute found: " + mdoc.html, ref.isEmpty()); + assertEquals("Incorrect link href rendered","http://example.com/some/document.html", ref); + + } + + // We leave it up to the document author to write working links in the document + @Test + public void testParseMediaWikiExternalLinkUtf8() + { + MarkupProcessor mp = new MarkupProcessor(getSettings(), new JSoupXssFilter()); + + String psep = "%2F"; + String markup = "link: [http://example.com/lang/日本語.html Japanese]"; + MarkupDocument mdoc = mp.parse("wikirepo", "12345abcde", "main.mw", markup); + Document doc = Jsoup.parseBodyFragment(mdoc.html); + String href = doc.getElementsByAttribute("href").attr("href"); + assertEquals("Incorrect link rendered","http://example.com/lang/日本語.html", href); + } + + + + + private MemorySettings getSettings() + { + Map<String, Object> backingMap = new HashMap<String, Object>(); + + backingMap.put(Keys.web.documents, "readme"); + backingMap.put(Keys.web.blobEncodings, "UTF-8 ISO-8859-1"); + backingMap.put(Keys.web.confluenceExtensions, "confluence"); + backingMap.put(Keys.web.markdownExtensions, "md mkd markdown MD MKD"); + backingMap.put(Keys.web.mediawikiExtensions, "mw mediawiki"); + backingMap.put(Keys.web.textileExtensions, "textile"); + backingMap.put(Keys.web.tracwikiExtensions, "tracwiki"); + backingMap.put(Keys.web.twikiExtensions, "twiki"); + backingMap.put(Keys.web.forwardSlashCharacter, "/"); + backingMap.put(Keys.web.mountParameters, true); + + MemorySettings ms = new MemorySettings(backingMap); + return ms; + } + + + private IPluginManager getPluginManager() + { + return new IPluginManager() + { + @Override + public Version getSystemVersion() + { + return null; + } + + @Override + public void startPlugins() + { + + } + + @Override + public void stopPlugins() + { + + } + + @Override + public PluginState startPlugin(String pluginId) + { + return null; + } + + @Override + public PluginState stopPlugin(String pluginId) + { + return null; + } + + @Override + public List<Class<?>> getExtensionClasses(String pluginId) + { + return null; + } + + @Override + public <T> List<T> getExtensions(Class<T> type) + { + return null; + } + + @Override + public List<PluginWrapper> getPlugins() + { + return Collections.emptyList(); + } + + @Override + public PluginWrapper getPlugin(String pluginId) + { + return null; + } + + @Override + public PluginWrapper whichPlugin(Class<?> clazz) + { + return null; + } + + @Override + public boolean disablePlugin(String pluginId) + { + return false; + } + + @Override + public boolean enablePlugin(String pluginId) + { + return false; + } + + @Override + public boolean uninstallPlugin(String pluginId) + { + return false; + } + + @Override + public boolean refreshRegistry(boolean verifyChecksum) + { + return false; + } + + @Override + public boolean installPlugin(String url, boolean verifyChecksum) throws IOException + { + return false; + } + + @Override + public boolean upgradePlugin(String pluginId, String url, boolean verifyChecksum) throws IOException + { + return false; + } + + @Override + public List<PluginRegistry.PluginRegistration> getRegisteredPlugins() + { + return null; + } + + @Override + public List<PluginRegistry.PluginRegistration> getRegisteredPlugins(PluginRegistry.InstallState state) + { + return null; + } + + @Override + public PluginRegistry.PluginRegistration lookupPlugin(String idOrName) + { + return null; + } + + @Override + public PluginRegistry.PluginRelease lookupRelease(String idOrName, String version) + { + return null; + } + + @Override + public IManager start() + { + return null; + } + + @Override + public IManager stop() + { + return null; + } + }; + } + +} |