1 /* 2 * The Apache Software License, Version 1.1 3 * 4 * Copyright (c) 2002 The Apache Software Foundation. All rights 5 * reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 11 * 1. Redistributions of source code must retain the above copyright 12 * notice, this list of conditions and the following disclaimer. 13 * 14 * 2. Redistributions in binary form must reproduce the above copyright 15 * notice, this list of conditions and the following disclaimer in 16 * the documentation and/or other materials provided with the 17 * distribution. 18 * 19 * 3. The end-user documentation included with the redistribution, 20 * if any, must include the following acknowledgment: 21 * "This product includes software developed by the 22 * Apache Software Foundation (http://www.apache.org/)." 23 * Alternately, this acknowledgment may appear in the software itself, 24 * if and wherever such third-party acknowledgments normally appear. 25 * 26 * 4. The names "Apache" and "Apache Software Foundation" must 27 * not be used to endorse or promote products derived from this 28 * software without prior written permission. For written 29 * permission, please contact apache@apache.org. 30 * 31 * 5. Products derived from this software may not be called "Apache", 32 * nor may "Apache" appear in their name, without prior written 33 * permission of the Apache Software Foundation. 34 * 35 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 36 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 37 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 38 * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR 39 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 40 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 41 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF 42 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 43 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 44 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 45 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 46 * SUCH DAMAGE. 47 * ==================================================================== 48 * 49 * This software consists of voluntary contributions made by many 50 * individuals on behalf of the Apache Software Foundation. For more 51 * information on the Apache Software Foundation, please see 52 * <http://www.apache.org/>;. 53 */ 54 package net.sf.cglib.util; 55 56 import net.sf.cglib.CodeGenTestCase; 57 import java.io.*; 58 import java.lang.reflect.Method; 59 import java.util.*; 60 import junit.framework.*; 61 62 /*** 63 * @author Chris Nokleberg <a href="mailto:chris@nokleberg.com">chris@nokleberg.com</a> 64 * @version $Id: TestParallelSorter.java,v 1.2 2003/09/18 17:23:29 herbyderby Exp $ 65 */ 66 public class TestParallelSorter extends CodeGenTestCase { 67 public void testSorts() throws Throwable { 68 Object[] data1 = getTestData(); 69 Object[] data2 = copy(data1); 70 Object[] data3 = copy(data1); 71 int[] idx1 = getIndexes(data1.length); 72 int[] idx2 = getIndexes(data1.length); 73 int[] idx3 = getIndexes(data1.length); 74 ParallelSorter p1 = ParallelSorter.create(new Object[]{ data1, idx1 }); 75 ParallelSorter p2 = ParallelSorter.create(new Object[]{ data2, idx2 }); 76 p1.quickSort(0); 77 p2.mergeSort(0); 78 compare(data1, data2); 79 compare(idx1, idx2); 80 p1.quickSort(1); 81 compare(idx1, idx3); 82 compare(data1, data3); 83 } 84 85 private void compare(Object[] data1, Object[] data2) { 86 assertTrue(data1.length == data2.length); 87 for (int i = 0; i < data1.length; i++) { 88 assertTrue(data1[i].equals(data2[i])); 89 } 90 } 91 92 private void compare(int[] data1, int[] data2) { 93 assertTrue(data1.length == data2.length); 94 for (int i = 0; i < data1.length; i++) { 95 assertTrue(data1[i] == data2[i]); 96 } 97 } 98 99 private int[] getIndexes(int len) { 100 int[] idx = new int[len]; 101 for (int i = 0; i < len; i++) { 102 idx[i] = i; 103 } 104 return idx; 105 } 106 107 private Object[] getTestData() throws IOException { 108 InputStream in = getClass().getResourceAsStream("words.txt"); 109 BufferedReader r = new BufferedReader(new InputStreamReader(in)); 110 List list = new ArrayList(); 111 String line; 112 int c = 0; 113 while ((line = r.readLine()) != null) { 114 list.add(line); 115 if (c++ == 20) break; 116 } 117 return list.toArray(); 118 } 119 120 private Object[] copy(Object[] data) { 121 Object[] copy = new Object[data.length]; 122 System.arraycopy(data, 0, copy, 0, data.length); 123 return copy; 124 } 125 126 public TestParallelSorter(String testName) { 127 super(testName); 128 } 129 130 public static void main(String[] args) { 131 junit.textui.TestRunner.run(suite()); 132 } 133 134 public static Test suite() { 135 return new TestSuite(TestParallelSorter.class); 136 } 137 }

This page was automatically generated by Maven