1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
|
// Tags: JDK1.2
// Copyright (C) 2005 David Gilbert <david.gilbert@object-refinery.com>
// Mauve is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2, or (at your option)
// any later version.
// Mauve is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with Mauve; see the file COPYING. If not, write to
// the Free Software Foundation, 59 Temple Place - Suite 330,
// Boston, MA 02111-1307, USA. */
package gnu.testlet.java.awt.image.BandedSampleModel;
import gnu.testlet.TestHarness;
import gnu.testlet.Testlet;
import java.awt.image.BandedSampleModel;
import java.awt.image.DataBuffer;
import java.awt.image.DataBufferInt;
/**
* Some checks for the <code>getSample()()</code> method in the
* {@link BandedSampleModel} class.
*/
public class getSample implements Testlet
{
/**
* Runs the test using the specified harness.
*
* @param harness the test harness (<code>null</code> not permitted).
*/
public void test(TestHarness harness)
{
BandedSampleModel m = new BandedSampleModel(DataBuffer.TYPE_INT, 2, 3, 2);
DataBufferInt b = new DataBufferInt(6, 2);
b.setElem(0, 0, 0xA0);
b.setElem(0, 1, 0xA1);
b.setElem(0, 2, 0xA2);
b.setElem(0, 3, 0xA3);
b.setElem(0, 4, 0xA4);
b.setElem(0, 5, 0xA5);
b.setElem(1, 0, 0xB0);
b.setElem(1, 1, 0xB1);
b.setElem(1, 2, 0xB2);
b.setElem(1, 3, 0xB3);
b.setElem(1, 4, 0xB4);
b.setElem(1, 5, 0xB5);
harness.check(m.getSample(0, 0, 0, b), 0xA0);
harness.check(m.getSample(1, 0, 0, b), 0xA1);
harness.check(m.getSample(0, 1, 0, b), 0xA2);
harness.check(m.getSample(1, 1, 0, b), 0xA3);
harness.check(m.getSample(0, 2, 0, b), 0xA4);
harness.check(m.getSample(1, 2, 0, b), 0xA5);
harness.check(m.getSample(0, 0, 1, b), 0xB0);
harness.check(m.getSample(1, 0, 1, b), 0xB1);
harness.check(m.getSample(0, 1, 1, b), 0xB2);
harness.check(m.getSample(1, 1, 1, b), 0xB3);
harness.check(m.getSample(0, 2, 1, b), 0xB4);
harness.check(m.getSample(1, 2, 1, b), 0xB5);
// try negative x
boolean pass = false;
try
{
/* int sample = */ m.getSample(-1, 0, 0, b);
}
catch (ArrayIndexOutOfBoundsException e)
{
pass = true;
}
harness.check(pass);
// try negative y
pass = false;
try
{
/* int sample = */ m.getSample(0, -1, 0, b);
}
catch (ArrayIndexOutOfBoundsException e)
{
pass = true;
}
harness.check(pass);
// try negative band
pass = false;
try
{
/* int sample = */ m.getSample(0, 0, -1, b);
}
catch (ArrayIndexOutOfBoundsException e)
{
pass = true;
}
harness.check(pass);
// try null buffer
pass = false;
try
{
/* int sample = */ m.getSample(0, 0, 0, null);
}
catch (NullPointerException e)
{
pass = true;
}
harness.check(pass);
}
}
|