1 /* 2 * Copyright (c) 2007, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. Oracle designates this 8 * particular file as subject to the "Classpath" exception as provided 9 * by Oracle in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 22 * or visit www.oracle.com if you need additional information or have any 23 * questions. 24 */ 25 26 /* @test 27 @summary Test SimpleInstrument add(ModelPerformer[],int,int,int,int) method */ 28 29 import javax.sound.sampled.*; 30 31 import com.sun.media.sound.*; 32 33 public class AddModelPerformerArrayIntIntIntInt { 34 35 private static void assertEquals(Object a, Object b) throws Exception 36 { 37 if(!a.equals(b)) 38 throw new RuntimeException("assertEquals fails!"); 39 } 40 41 public static void main(String[] args) throws Exception { 42 43 SimpleInstrument instrument = new SimpleInstrument(); 44 45 ModelPerformer[] performers = new ModelPerformer[2]; 46 47 performers[0] = new ModelPerformer(); 48 performers[0].setExclusiveClass(1); 49 performers[0].setKeyFrom(36); 50 performers[0].setKeyTo(48); 51 performers[0].setVelFrom(16); 52 performers[0].setVelTo(80); 53 performers[0].setSelfNonExclusive(true); 54 performers[0].setDefaultConnectionsEnabled(false); 55 performers[0].getConnectionBlocks().add(new ModelConnectionBlock()); 56 performers[0].getOscillators().add(new ModelByteBufferWavetable(new ModelByteBuffer(new byte[] {1,2,3}))); 57 58 performers[1] = new ModelPerformer(); 59 performers[1].setExclusiveClass(0); 60 performers[1].setKeyFrom(12); 61 performers[1].setKeyTo(24); 62 performers[1].setVelFrom(20); 63 performers[1].setVelTo(90); 64 performers[1].setSelfNonExclusive(false); 65 performers[0].setDefaultConnectionsEnabled(true); 66 performers[1].getConnectionBlocks().add(new ModelConnectionBlock()); 67 performers[1].getOscillators().add(new ModelByteBufferWavetable(new ModelByteBuffer(new byte[] {1,2,3}))); 68 69 instrument.add(performers,18,40,20,75); 70 ModelPerformer[] performers2 = instrument.getPerformers(); 71 for (int i = 0; i < performers2.length; i++) { 72 assertEquals(performers[i].getConnectionBlocks(), performers2[i].getConnectionBlocks()); 73 assertEquals(performers[i].getExclusiveClass(), performers2[i].getExclusiveClass()); 74 if(performers[i].getKeyFrom() < 18) 75 assertEquals(18, performers2[i].getKeyFrom()); 76 else 77 assertEquals(performers[i].getKeyFrom(), performers2[i].getKeyFrom()); 78 if(performers[i].getKeyTo() > 40) 79 assertEquals(40, performers2[i].getKeyTo()); 80 else 81 assertEquals(performers[i].getKeyTo(), performers2[i].getKeyTo()); 82 if(performers[i].getVelFrom() < 20) 83 assertEquals(20, performers2[i].getVelFrom()); 84 else 85 assertEquals(performers[i].getVelFrom(), performers2[i].getVelFrom()); 86 if(performers[i].getVelTo() > 75) 87 assertEquals(75, performers2[i].getVelTo()); 88 else 89 assertEquals(performers[i].getVelTo(), performers2[i].getVelTo()); 90 assertEquals(performers[i].getOscillators(), performers2[i].getOscillators()); 91 assertEquals(performers[i].isSelfNonExclusive(), performers2[i].isSelfNonExclusive()); 92 assertEquals(performers[i].isDefaultConnectionsEnabled(), performers2[i].isDefaultConnectionsEnabled()); 93 } 94 } 95 }