Skip to content

Commit

Permalink
update unit tests
Browse files Browse the repository at this point in the history
  • Loading branch information
alexo committed Jun 5, 2012
1 parent 6dc6bb6 commit 1034805
Show file tree
Hide file tree
Showing 29 changed files with 117 additions and 34 deletions.
4 changes: 2 additions & 2 deletions wro4j-core/src/main/java/ro/isdc/wro/manager/WroManager.java
Expand Up @@ -208,13 +208,13 @@ private void serveProcessedBundle()
if (cacheValue.getRawContent() != null) {
// use gziped response if supported & Set content length based on gzip flag
if (isGzipAllowed()) {
response.setContentLength(cacheValue.getGzippedContent().length);
// response.setContentLength(cacheValue.getGzippedContent().length);
// add gzip header and gzip response
response.setHeader(HttpHeader.CONTENT_ENCODING.toString(), "gzip");
response.setHeader("Vary", "Accept-Encoding");
IOUtils.write(cacheValue.getGzippedContent(), os);
} else {
response.setContentLength(cacheValue.getRawContent().length());
// response.setContentLength(cacheValue.getRawContent().length());
IOUtils.write(cacheValue.getRawContent(), os, configuration.getEncoding());
}
}
Expand Down
Expand Up @@ -19,6 +19,7 @@ public class PerformanceLoggerCallback
extends LifecycleCallbackSupport {
private static final Logger LOG = LoggerFactory.getLogger(PerformanceLoggerCallback.class);
private static final String SHORT_SUMMARY = "=====Performance Logger Statistics==============";
// TODO use ThreadLocal to store watch in order to be threadSafe.
private StopWatch watch;

/**
Expand Down
Expand Up @@ -50,8 +50,7 @@ public abstract class AbstractCssUrlRewritingProcessor
/**
* Pattern used to identify the placeholders where the url rewriting will be performed.
*/
//(.*:\\s*
private static final String PATTERN_PATH = "(background.*?:\\s*url\\s*\\((\\s*['\"]?((?:.*?|\\s*?))['\"]?\\s*)\\)|src\\s*=\\s*['\"]((?:.|\\s)*?)['\"])";
private static final String PATTERN_PATH = "(?ims)(background.*?url\\s*\\((\\s*['\"]?((?:.*?|\\s*?))['\"]?\\s*)\\)|.*?:.*?src\\s*=\\s*['\"]((?:.|\\s)*?)['\"])";
/**
* Compiled pattern.
*/
Expand Down
Expand Up @@ -91,7 +91,11 @@ private boolean isImageUrlChangeRequired(final String imageUrl) {
return !(imageUrl.startsWith("http") || (isProxyResource(imageUrl)));
}

private DataUriGenerator getDataUriGenerator() {
/**
* @return the DataUriGenerator class responsible for transforming streams into base64 encoded strings.
* @VisibleForTesting
*/
protected DataUriGenerator getDataUriGenerator() {
if (dataUriGenerator == null) {
dataUriGenerator = new DataUriGenerator();
}
Expand Down
Expand Up @@ -240,7 +240,10 @@ private String computeNewImageLocation(final String cssUri, final String imageUr
// remove '/' from imageUrl if it starts with one.
final String processedImageUrl = cleanImageUrl.startsWith(ServletContextUriLocator.PREFIX) ? cleanImageUrl.substring(1)
: cleanImageUrl;
// remove redundant part of the path
// remove redundant part of the path, but skip protected resources (ex: located inside /WEB-INF/ folder). -> Not
// sure if this is a problem yet.
// final String computedImageLocation = ServletContextUriLocator.isProtectedResource(cssUriFolder) ? cssUriFolder
// + processedImageUrl : cleanPath(cssUriFolder + processedImageUrl);
final String computedImageLocation = cleanPath(cssUriFolder + processedImageUrl);
LOG.debug("computedImageLocation: {}", computedImageLocation);
return computedImageLocation;
Expand Down
Expand Up @@ -10,6 +10,7 @@

import org.junit.Before;
import org.junit.Test;
import org.mockito.Mockito;

import ro.isdc.wro.config.Context;
import ro.isdc.wro.manager.factory.BaseWroManagerFactory;
Expand All @@ -23,6 +24,7 @@
import ro.isdc.wro.model.resource.locator.factory.UriLocatorFactory;
import ro.isdc.wro.model.resource.processor.factory.SimpleProcessorsFactory;
import ro.isdc.wro.model.resource.processor.impl.css.CssDataUriPreProcessor;
import ro.isdc.wro.model.resource.processor.support.DataUriGenerator;
import ro.isdc.wro.util.WroTestUtils;


Expand All @@ -36,10 +38,27 @@ public class TestCssDataUriPreProcessor {
private final String PROXY_RESOURCE_PATH = "classpath:ro/isdc/wro/model/resource/processor/dataUri/proxyImage/";
private ResourcePreProcessor processor;

protected DataUriGenerator createMockDataUriGenerator() {
try {
DataUriGenerator uriGenerator = Mockito.mock(DataUriGenerator.class);
Mockito.when(uriGenerator.generateDataURI(Mockito.any(InputStream.class), Mockito.anyString())).thenReturn(
"");
return uriGenerator;
} catch (Exception e) {
throw new RuntimeException("Cannot create DataUriGenerator mock", e);
}
}

@Before
public void init() {
public void init()
throws Exception {
Context.set(Context.standaloneContext());
processor = new CssDataUriPreProcessor();
processor = new CssDataUriPreProcessor() {
@Override
protected DataUriGenerator getDataUriGenerator() {
return createMockDataUriGenerator();
}
};
initProcessor(processor);
}

Expand Down Expand Up @@ -82,7 +101,7 @@ public InputStream locate(final String uri)
}

@Test
public void testFromFolder()
public void shouldTransformResourcesFromFolder()
throws Exception {
final URL url = getClass().getResource("dataUri");

Expand All @@ -91,6 +110,19 @@ public void testFromFolder()
WroTestUtils.compareFromDifferentFoldersByExtension(testFolder, expectedFolder, "css", processor);
}

@Test
public void shouldTransformLargeResources()
throws Exception {
processor = new CssDataUriPreProcessor();
initProcessor(processor);

final URL url = getClass().getResource("dataUri");

final File testFolder = new File(url.getFile(), "test");
final File expectedFolder = new File(url.getFile(), "expectedLarge");
WroTestUtils.compareFromDifferentFoldersByExtension(testFolder, expectedFolder, "css", processor);
}

@Test
public void shouldSupportOnlyCssResources() {
WroTestUtils.assertProcessorSupportResourceTypes(processor, ResourceType.CSS);
Expand Down
Expand Up @@ -13,6 +13,7 @@
import ro.isdc.wro.model.resource.ResourceType;
import ro.isdc.wro.model.resource.processor.impl.css.CssDataUriPreProcessor;
import ro.isdc.wro.model.resource.processor.impl.css.FallbackCssDataUriProcessor;
import ro.isdc.wro.model.resource.processor.support.DataUriGenerator;
import ro.isdc.wro.util.WroTestUtils;


Expand All @@ -30,19 +31,38 @@ public class TestFallbackCssDataUriProcessor
@Before
public void init() {
Context.set(Context.standaloneContext());
processor = new FallbackCssDataUriProcessor();
processor = new FallbackCssDataUriProcessor() {
@Override
protected DataUriGenerator getDataUriGenerator() {
return createMockDataUriGenerator();
}
};
//find a way to use a custom uriLocator
initProcessor(processor);
}

@Override
@Test
public void testFromFolder()
public void shouldTransformResourcesFromFolder()
throws Exception {
final URL url = getClass().getResource("dataUri");

final File testFolder = new File(url.getFile(), "test");
final File expectedFolder = new File(url.getFile(), "fallbackExpected");
final File expectedFolder = new File(url.getFile(), "expectedFallback");
WroTestUtils.compareFromDifferentFoldersByExtension(testFolder, expectedFolder, "css", processor);
}

@Override
@Test
public void shouldTransformLargeResources()
throws Exception {
processor = new CssDataUriPreProcessor();
initProcessor(processor);

final URL url = getClass().getResource("dataUri");

final File testFolder = new File(url.getFile(), "test");
final File expectedFolder = new File(url.getFile(), "expectedFallbackLarge");
WroTestUtils.compareFromDifferentFoldersByExtension(testFolder, expectedFolder, "css", processor);
}

Expand Down
@@ -1,3 +1,5 @@
input.button {
background: url();
background: url();
background-image: url("");
filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='', sizingMethod='scale');
}

This file was deleted.

0 comments on commit 1034805

Please sign in to comment.