Fix test compilation
This commit is contained in:
		
							parent
							
								
									5bf21bc940
								
							
						
					
					
						commit
						64af306e53
					
				| @ -5,27 +5,12 @@ import org.junit.runner.RunWith; | |||||||
| import org.robolectric.RobolectricTestRunner; | import org.robolectric.RobolectricTestRunner; | ||||||
| import org.robolectric.annotation.Config; | import org.robolectric.annotation.Config; | ||||||
| 
 | 
 | ||||||
| import java.util.List; |  | ||||||
| 
 |  | ||||||
| import ru.noties.markwon.core.CorePlugin; |  | ||||||
| 
 |  | ||||||
| import static org.junit.Assert.assertEquals; | import static org.junit.Assert.assertEquals; | ||||||
| 
 | 
 | ||||||
| @RunWith(RobolectricTestRunner.class) | @RunWith(RobolectricTestRunner.class) | ||||||
| @Config(manifest = Config.NONE) | @Config(manifest = Config.NONE) | ||||||
| public class AbstractMarkwonPluginTest { | public class AbstractMarkwonPluginTest { | ||||||
|      |      | ||||||
|     @Test |  | ||||||
|     public void priority() { |  | ||||||
|         // returns CorePlugin dependency |  | ||||||
| 
 |  | ||||||
|         final Priority priority = new AbstractMarkwonPlugin() { |  | ||||||
|         }.priority(); |  | ||||||
|         final List<Class<? extends MarkwonPlugin>> after = priority.after(); |  | ||||||
|         assertEquals(1, after.size()); |  | ||||||
|         assertEquals(CorePlugin.class, after.get(0)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |     @Test | ||||||
|     public void process_markdown() { |     public void process_markdown() { | ||||||
|         // returns supplied argument (no-op) |         // returns supplied argument (no-op) | ||||||
|  | |||||||
| @ -1,6 +1,5 @@ | |||||||
| package ru.noties.markwon; | package ru.noties.markwon; | ||||||
| 
 | 
 | ||||||
| import android.support.annotation.NonNull; |  | ||||||
| import android.text.Spanned; | import android.text.Spanned; | ||||||
| import android.widget.TextView; | import android.widget.TextView; | ||||||
| 
 | 
 | ||||||
| @ -8,183 +7,57 @@ import org.commonmark.node.Node; | |||||||
| import org.commonmark.parser.Parser; | import org.commonmark.parser.Parser; | ||||||
| import org.junit.Test; | import org.junit.Test; | ||||||
| import org.junit.runner.RunWith; | import org.junit.runner.RunWith; | ||||||
| import org.mockito.ArgumentMatchers; |  | ||||||
| import org.mockito.invocation.InvocationOnMock; |  | ||||||
| import org.mockito.stubbing.Answer; |  | ||||||
| import org.robolectric.RobolectricTestRunner; | import org.robolectric.RobolectricTestRunner; | ||||||
| import org.robolectric.RuntimeEnvironment; | import org.robolectric.RuntimeEnvironment; | ||||||
| import org.robolectric.annotation.Config; | import org.robolectric.annotation.Config; | ||||||
| 
 | 
 | ||||||
| import java.util.Arrays; |  | ||||||
| import java.util.Collections; |  | ||||||
| import java.util.List; |  | ||||||
| 
 |  | ||||||
| import ru.noties.markwon.core.CorePlugin; |  | ||||||
| import ru.noties.markwon.core.MarkwonTheme; | import ru.noties.markwon.core.MarkwonTheme; | ||||||
| import ru.noties.markwon.html.MarkwonHtmlRenderer; | import ru.noties.markwon.html.MarkwonHtmlRenderer; | ||||||
| import ru.noties.markwon.image.AsyncDrawableLoader; |  | ||||||
| 
 | 
 | ||||||
| import static org.hamcrest.Matchers.containsString; | import static org.hamcrest.Matchers.containsString; | ||||||
| import static org.hamcrest.Matchers.hasItem; |  | ||||||
| import static org.hamcrest.Matchers.hasSize; |  | ||||||
| import static org.hamcrest.Matchers.isA; |  | ||||||
| import static org.hamcrest.Matchers.not; |  | ||||||
| import static org.junit.Assert.assertThat; | import static org.junit.Assert.assertThat; | ||||||
| import static org.junit.Assert.fail; | import static org.junit.Assert.fail; | ||||||
| import static org.mockito.ArgumentMatchers.any; | import static org.mockito.ArgumentMatchers.any; | ||||||
| import static org.mockito.ArgumentMatchers.anyString; | import static org.mockito.ArgumentMatchers.anyString; | ||||||
| import static org.mockito.Mockito.atLeast; |  | ||||||
| import static org.mockito.Mockito.mock; | import static org.mockito.Mockito.mock; | ||||||
| import static org.mockito.Mockito.times; | import static org.mockito.Mockito.times; | ||||||
| import static org.mockito.Mockito.verify; | import static org.mockito.Mockito.verify; | ||||||
| import static org.mockito.Mockito.when; |  | ||||||
| import static ru.noties.markwon.MarkwonBuilderImpl.ensureImplicitCoreIfHasDependents; |  | ||||||
| import static ru.noties.markwon.MarkwonBuilderImpl.preparePlugins; |  | ||||||
| 
 | 
 | ||||||
| @RunWith(RobolectricTestRunner.class) | @RunWith(RobolectricTestRunner.class) | ||||||
| @Config(manifest = Config.NONE) | @Config(manifest = Config.NONE) | ||||||
| public class MarkwonBuilderImplTest { | public class MarkwonBuilderImplTest { | ||||||
| 
 | 
 | ||||||
|     @Test |  | ||||||
|     public void implicit_core_created() { |  | ||||||
|         // a plugin explicitly requests CorePlugin, but CorePlugin is not added manually by user |  | ||||||
|         // we validate that default CorePlugin instance is added |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin plugin = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 // strictly speaking we do not need to override this method |  | ||||||
|                 // as all children of AbstractMarkwonPlugin specify CorePlugin as a dependency. |  | ||||||
|                 // but we still add it to make things explicit and future proof, if this |  | ||||||
|                 // behavior changes |  | ||||||
|                 return Priority.after(CorePlugin.class); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = ensureImplicitCoreIfHasDependents(Collections.singletonList(plugin)); |  | ||||||
| 
 |  | ||||||
|         assertThat(plugins, hasSize(2)); |  | ||||||
|         assertThat(plugins, hasItem(isA(CorePlugin.class))); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void implicit_core_no_dependents_not_added() { |  | ||||||
|         final MarkwonPlugin a = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.none(); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin b = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(a.getClass()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = ensureImplicitCoreIfHasDependents(Arrays.asList(a, b)); |  | ||||||
|         assertThat(plugins, hasSize(2)); |  | ||||||
|         assertThat(plugins, not(hasItem(isA(CorePlugin.class)))); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void implicit_core_present() { |  | ||||||
|         // if core is present it won't be added (whether or not there are dependents) |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin plugin = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(CorePlugin.class); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final CorePlugin corePlugin = CorePlugin.create(); |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = ensureImplicitCoreIfHasDependents(Arrays.asList(plugin, corePlugin)); |  | ||||||
|         assertThat(plugins, hasSize(2)); |  | ||||||
|         assertThat(plugins, hasItem(plugin)); |  | ||||||
|         assertThat(plugins, hasItem(corePlugin)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void implicit_core_subclass_present() { |  | ||||||
|         // core was subclassed by a user and provided (implicit core won't be added) |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin plugin = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(CorePlugin.class); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         // our subclass |  | ||||||
|         final CorePlugin corePlugin = new CorePlugin() { |  | ||||||
| 
 |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = ensureImplicitCoreIfHasDependents(Arrays.asList(plugin, corePlugin)); |  | ||||||
|         assertThat(plugins, hasSize(2)); |  | ||||||
|         assertThat(plugins, hasItem(plugin)); |  | ||||||
|         assertThat(plugins, hasItem(corePlugin)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |     @Test | ||||||
|     public void prepare_plugins() { |     public void prepare_plugins() { | ||||||
|         // validate that prepare plugins is calling `ensureImplicitCoreIfHasDependents` and |         // validate that prepare plugins is calling `ensureImplicitCoreIfHasDependents` and | ||||||
|         // priority processor |         // priority processor | ||||||
| 
 | 
 | ||||||
|         final PriorityProcessor priorityProcessor = mock(PriorityProcessor.class); | //        final PriorityProcessor priorityProcessor = mock(PriorityProcessor.class); | ||||||
|         when(priorityProcessor.process(ArgumentMatchers.<MarkwonPlugin>anyList())) | //        when(priorityProcessor.process(ArgumentMatchers.<MarkwonPlugin>anyList())) | ||||||
|                 .thenAnswer(new Answer<Object>() { | //                .thenAnswer(new Answer<Object>() { | ||||||
|                     @Override | //                    @Override | ||||||
|                     public Object answer(InvocationOnMock invocation) { | //                    public Object answer(InvocationOnMock invocation) { | ||||||
|                         return invocation.getArgument(0); | //                        return invocation.getArgument(0); | ||||||
|                     } | //                    } | ||||||
|                 }); | //                }); | ||||||
|  | // | ||||||
|  | //        final MarkwonPlugin plugin = new AbstractMarkwonPlugin() { | ||||||
|  | //            @NonNull | ||||||
|  | //            @Override | ||||||
|  | //            public Priority priority() { | ||||||
|  | //                return Priority.after(CorePlugin.class); | ||||||
|  | //            } | ||||||
|  | //        }; | ||||||
|  | // | ||||||
|  | //        final List<MarkwonPlugin> plugins = preparePlugins(priorityProcessor, Collections.singletonList(plugin)); | ||||||
|  | //        assertThat(plugins, hasSize(2)); | ||||||
|  | //        assertThat(plugins, hasItem(plugin)); | ||||||
|  | //        assertThat(plugins, hasItem(isA(CorePlugin.class))); | ||||||
|  | // | ||||||
|  | //        verify(priorityProcessor, times(1)) | ||||||
|  | //                .process(ArgumentMatchers.<MarkwonPlugin>anyList()); | ||||||
| 
 | 
 | ||||||
|         final MarkwonPlugin plugin = new AbstractMarkwonPlugin() { |         fail(); | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(CorePlugin.class); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = preparePlugins(priorityProcessor, Collections.singletonList(plugin)); |  | ||||||
|         assertThat(plugins, hasSize(2)); |  | ||||||
|         assertThat(plugins, hasItem(plugin)); |  | ||||||
|         assertThat(plugins, hasItem(isA(CorePlugin.class))); |  | ||||||
| 
 |  | ||||||
|         verify(priorityProcessor, times(1)) |  | ||||||
|                 .process(ArgumentMatchers.<MarkwonPlugin>anyList()); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void user_supplied_priority_processor() { |  | ||||||
|         // verify that if user supplied priority processor it will be used |  | ||||||
| 
 |  | ||||||
|         final PriorityProcessor priorityProcessor = mock(PriorityProcessor.class); |  | ||||||
|         final MarkwonBuilderImpl impl = new MarkwonBuilderImpl(RuntimeEnvironment.application); |  | ||||||
| 
 |  | ||||||
|         // add some plugin (we do not care which one, but it must be present as we do not |  | ||||||
|         // allow empty plugins list) |  | ||||||
|         impl.usePlugin(new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.none(); |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
|         impl.priorityProcessor(priorityProcessor); |  | ||||||
|         impl.build(); |  | ||||||
| 
 |  | ||||||
|         verify(priorityProcessor, times(1)).process(ArgumentMatchers.<MarkwonPlugin>anyList()); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
| @ -204,22 +77,19 @@ public class MarkwonBuilderImplTest { | |||||||
|         // verify that all configuration methods (applicable) are called |         // verify that all configuration methods (applicable) are called | ||||||
| 
 | 
 | ||||||
|         final MarkwonPlugin plugin = mock(MarkwonPlugin.class); |         final MarkwonPlugin plugin = mock(MarkwonPlugin.class); | ||||||
|         when(plugin.priority()).thenReturn(Priority.none()); |  | ||||||
| 
 | 
 | ||||||
|         final MarkwonBuilderImpl impl = new MarkwonBuilderImpl(RuntimeEnvironment.application); |         final MarkwonBuilderImpl impl = new MarkwonBuilderImpl(RuntimeEnvironment.application); | ||||||
|         impl.usePlugin(plugin).build(); |         impl.usePlugin(plugin).build(); | ||||||
| 
 | 
 | ||||||
|  |         verify(plugin, times(1)).configure(any(MarkwonPlugin.Registry.class)); | ||||||
|  | 
 | ||||||
|         verify(plugin, times(1)).configureParser(any(Parser.Builder.class)); |         verify(plugin, times(1)).configureParser(any(Parser.Builder.class)); | ||||||
|         verify(plugin, times(1)).configureTheme(any(MarkwonTheme.Builder.class)); |         verify(plugin, times(1)).configureTheme(any(MarkwonTheme.Builder.class)); | ||||||
|         verify(plugin, times(1)).configureImages(any(AsyncDrawableLoader.Builder.class)); |  | ||||||
|         verify(plugin, times(1)).configureConfiguration(any(MarkwonConfiguration.Builder.class)); |         verify(plugin, times(1)).configureConfiguration(any(MarkwonConfiguration.Builder.class)); | ||||||
|         verify(plugin, times(1)).configureVisitor(any(MarkwonVisitor.Builder.class)); |         verify(plugin, times(1)).configureVisitor(any(MarkwonVisitor.Builder.class)); | ||||||
|         verify(plugin, times(1)).configureSpansFactory(any(MarkwonSpansFactory.Builder.class)); |         verify(plugin, times(1)).configureSpansFactory(any(MarkwonSpansFactory.Builder.class)); | ||||||
|         verify(plugin, times(1)).configureHtmlRenderer(any(MarkwonHtmlRenderer.Builder.class)); |         verify(plugin, times(1)).configureHtmlRenderer(any(MarkwonHtmlRenderer.Builder.class)); | ||||||
| 
 | 
 | ||||||
|         // we do not know how many times exactly, but at least once it must be called |  | ||||||
|         verify(plugin, atLeast(1)).priority(); |  | ||||||
| 
 |  | ||||||
|         // note, no render props -> they must be configured on render stage |         // note, no render props -> they must be configured on render stage | ||||||
|         verify(plugin, times(0)).processMarkdown(anyString()); |         verify(plugin, times(0)).processMarkdown(anyString()); | ||||||
|         verify(plugin, times(0)).beforeRender(any(Node.class)); |         verify(plugin, times(0)).beforeRender(any(Node.class)); | ||||||
|  | |||||||
| @ -191,13 +191,6 @@ public class CorePluginTest { | |||||||
|         assertEquals(impl.map.toString(), 0, impl.map.size()); |         assertEquals(impl.map.toString(), 0, impl.map.size()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |  | ||||||
|     public void priority_none() { |  | ||||||
|         // CorePlugin returns none as priority (thus 0) |  | ||||||
| 
 |  | ||||||
|         assertEquals(0, CorePlugin.create().priority().after().size()); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |     @Test | ||||||
|     public void plugin_methods() { |     public void plugin_methods() { | ||||||
|         // checks that only expected plugin methods are overridden |         // checks that only expected plugin methods are overridden | ||||||
|  | |||||||
| @ -2,7 +2,6 @@ package ru.noties.markwon.image; | |||||||
| 
 | 
 | ||||||
| import android.content.Context; | import android.content.Context; | ||||||
| import android.support.annotation.NonNull; | import android.support.annotation.NonNull; | ||||||
| import android.support.annotation.Nullable; |  | ||||||
| 
 | 
 | ||||||
| import org.commonmark.node.Image; | import org.commonmark.node.Image; | ||||||
| import org.junit.Test; | import org.junit.Test; | ||||||
| @ -18,7 +17,6 @@ import ru.noties.markwon.MarkwonSpansFactory; | |||||||
| import ru.noties.markwon.RenderProps; | import ru.noties.markwon.RenderProps; | ||||||
| import ru.noties.markwon.SpanFactory; | import ru.noties.markwon.SpanFactory; | ||||||
| import ru.noties.markwon.core.CorePlugin; | import ru.noties.markwon.core.CorePlugin; | ||||||
| import ru.noties.markwon.core.MarkwonTheme; |  | ||||||
| import ru.noties.markwon.test.TestSpan.Document; | import ru.noties.markwon.test.TestSpan.Document; | ||||||
| import ru.noties.markwon.test.TestSpanMatcher; | import ru.noties.markwon.test.TestSpanMatcher; | ||||||
| 
 | 
 | ||||||
| @ -39,7 +37,6 @@ public class ImageTest { | |||||||
|         final Context context = RuntimeEnvironment.application; |         final Context context = RuntimeEnvironment.application; | ||||||
|         final Markwon markwon = Markwon.builder(context) |         final Markwon markwon = Markwon.builder(context) | ||||||
|                 .usePlugin(CorePlugin.create()) |                 .usePlugin(CorePlugin.create()) | ||||||
|                 .usePlugin(new ImagesPlugin(context, false)) |  | ||||||
|                 .usePlugin(new AbstractMarkwonPlugin() { |                 .usePlugin(new AbstractMarkwonPlugin() { | ||||||
|                     @Override |                     @Override | ||||||
|                     public void configureSpansFactory(@NonNull MarkwonSpansFactory.Builder builder) { |                     public void configureSpansFactory(@NonNull MarkwonSpansFactory.Builder builder) { | ||||||
|  | |||||||
| @ -1,494 +0,0 @@ | |||||||
| package ru.noties.markwon.priority; |  | ||||||
| 
 |  | ||||||
| import android.support.annotation.NonNull; |  | ||||||
| import android.support.annotation.Nullable; |  | ||||||
| 
 |  | ||||||
| import org.junit.Before; |  | ||||||
| import org.junit.Test; |  | ||||||
| import org.junit.runner.RunWith; |  | ||||||
| import org.robolectric.RobolectricTestRunner; |  | ||||||
| import org.robolectric.annotation.Config; |  | ||||||
| 
 |  | ||||||
| import java.util.ArrayList; |  | ||||||
| import java.util.Arrays; |  | ||||||
| import java.util.Collections; |  | ||||||
| import java.util.HashSet; |  | ||||||
| import java.util.List; |  | ||||||
| 
 |  | ||||||
| import ru.noties.markwon.AbstractMarkwonPlugin; |  | ||||||
| import ru.noties.markwon.MarkwonPlugin; |  | ||||||
| import ru.noties.markwon.core.CorePlugin; |  | ||||||
| 
 |  | ||||||
| import static org.junit.Assert.assertEquals; |  | ||||||
| import static org.junit.Assert.assertTrue; |  | ||||||
| import static org.junit.Assert.fail; |  | ||||||
| 
 |  | ||||||
| @RunWith(RobolectricTestRunner.class) |  | ||||||
| @Config(manifest = Config.NONE) |  | ||||||
| public class PriorityProcessorTest { |  | ||||||
| 
 |  | ||||||
|     private PriorityProcessor processor; |  | ||||||
| 
 |  | ||||||
|     @Before |  | ||||||
|     public void before() { |  | ||||||
|         processor = PriorityProcessor.create(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void empty_list() { |  | ||||||
|         final List<MarkwonPlugin> plugins = Collections.emptyList(); |  | ||||||
|         assertEquals(0, processor.process(plugins).size()); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void simple_two_plugins() { |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin first = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.none(); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin second = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(first.getClass()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = processor.process(Arrays.asList(second, first)); |  | ||||||
| 
 |  | ||||||
|         assertEquals(2, plugins.size()); |  | ||||||
|         assertEquals(first, plugins.get(0)); |  | ||||||
|         assertEquals(second, plugins.get(1)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void plugin_after_self() { |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin plugin = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(getClass()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         try { |  | ||||||
|             processor.process(Collections.singletonList(plugin)); |  | ||||||
|             fail(); |  | ||||||
|         } catch (IllegalStateException e) { |  | ||||||
|             assertTrue(e.getMessage(), e.getMessage().contains("defined self as a dependency")); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void unsatisfied_dependency() { |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin plugin = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(ImagesPlugin.class); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         try { |  | ||||||
|             processor.process(Collections.singletonList(plugin)); |  | ||||||
|             fail(); |  | ||||||
|         } catch (IllegalStateException e) { |  | ||||||
|             assertTrue(e.getMessage(), e.getMessage().contains("Markwon unsatisfied dependency found")); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void subclass_found() { |  | ||||||
|         // when a plugin comes after another, but _another_ was subclassed and placed in the list |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin core = new CorePlugin() { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin plugin = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(CorePlugin.class); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = processor.process(Arrays.asList(plugin, core)); |  | ||||||
|         assertEquals(2, plugins.size()); |  | ||||||
|         assertEquals(core, plugins.get(0)); |  | ||||||
|         assertEquals(plugin, plugins.get(1)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void three_plugins_sequential() { |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin first = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.none(); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin second = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(first.getClass()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin third = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(second.getClass()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = processor.process(Arrays.asList(third, second, first)); |  | ||||||
|         assertEquals(3, plugins.size()); |  | ||||||
|         assertEquals(first, plugins.get(0)); |  | ||||||
|         assertEquals(second, plugins.get(1)); |  | ||||||
|         assertEquals(third, plugins.get(2)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void five_plugins_sequential() { |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin a = new NamedPlugin("a") { |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin b = new NamedPlugin("b", a) { |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin c = new NamedPlugin("c", b) { |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin d = new NamedPlugin("d", c) { |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin e = new NamedPlugin("e", d) { |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = processor.process(Arrays.asList(d, e, a, c, b)); |  | ||||||
|         assertEquals(5, plugins.size()); |  | ||||||
|         assertEquals(a, plugins.get(0)); |  | ||||||
|         assertEquals(b, plugins.get(1)); |  | ||||||
|         assertEquals(c, plugins.get(2)); |  | ||||||
|         assertEquals(d, plugins.get(3)); |  | ||||||
|         assertEquals(e, plugins.get(4)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void plugin_duplicate() { |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin plugin = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.none(); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         try { |  | ||||||
|             processor.process(Arrays.asList(plugin, plugin)); |  | ||||||
|             fail(); |  | ||||||
|         } catch (IllegalStateException e) { |  | ||||||
|             assertTrue(e.getMessage(), e.getMessage().contains("Markwon duplicate plugin found")); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void multiple_after_3() { |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin a1 = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.none(); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin b1 = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(a1.getClass()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin c1 = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(a1.getClass(), b1.getClass()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = processor.process(Arrays.asList(c1, a1, b1)); |  | ||||||
|         assertEquals(3, plugins.size()); |  | ||||||
|         assertEquals(a1, plugins.get(0)); |  | ||||||
|         assertEquals(b1, plugins.get(1)); |  | ||||||
|         assertEquals(c1, plugins.get(2)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void multiple_after_4() { |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin a1 = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.none(); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin b1 = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(a1.getClass()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin c1 = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(a1.getClass(), b1.getClass()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin d1 = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.builder() |  | ||||||
|                         .after(a1.getClass()) |  | ||||||
|                         .after(b1.getClass()) |  | ||||||
|                         .after(c1.getClass()) |  | ||||||
|                         .build(); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = processor.process(Arrays.asList(c1, d1, a1, b1)); |  | ||||||
|         assertEquals(4, plugins.size()); |  | ||||||
|         assertEquals(a1, plugins.get(0)); |  | ||||||
|         assertEquals(b1, plugins.get(1)); |  | ||||||
|         assertEquals(c1, plugins.get(2)); |  | ||||||
|         assertEquals(d1, plugins.get(3)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void cycle() { |  | ||||||
| 
 |  | ||||||
|         final class Holder { |  | ||||||
|             Class<? extends MarkwonPlugin> type; |  | ||||||
|         } |  | ||||||
|         final Holder holder = new Holder(); |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin first = new AbstractMarkwonPlugin() { |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(holder.type); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin second = new AbstractMarkwonPlugin() { |  | ||||||
| 
 |  | ||||||
|             { |  | ||||||
|                 holder.type = getClass(); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return Priority.after(first.getClass()); |  | ||||||
|             } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         try { |  | ||||||
|             processor.process(Arrays.asList(second, first)); |  | ||||||
|             fail(); |  | ||||||
|         } catch (IllegalStateException e) { |  | ||||||
|             assertTrue(e.getMessage(), e.getMessage().contains("being referenced by own dependency (cycle)")); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void bigger_cycle() { |  | ||||||
| 
 |  | ||||||
|         final class Plugin extends NamedPlugin { |  | ||||||
| 
 |  | ||||||
|             private Priority priority; |  | ||||||
| 
 |  | ||||||
|             private Plugin(@NonNull String name) { |  | ||||||
|                 super(name); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             private void set(@NonNull MarkwonPlugin plugin) { |  | ||||||
|                 priority = Priority.after(plugin.getClass()); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             @NonNull |  | ||||||
|             @Override |  | ||||||
|             public Priority priority() { |  | ||||||
|                 return priority; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         final Plugin a = new Plugin("a"); |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = new ArrayList<>(); |  | ||||||
|         plugins.add(a); |  | ||||||
|         plugins.add(new NamedPlugin("b", plugins.get(plugins.size() - 1)) { |  | ||||||
|         }); |  | ||||||
|         plugins.add(new NamedPlugin("c", plugins.get(plugins.size() - 1)) { |  | ||||||
|         }); |  | ||||||
|         plugins.add(new NamedPlugin("d", plugins.get(plugins.size() - 1)) { |  | ||||||
|         }); |  | ||||||
|         plugins.add(new NamedPlugin("e", plugins.get(plugins.size() - 1)) { |  | ||||||
|         }); |  | ||||||
|         plugins.add(new NamedPlugin("f", plugins.get(plugins.size() - 1)) { |  | ||||||
|         }); |  | ||||||
|         plugins.add(new NamedPlugin("g", plugins.get(plugins.size() - 1)) { |  | ||||||
|         }); |  | ||||||
| 
 |  | ||||||
|         // link with the last one |  | ||||||
|         a.set(plugins.get(plugins.size() - 1)); |  | ||||||
| 
 |  | ||||||
|         try { |  | ||||||
|             processor.process(plugins); |  | ||||||
|             fail(); |  | ||||||
|         } catch (IllegalStateException e) { |  | ||||||
|             assertTrue(e.getMessage(), e.getMessage().contains("being referenced by own dependency (cycle)")); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void deep_tree() { |  | ||||||
| 
 |  | ||||||
|         // we must create subclasses in order to register them like this (otherwise -> duplicates) |  | ||||||
|         final MarkwonPlugin a = new NamedPlugin("a") { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin b1 = new NamedPlugin("b1", a) { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin b2 = new NamedPlugin("b2", a) { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin c1 = new NamedPlugin("c1", b1) { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin c2 = new NamedPlugin("c2", b1) { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin c3 = new NamedPlugin("c3", b2) { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin c4 = new NamedPlugin("c4", b2) { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin d1 = new NamedPlugin("d1", c1) { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin e1 = new NamedPlugin("e1", d1, c2, c3, c4) { |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = processor.process(Arrays.asList(b2, b1, |  | ||||||
|                 a, e1, c4, c3, c2, c1, d1)); |  | ||||||
| 
 |  | ||||||
|         // a is first |  | ||||||
|         // b1 + b2 -> second+third |  | ||||||
|         // c1 + c2 + c3 + c4 -> forth, fifth, sixth, seventh |  | ||||||
|         // d1 -> 8th |  | ||||||
|         // e1 -> 9th |  | ||||||
| 
 |  | ||||||
|         assertEquals(9, plugins.size()); |  | ||||||
|         assertEquals(a, plugins.get(0)); |  | ||||||
|         assertEquals(new HashSet<>(Arrays.asList(b1, b2)), new HashSet<>(plugins.subList(1, 3))); |  | ||||||
|         assertEquals(new HashSet<>(Arrays.asList(c1, c2, c3, c4)), new HashSet<>(plugins.subList(3, 7))); |  | ||||||
|         assertEquals(d1, plugins.get(7)); |  | ||||||
|         assertEquals(e1, plugins.get(8)); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void multiple_detached() { |  | ||||||
| 
 |  | ||||||
|         // when graph has independent elements that are not connected with each other |  | ||||||
|         final MarkwonPlugin a0 = new NamedPlugin("a0") { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin a1 = new NamedPlugin("a1", a0) { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin a2 = new NamedPlugin("a2", a1) { |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final MarkwonPlugin b0 = new NamedPlugin("b0") { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin b1 = new NamedPlugin("b1", b0) { |  | ||||||
|         }; |  | ||||||
|         final MarkwonPlugin b2 = new NamedPlugin("b2", b1) { |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         final List<MarkwonPlugin> plugins = processor.process(Arrays.asList( |  | ||||||
|                 b2, a2, a0, b0, b1, a1)); |  | ||||||
| 
 |  | ||||||
|         assertEquals(6, plugins.size()); |  | ||||||
| 
 |  | ||||||
|         assertEquals(new HashSet<>(Arrays.asList(a0, b0)), new HashSet<>(plugins.subList(0, 2))); |  | ||||||
|         assertEquals(new HashSet<>(Arrays.asList(a1, b1)), new HashSet<>(plugins.subList(2, 4))); |  | ||||||
|         assertEquals(new HashSet<>(Arrays.asList(a2, b2)), new HashSet<>(plugins.subList(4, 6))); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     private static abstract class NamedPlugin extends AbstractMarkwonPlugin { |  | ||||||
| 
 |  | ||||||
|         private final String name; |  | ||||||
|         private final Priority priority; |  | ||||||
| 
 |  | ||||||
|         NamedPlugin(@NonNull String name) { |  | ||||||
|             this(name, (Priority) null); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         NamedPlugin(@NonNull String name, @Nullable MarkwonPlugin plugin) { |  | ||||||
|             this(name, plugin != null ? Priority.after(plugin.getClass()) : null); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         NamedPlugin(@NonNull String name, MarkwonPlugin... plugins) { |  | ||||||
|             this(name, of(plugins)); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         NamedPlugin(@NonNull String name, @Nullable Class<? extends MarkwonPlugin> plugin) { |  | ||||||
|             this(name, plugin != null ? Priority.after(plugin) : null); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         NamedPlugin(@NonNull String name, @Nullable Priority priority) { |  | ||||||
|             this.name = name; |  | ||||||
|             this.priority = priority; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         @NonNull |  | ||||||
|         @Override |  | ||||||
|         public Priority priority() { |  | ||||||
|             return priority != null |  | ||||||
|                     ? priority |  | ||||||
|                     : Priority.none(); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         @Override |  | ||||||
|         public String toString() { |  | ||||||
|             return "NamedPlugin{" + |  | ||||||
|                     "name='" + name + '\'' + |  | ||||||
|                     '}'; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         @NonNull |  | ||||||
|         private static Priority of(@NonNull MarkwonPlugin... plugins) { |  | ||||||
|             if (plugins.length == 0) return Priority.none(); |  | ||||||
|             final Priority.Builder builder = Priority.builder(); |  | ||||||
|             for (MarkwonPlugin plugin : plugins) { |  | ||||||
|                 builder.after(plugin.getClass()); |  | ||||||
|             } |  | ||||||
|             return builder.build(); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -27,7 +27,6 @@ import ru.noties.markwon.SpannableBuilder; | |||||||
| import ru.noties.markwon.core.CorePluginBridge; | import ru.noties.markwon.core.CorePluginBridge; | ||||||
| import ru.noties.markwon.core.MarkwonTheme; | import ru.noties.markwon.core.MarkwonTheme; | ||||||
| import ru.noties.markwon.html.MarkwonHtmlRenderer; | import ru.noties.markwon.html.MarkwonHtmlRenderer; | ||||||
| import ru.noties.markwon.image.AsyncDrawableLoader; |  | ||||||
| 
 | 
 | ||||||
| import static org.junit.Assert.assertEquals; | import static org.junit.Assert.assertEquals; | ||||||
| import static org.junit.Assert.assertTrue; | import static org.junit.Assert.assertTrue; | ||||||
| @ -84,7 +83,7 @@ public class SyntaxHighlightTest { | |||||||
| 
 | 
 | ||||||
|         final MarkwonConfiguration configuration = MarkwonConfiguration.builder() |         final MarkwonConfiguration configuration = MarkwonConfiguration.builder() | ||||||
|                 .syntaxHighlight(highlight) |                 .syntaxHighlight(highlight) | ||||||
|                 .build(mock(MarkwonTheme.class), mock(AsyncDrawableLoader.class), mock(MarkwonHtmlRenderer.class), spansFactory); |                 .build(mock(MarkwonTheme.class), mock(MarkwonHtmlRenderer.class), spansFactory); | ||||||
| 
 | 
 | ||||||
|         final Map<Class<? extends Node>, MarkwonVisitor.NodeVisitor<? extends Node>> visitorMap = Collections.emptyMap(); |         final Map<Class<? extends Node>, MarkwonVisitor.NodeVisitor<? extends Node>> visitorMap = Collections.emptyMap(); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -22,6 +22,17 @@ dependencies { | |||||||
|         compileOnly it['android-svg'] |         compileOnly it['android-svg'] | ||||||
|         compileOnly it['okhttp'] |         compileOnly it['okhttp'] | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     deps['test'].with { | ||||||
|  | 
 | ||||||
|  |         testImplementation project(':markwon-test-span') | ||||||
|  | 
 | ||||||
|  |         testImplementation it['junit'] | ||||||
|  |         testImplementation it['robolectric'] | ||||||
|  |         testImplementation it['mockito'] | ||||||
|  | 
 | ||||||
|  |         testImplementation it['commons-io'] | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| registerArtifact(this) | registerArtifact(this) | ||||||
| @ -14,9 +14,11 @@ import java.util.HashMap; | |||||||
| import java.util.Map; | import java.util.Map; | ||||||
| import java.util.Scanner; | import java.util.Scanner; | ||||||
| 
 | 
 | ||||||
|  | import ru.noties.markwon.image.ImageItem; | ||||||
|  | 
 | ||||||
| import static org.junit.Assert.assertEquals; | import static org.junit.Assert.assertEquals; | ||||||
| import static org.junit.Assert.assertNotNull; | import static org.junit.Assert.assertNotNull; | ||||||
| import static org.junit.Assert.assertNull; | import static org.junit.Assert.assertTrue; | ||||||
| 
 | 
 | ||||||
| @RunWith(RobolectricTestRunner.class) | @RunWith(RobolectricTestRunner.class) | ||||||
| @Config(manifest = Config.NONE) | @Config(manifest = Config.NONE) | ||||||
| @ -31,17 +33,29 @@ public class DataUriSchemeHandlerTest { | |||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void scheme_specific_part_is_empty() { |     public void scheme_specific_part_is_empty() { | ||||||
|         assertNull(handler.handle("data:", Uri.parse("data:"))); |         try { | ||||||
|  |             handler.handle("data:", Uri.parse("data:")); | ||||||
|  |         } catch (Throwable t) { | ||||||
|  |             assertTrue(t.getMessage(), t.getMessage().contains("Invalid data-uri")); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void data_uri_is_empty() { |     public void data_uri_is_empty() { | ||||||
|         assertNull(handler.handle("data://whatever", Uri.parse("data://whatever"))); |         try { | ||||||
|  |             handler.handle("data:whatever", Uri.parse("data:whatever")); | ||||||
|  |         } catch (Throwable t) { | ||||||
|  |             assertTrue(t.getMessage(), t.getMessage().contains("Invalid data-uri")); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void no_data() { |     public void no_data() { | ||||||
|         assertNull(handler.handle("data://,", Uri.parse("data://,"))); |         try { | ||||||
|  |             handler.handle("data:,", Uri.parse("data:,")); | ||||||
|  |         } catch (Throwable t) { | ||||||
|  |             assertTrue(t.getMessage(), t.getMessage().contains("Decoding data-uri failed")); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Test |     @Test | ||||||
| @ -58,33 +72,6 @@ public class DataUriSchemeHandlerTest { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         final Map<String, Item> expected = new HashMap<String, Item>() {{ |  | ||||||
|             put("data://text/plain;,123", new Item("text/plain", "123")); |  | ||||||
|             put("data://image/svg+xml;base64,MTIz", new Item("image/svg+xml", "123")); |  | ||||||
|         }}; |  | ||||||
| 
 |  | ||||||
|         for (Map.Entry<String, Item> entry : expected.entrySet()) { |  | ||||||
|             final ImageItem item = handler.handle(entry.getKey(), Uri.parse(entry.getKey())); |  | ||||||
|             assertNotNull(entry.getKey(), item); |  | ||||||
|             assertEquals(entry.getKey(), entry.getValue().contentType, item.contentType()); |  | ||||||
|             assertEquals(entry.getKey(), entry.getValue().data, readStream(item.inputStream())); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Test |  | ||||||
|     public void correct_real() { |  | ||||||
| 
 |  | ||||||
|         final class Item { |  | ||||||
| 
 |  | ||||||
|             final String contentType; |  | ||||||
|             final String data; |  | ||||||
| 
 |  | ||||||
|             Item(String contentType, String data) { |  | ||||||
|                 this.contentType = contentType; |  | ||||||
|                 this.data = data; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         final Map<String, Item> expected = new HashMap<String, Item>() {{ |         final Map<String, Item> expected = new HashMap<String, Item>() {{ | ||||||
|             put("data:text/plain;,123", new Item("text/plain", "123")); |             put("data:text/plain;,123", new Item("text/plain", "123")); | ||||||
|             put("", new Item("image/svg+xml", "123")); |             put("", new Item("image/svg+xml", "123")); | ||||||
| @ -93,8 +80,11 @@ public class DataUriSchemeHandlerTest { | |||||||
|         for (Map.Entry<String, Item> entry : expected.entrySet()) { |         for (Map.Entry<String, Item> entry : expected.entrySet()) { | ||||||
|             final ImageItem item = handler.handle(entry.getKey(), Uri.parse(entry.getKey())); |             final ImageItem item = handler.handle(entry.getKey(), Uri.parse(entry.getKey())); | ||||||
|             assertNotNull(entry.getKey(), item); |             assertNotNull(entry.getKey(), item); | ||||||
|             assertEquals(entry.getKey(), entry.getValue().contentType, item.contentType()); |             assertTrue(item.hasDecodingNeeded()); | ||||||
|             assertEquals(entry.getKey(), entry.getValue().data, readStream(item.inputStream())); | 
 | ||||||
|  |             final ImageItem.WithDecodingNeeded withDecodingNeeded = item.getAsWithDecodingNeeded(); | ||||||
|  |             assertEquals(entry.getKey(), entry.getValue().contentType, withDecodingNeeded.contentType()); | ||||||
|  |             assertEquals(entry.getKey(), entry.getValue().data, readStream(withDecodingNeeded.inputStream())); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Dimitry Ivanov
						Dimitry Ivanov