@Test
public void linksToPostAreParsedCorrectly() throws IOException {
- postProvider.addValidPostId("foo", "Post about foo...");
+ postProvider.addValidPostId("foo", "internal", "Post about foo...");
Iterable<Part> parts = soneTextParser.parse(null, new StringReader("This post://foo is awesome."));
- assertThat(convertText(parts, PlainTextPart.class, PostPart.class), is("This [post|foo|Post about foo...] is awesome."));
+ assertThat(convertText(parts, PlainTextPart.class, PostPart.class), is("This [post|new|foo|Post about foo...] is awesome."));
+ }
+
+ @Test
+ public void linksToPostsWithOldIdsAreParsedCorrectly() throws IOException {
+ postProvider.addValidPostId("foo", "internal", "Post about foo...");
+ Iterable<Part> parts = soneTextParser.parse(null, new StringReader("This post://internal is awesome."));
+ assertThat(convertText(parts, PlainTextPart.class, PostPart.class), is("This [post|old|foo|Post about foo...] is awesome."));
}
//
text.append("[Sone|").append(sonePart.getSone().getId()).append(']');
} else if (part instanceof PostPart) {
PostPart postPart = (PostPart) part;
- text.append("[post|").append(postPart.getPost().getId()).append('|').append(postPart.getPost().getText()).append(']');
+ text.append("[post|")
+ .append(postPart.usesDeprecatedLink() ? "old" : "new")
+ .append('|')
+ .append(postPart.getPost().getId())
+ .append('|')
+ .append(postPart.getPost().getText())
+ .append(']');
}
}
return text.toString();
private static class TestPostProvider implements PostProvider {
- private final Map<String, String> posts = new HashMap<String, String>();
+ private final Map<String, String> postTexts = new HashMap<String, String>();
+ private final Map<String, String> postInternalIds = new HashMap<String, String>();
+ private final Map<String, String> internalIdPosts = new HashMap<String, String>();
- private void addValidPostId(String validPostId, String text) {
- posts.put(validPostId, text);
+ private void addValidPostId(String validPostId, String internalId, String text) {
+ postTexts.put(validPostId, text);
+ postInternalIds.put(validPostId, internalId);
+ internalIdPosts.put(internalId, validPostId);
}
@Override
@Override
public Optional<Post> getPost(String postId) {
- if (posts.containsKey(postId)) {
+ if (postTexts.containsKey(postId)) {
Post post = mock(Post.class);
when(post.getId()).thenReturn(postId);
- when(post.getText()).thenReturn(posts.get(postId));
+ when(post.getInternalId()).thenReturn(postInternalIds.get(postId));
+ when(post.getText()).thenReturn(postTexts.get(postId));
+ return Optional.of(post);
+ } else if (internalIdPosts.containsKey(postId)) {
+ Post post = mock(Post.class);
+ when(post.getId()).thenReturn(internalIdPosts.get(postId));
+ when(post.getInternalId()).thenReturn(postId);
+ when(post.getText()).thenReturn(postTexts.get(internalIdPosts.get(postId)));
return Optional.of(post);
}
return Optional.absent();