[jboss-svn-commits] JBoss Common SVN: r3533 - in shrinkwrap/trunk/impl-base/src: test/java/org/jboss/shrinkwrap/impl/base/asset and 1 other directory.
jboss-svn-commits at lists.jboss.org
jboss-svn-commits at lists.jboss.org
Fri Sep 18 12:00:17 EDT 2009
Author: ALRubinger
Date: 2009-09-18 12:00:16 -0400 (Fri, 18 Sep 2009)
New Revision: 3533
Added:
shrinkwrap/trunk/impl-base/src/test/java/org/jboss/shrinkwrap/impl/base/asset/ByteArrayAssetTestCase.java
Modified:
shrinkwrap/trunk/impl-base/src/main/java/org/jboss/shrinkwrap/impl/base/asset/ByteArrayAsset.java
Log:
[SHRINKWRAP-38] Add a defensive copy on ByteArrayAsset
Modified: shrinkwrap/trunk/impl-base/src/main/java/org/jboss/shrinkwrap/impl/base/asset/ByteArrayAsset.java
===================================================================
--- shrinkwrap/trunk/impl-base/src/main/java/org/jboss/shrinkwrap/impl/base/asset/ByteArrayAsset.java 2009-09-18 15:59:07 UTC (rev 3532)
+++ shrinkwrap/trunk/impl-base/src/main/java/org/jboss/shrinkwrap/impl/base/asset/ByteArrayAsset.java 2009-09-18 16:00:16 UTC (rev 3533)
@@ -70,11 +70,19 @@
// Precondition check
Validate.notNull(content, "content must be specified");
+ // Defensive copy on set, SHRINKWRAP-38
+ final int length = content.length;
+ byte[] newArray = new byte[length];
+ for (int i = 0; i < length; i++)
+ {
+ newArray[i] = content[i];
+ }
+
// Set
- this.content = content;
+ this.content = newArray;
if (log.isLoggable(Level.FINER))
{
- log.finer("Created " + this + " with backing byte array of size " + content.length + "b");
+ log.finer("Created " + this + " with backing byte array of size " + length + "b");
}
}
Added: shrinkwrap/trunk/impl-base/src/test/java/org/jboss/shrinkwrap/impl/base/asset/ByteArrayAssetTestCase.java
===================================================================
--- shrinkwrap/trunk/impl-base/src/test/java/org/jboss/shrinkwrap/impl/base/asset/ByteArrayAssetTestCase.java (rev 0)
+++ shrinkwrap/trunk/impl-base/src/test/java/org/jboss/shrinkwrap/impl/base/asset/ByteArrayAssetTestCase.java 2009-09-18 16:00:16 UTC (rev 3533)
@@ -0,0 +1,100 @@
+/*
+ * JBoss, Home of Professional Open Source
+ * Copyright 2009, Red Hat Middleware LLC, and individual contributors
+ * by the @authors tag. See the copyright.txt in the distribution for a
+ * full listing of individual contributors.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * http://www.apache.org/licenses/LICENSE-2.0
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.jboss.shrinkwrap.impl.base.asset;
+
+import java.io.ByteArrayOutputStream;
+import java.io.InputStream;
+import java.util.Arrays;
+import java.util.logging.Logger;
+
+import junit.framework.Assert;
+
+import org.junit.Test;
+
+/**
+ * ByteArrayAssetTestCase
+ *
+ * Test Cases for the {@link ByteArrayAsset}
+ *
+ * @author <a href="mailto:andrew.rubinger at jboss.org">ALR</a>
+ * @version $Revision: $
+ */
+public class ByteArrayAssetTestCase
+{
+
+ //-------------------------------------------------------------------------------------||
+ // Class Members ----------------------------------------------------------------------||
+ //-------------------------------------------------------------------------------------||
+
+ /**
+ * Logger
+ */
+ private static final Logger log = Logger.getLogger(ByteArrayAssetTestCase.class.getName());
+
+ //-------------------------------------------------------------------------------------||
+ // Instance Members -------------------------------------------------------------------||
+ //-------------------------------------------------------------------------------------||
+
+ //-------------------------------------------------------------------------------------||
+ // Tests ------------------------------------------------------------------------------||
+ //-------------------------------------------------------------------------------------||
+
+ /**
+ * Ensures that the contents of the asset match that which was passed in,
+ * and that the state of the asset can not be mutated from the outside
+ */
+ @Test
+ public void testRoundtripAndExternalMutationGuard() throws Exception
+ {
+ // Log
+ log.info("testRoundtrip");
+
+ // Make contents
+ final int length = 10;
+ final byte[] contents = new byte[length];
+ for (int i = 0; i < length; i++)
+ {
+ contents[i] = (byte) i;
+ }
+ log.info("Inbound contents: " + Arrays.toString(contents));
+
+ // Make Asset
+ final ByteArrayAsset asset = new ByteArrayAsset(contents);
+
+ // Change the contents passed in (so we ensure we protect against mutation, SHRINKWRAP-38)
+ contents[0] = 0x1;
+ log.info("Contents after change: " + Arrays.toString(contents));
+
+ // Get the contents back out of the asset
+ final InputStream stream = asset.getStream();
+ final ByteArrayOutputStream out = new ByteArrayOutputStream(length);
+ int read;
+ while ((read = stream.read()) != -1)
+ {
+ out.write(read);
+ }
+ byte[] roundtrip = out.toByteArray();
+ log.info("Roundtrip contents: " + Arrays.toString(roundtrip));
+
+ // Ensure the roundtrip matches the input (index number)
+ for (int i = 0; i < length; i++)
+ {
+ Assert.assertEquals("Roundtrip did not equal passed in contents", i, roundtrip[i]);
+ }
+
+ }
+}
More information about the jboss-svn-commits
mailing list