Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. 
                        
                        Project price only 1 $ 
                        
                            You can buy this project and download/modify it how often you want.
                        
                        
                        
                     
                 
             
         
                    
                com.webimageloader.test.ImageLoaderTestCase Maven / Gradle / Ivy 
    
package com.webimageloader.test;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.net.URL;
import java.net.URLConnection;
import java.net.URLStreamHandler;
import java.util.Random;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;
import android.annotation.TargetApi;
import android.content.res.AssetManager;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.test.AndroidTestCase;
import com.webimageloader.ImageLoader;
import com.webimageloader.ImageLoader.Listener;
import com.webimageloader.Request;
import com.webimageloader.transformation.SimpleTransformation;
import com.webimageloader.transformation.Transformation;
@TargetApi(16)
public class ImageLoaderTestCase extends AndroidTestCase {
    private static final int TIMEOUT = 1;
    private static final int TEN_MEGABYTES = 10 * 1024 * 1024;
    private static final String MOCK_SCHEME = "mock://";
    private static final String CORRECT_FILE_PATH = "test.png";
    private static final String CORRECT_MOCK_FILE_PATH = MOCK_SCHEME + CORRECT_FILE_PATH;
    private static final String WRONG_FILE_PATH = MOCK_SCHEME + "error.jpeg";
    private static final Listener EMPTY_LISTENER = new Listener() {
        @Override
        public void onSuccess(Object tag, Bitmap b) {}
        @Override
        public void onError(Object tag, Throwable t) {}
    };
    private ImageLoader loader;
    private Bitmap correctFile;
    private MockURLStreamHandler streamHandler;
    @Override
    protected void setUp() throws Exception {
        int random = Math.abs(new Random().nextInt());
        File cacheDir = new File(getContext().getCacheDir(), String.valueOf(random));
        streamHandler = new MockURLStreamHandler(getContext().getAssets());
        loader = new ImageLoader.Builder(getContext())
                .enableDiskCache(cacheDir, TEN_MEGABYTES)
                .enableMemoryCache(TEN_MEGABYTES)
                .addURLSchemeHandler("mock", streamHandler)
                .build();
        correctFile = BitmapFactory.decodeStream(getContext().getAssets().open(CORRECT_FILE_PATH));
    }
    @Override
    protected void tearDown() throws Exception {
        loader.destroy();
    }
    public void testSameThread() throws IOException {
        Bitmap b = loader.loadBlocking(CORRECT_MOCK_FILE_PATH);
        assertTrue(correctFile.sameAs(b));
    }
    public void testNoDiskCacheFallback() throws IOException {
        File invalidCacheDir = new File("../");
        ImageLoader loader = new ImageLoader.Builder(getContext())
        .enableDiskCache(invalidCacheDir, TEN_MEGABYTES)
        .enableMemoryCache(TEN_MEGABYTES)
        .addURLSchemeHandler("mock", new MockURLStreamHandler(getContext().getAssets()))
        .build();
        Bitmap b = loader.loadBlocking(CORRECT_MOCK_FILE_PATH);
        assertTrue(correctFile.sameAs(b));
    }
    public void testTag() throws InterruptedException {
        final CountDownLatch latch = new CountDownLatch(1);
        final Object t = new Object();
        final Holder h = new Holder();
        loader.load(t, CORRECT_MOCK_FILE_PATH, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                h.value = tag;
                latch.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                h.value = tag;
                latch.countDown();
            }
        });
        assertTrue(latch.await(TIMEOUT, TimeUnit.SECONDS));
        assertSame(t, h.value);
    }
    public void testMissingImageAsync() throws InterruptedException {
        final CountDownLatch latch = new CountDownLatch(1);
        final Holder h = new Holder();
        loader.load(null, WRONG_FILE_PATH, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                latch.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                h.value = t;
                latch.countDown();
            }
        });
        assertTrue(latch.await(TIMEOUT, TimeUnit.SECONDS));
        assertTrue(h.value instanceof FileNotFoundException);
    }
    public void testMissingImage() throws IOException {
        try {
            loader.loadBlocking(WRONG_FILE_PATH);
            fail("Should have thrown an exception");
        } catch (FileNotFoundException e) {
            // Expected
        }
    }
    public void testMemory() throws IOException {
        loader.loadBlocking(CORRECT_MOCK_FILE_PATH);
        Bitmap b = loader.load(null, CORRECT_MOCK_FILE_PATH, EMPTY_LISTENER);
        assertNotNull(b);
    }
    public void testAsyncSuccess() throws InterruptedException {
        final CountDownLatch latch = new CountDownLatch(1);
        final Holder h = new Holder();
        loader.load(null, CORRECT_MOCK_FILE_PATH, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                h.value = b;
                latch.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                latch.countDown();
            }
        });
        assertTrue(latch.await(TIMEOUT, TimeUnit.SECONDS));
        assertNotNull(h.value);
        assertTrue(h.value.sameAs(correctFile));
    }
    public void testAsyncError() throws InterruptedException {
        final CountDownLatch latch = new CountDownLatch(1);
        final Holder h = new Holder();
        loader.load(null, WRONG_FILE_PATH, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                latch.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                h.value = t;
                latch.countDown();
            }
        });
        assertTrue(latch.await(TIMEOUT, TimeUnit.SECONDS));
        assertNotNull(h.value);
    }
    public void testMultipleRequests() throws InterruptedException {
        final CountDownLatch latch = new CountDownLatch(5);
        for (int i = 0; i < 5; i++) {
            loader.load(null, CORRECT_MOCK_FILE_PATH, new Listener() {
                @Override
                public void onSuccess(Object tag, Bitmap b) {
                    latch.countDown();
                }
                @Override
                public void onError(Object tag, Throwable t) {
                    latch.countDown();
                }
            });
        }
        assertTrue(latch.await(TIMEOUT, TimeUnit.SECONDS));
    }
    public void testRequestReuse() throws InterruptedException {
        final CountDownLatch latch = new CountDownLatch(2);
        final Holder h1 = new Holder();
        final Holder h2 = new Holder();
        loader.load(null, CORRECT_MOCK_FILE_PATH, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                h1.value = b;
                latch.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                latch.countDown();
            }
        });
        loader.load(null, CORRECT_MOCK_FILE_PATH, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                h2.value = b;
                latch.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                latch.countDown();
            }
        });
        assertTrue(latch.await(TIMEOUT, TimeUnit.SECONDS));
        assertNotNull(h1.value);
        assertNotNull(h2.value);
        assertSame(h1.value, h2.value);
    }
    public void testRequestCancellation() throws InterruptedException {
        final CountDownLatch latch = new CountDownLatch(1);
        Object tag = new Object();
        final Holder failed = new Holder();
        loader.load(tag, WRONG_FILE_PATH, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                failed.value = true;
                latch.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                failed.value = true;
                latch.countDown();
            }
        });
        loader.load(tag, CORRECT_MOCK_FILE_PATH, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                latch.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                latch.countDown();
            }
        });
        assertTrue(latch.await(TIMEOUT, TimeUnit.SECONDS));
        if (failed.value == Boolean.TRUE) {
            fail("First request should have been cancelled");
        }
    }
    public void testTagCancel() throws InterruptedException {
        final CountDownLatch latch = new CountDownLatch(1);
        Object tag = new Object();
        // Use wrong path so it will fail faster
        loader.load(tag, WRONG_FILE_PATH, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                latch.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                latch.countDown();
            }
        });
        loader.cancel(tag);
        // We should not get any callbacks
        assertFalse(latch.await(TIMEOUT, TimeUnit.SECONDS));
    }
    public void testIgnoreCache() throws InterruptedException {
        ignoreCache(new Request(CORRECT_MOCK_FILE_PATH));
    }
    public void testIgnoreCacheTransformation() throws InterruptedException {
        ignoreCache(new Request(CORRECT_MOCK_FILE_PATH, new IdentityTransformation()));
    }
    public void testNoCache() throws InterruptedException {
        noCache(new Request(CORRECT_MOCK_FILE_PATH), new Request(CORRECT_MOCK_FILE_PATH));
    }
    public void testNoCacheTransformation() throws InterruptedException {
        noCache(new Request(CORRECT_MOCK_FILE_PATH), new Request(CORRECT_MOCK_FILE_PATH, new IdentityTransformation()));
    }
    public void noCache(Request firstRequest, Request secondRequest) throws InterruptedException {
        firstRequest.addFlag(Request.Flag.NO_CACHE);
        final CountDownLatch latch1 = new CountDownLatch(1);
        loader.load(null, firstRequest, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                latch1.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                latch1.countDown();
            }
        });
        assertTrue(latch1.await(TIMEOUT, TimeUnit.SECONDS));
        // Request the image again and and see if the cache is present
        final CountDownLatch latch2 = new CountDownLatch(1);
        Bitmap b = loader.load(null, secondRequest, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                latch2.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                latch2.countDown();
            }
        });
        assertNull(b);
        assertTrue(latch2.await(TIMEOUT, TimeUnit.SECONDS));
        assertEquals(2, streamHandler.timesOpened);
    }
    private void ignoreCache(Request request) throws InterruptedException {
        request.addFlag(Request.Flag.IGNORE_CACHE);
        final CountDownLatch latch1 = new CountDownLatch(1);
        loader.load(null, CORRECT_MOCK_FILE_PATH, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                latch1.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                latch1.countDown();
            }
        });
        assertTrue(latch1.await(TIMEOUT, TimeUnit.SECONDS));
        // Request the image again and ignore cache
        final CountDownLatch latch2 = new CountDownLatch(1);
        Bitmap b = loader.load(null, request, new Listener() {
            @Override
            public void onSuccess(Object tag, Bitmap b) {
                latch2.countDown();
            }
            @Override
            public void onError(Object tag, Throwable t) {
                latch2.countDown();
            }
        });
        assertNull(b);
        assertTrue(latch2.await(TIMEOUT, TimeUnit.SECONDS));
        assertEquals(2, streamHandler.timesOpened);
    }
    private static class IdentityTransformation extends SimpleTransformation {
        @Override
        public String getIdentifier() {
            return "identity";
        }
        @Override
        public Bitmap transform(Bitmap b) {
            return b;
        }
    }
    private static class MockURLStreamHandler extends URLStreamHandler {
        private AssetManager assets;
        public int timesOpened = 0;
        public MockURLStreamHandler(AssetManager assets) {
            this.assets = assets;
        }
        @Override
        protected URLConnection openConnection(URL url) throws IOException {
            timesOpened++;
            return new MockURLConnection(assets, url);
        }
    }
    private static class MockURLConnection extends URLConnection {
        private AssetManager assets;
        private String filename;
        protected MockURLConnection(AssetManager assets, URL url) {
            super(url);
            this.assets = assets;
            filename = url.getAuthority();
        }
        @Override
        public void connect() throws IOException {}
        @Override
        public InputStream getInputStream() throws IOException {
            return assets.open(filename);
        }
    }
    private static class Holder {
        public T value;
    }
}