KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > jcorporate > expresso > core > misc > tests > HexEncoderTest


1 /* ====================================================================
2  * The Jcorporate Apache Style Software License, Version 1.2 05-07-2002
3  *
4  * Copyright (c) 1995-2002 Jcorporate Ltd. All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  *
10  * 1. Redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer.
12  *
13  * 2. Redistributions in binary form must reproduce the above copyright
14  * notice, this list of conditions and the following disclaimer in
15  * the documentation and/or other materials provided with the
16  * distribution.
17  *
18  * 3. The end-user documentation included with the redistribution,
19  * if any, must include the following acknowledgment:
20  * "This product includes software developed by Jcorporate Ltd.
21  * (http://www.jcorporate.com/)."
22  * Alternately, this acknowledgment may appear in the software itself,
23  * if and wherever such third-party acknowledgments normally appear.
24  *
25  * 4. "Jcorporate" and product names such as "Expresso" must
26  * not be used to endorse or promote products derived from this
27  * software without prior written permission. For written permission,
28  * please contact info@jcorporate.com.
29  *
30  * 5. Products derived from this software may not be called "Expresso",
31  * or other Jcorporate product names; nor may "Expresso" or other
32  * Jcorporate product names appear in their name, without prior
33  * written permission of Jcorporate Ltd.
34  *
35  * 6. No product derived from this software may compete in the same
36  * market space, i.e. framework, without prior written permission
37  * of Jcorporate Ltd. For written permission, please contact
38  * partners@jcorporate.com.
39  *
40  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
41  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
42  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
43  * DISCLAIMED. IN NO EVENT SHALL JCORPORATE LTD OR ITS CONTRIBUTORS
44  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
45  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
46  * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
47  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
48  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
49  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
50  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
51  * SUCH DAMAGE.
52  * ====================================================================
53  *
54  * This software consists of voluntary contributions made by many
55  * individuals on behalf of the Jcorporate Ltd. Contributions back
56  * to the project(s) are encouraged when you make modifications.
57  * Please send them to support@jcorporate.com. For more information
58  * on Jcorporate Ltd. and its products, please see
59  * <http://www.jcorporate.com/>.
60  *
61  * Portions of this software are based upon other open source
62  * products and are subject to their respective licenses.
63  */

64
65 package com.jcorporate.expresso.core.misc.tests;
66
67 import com.jcorporate.expresso.core.misc.HexEncoder;
68 import com.jcorporate.expresso.services.test.CommandLineParser;
69 import com.jcorporate.expresso.services.test.ExpressoTestCase;
70 import junit.framework.TestSuite;
71
72
73 /**
74  * Tests The HexEncoder Class. A Class that will take binary numbers and
75  * product a Hexadecimal output.
76  *
77  * @author Michael Rimov
78  * @version $Revision: 1.2 $ on $Date: 2004/11/17 20:48:23 $
79  */

80 public class HexEncoderTest
81         extends ExpressoTestCase {
82     public HexEncoderTest(String JavaDoc testName)
83             throws Exception JavaDoc {
84         super(testName);
85     }
86
87     public static void main(String JavaDoc[] args)
88             throws Exception JavaDoc {
89
90         //Set the system properties we need
91
CommandLineParser.parseCommandLine(args);
92         junit.textui.TestRunner.run(suite());
93     }
94
95     /**
96      * Filler Function to conform to log4j test suites.
97      */

98     public static junit.framework.Test suite() {
99         return new TestSuite(HexEncoderTest.class);
100     }
101
102     /**
103      * Tests to make sure both arrays are equal values.
104      *
105      * @param array1[]
106      * @param array2[]
107      * @return true if array1 and array2 have equal values contained in them.
108      */

109     private static boolean arraysAreEqual(byte[] array1, byte[] array2) {
110         if (array1.length != array2.length) {
111             return false;
112         }
113
114         int len = array1.length;
115
116         for (int i = 0; i < len; i++) {
117             if (array1[i] != array2[i]) {
118                 return false;
119             }
120         }
121
122         return true;
123     } /* arraysAreEqual(byte, byte) */
124
125     /**
126      * This test case makes sure that various byte values get properly
127      * encoded and decoded back.
128      *
129      * @throws Exception if an error occurs during encode/decode process
130      */

131     public void testHexEncode()
132             throws Exception JavaDoc {
133         byte[][] testArray = {
134             {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}, {5, 6, 7, 8, 9, 0, 35, 62, 33},
135             {(byte) 0x0A, (byte) 0xFF, (byte) 0xCA, (byte) 0xB1, (byte) 0x00, (byte) 0x42}
136         };
137
138         for (int i = 0; i < testArray.length; i++) {
139             byte[] test = testArray[i];
140             String JavaDoc encoded = HexEncoder.encode(test);
141             byte[] decoded = HexEncoder.decode(encoded);
142             assertTrue("Arrays Must Be Equal: i=" + i,
143                     arraysAreEqual(test, decoded));
144         }
145     }
146
147     /**
148      * This test makes sure that IllegalArgumentExceptions are thrown if
149      * invalid inputs are given to the system.
150      */

151     public void testBadInputs()
152             throws Exception JavaDoc {
153         String JavaDoc[] breakDecode = {"ABA", "", "ABCDEFHLKAMABACD"};
154
155         for (int i = 0; i < breakDecode.length; i++) {
156             try {
157                 byte[] decoded = HexEncoder.decode(breakDecode[i]);
158                 fail("Didn't handle bad input " + breakDecode[i]);
159             } catch (IllegalArgumentException JavaDoc ex) {
160             }
161         }
162     }
163 }
Popular Tags