// Tags: JDK1.2
// Copyright (C) 2004 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.wonka.lang.Float;
import gnu.testlet.TestHarness;
import gnu.testlet.Testlet;
/**
* Some checks for the valueOf() method in the {@link Float} class.
*/
public class valueOf implements Testlet
{
/**
* Runs the test using the specified harness.
*
* @param harness the test harness (<code>null</code> not permitted).
*/
public void test(TestHarness harness)
{
testRegular(harness);
testInfinities(harness);
testNaN(harness);
}
/**
* Tests some regular values.
*
* @param harness the test harness.
*/
public void testRegular(TestHarness harness)
{
harness.check(Float.valueOf("1.0"), new Float(1.0f));
harness.check(Float.valueOf("+1.0"), new Float(1.0f));
harness.check(Float.valueOf("-1.0"), new Float(-1.0f));
harness.check(Float.valueOf(" 1.0 "), new Float(1.0f));
harness.check(Float.valueOf(" -1.0 "), new Float(-1.0f));
harness.check(Float.valueOf("2."), new Float(2.0f));
harness.check(Float.valueOf(".3"), new Float(0.3f));
harness.check(Float.valueOf("1e-9"), new Float(1e-9f));
harness.check(Float.valueOf("1e37"), new Float(1e37f));
// test some bad formats
try
{
/* Float f = */ Float.valueOf("");
harness.check(false);
}
catch (NumberFormatException e)
{
harness.check(true);
}
try
{
/* Float f = */ Float.valueOf("X");
harness.check(false);
}
catch (NumberFormatException e)
{
harness.check(true);
}
try
{
/* Float f = */ Float.valueOf("e");
harness.check(false);
}
catch (NumberFormatException e)
{
harness.check(true);
}
try
{
/* Float f = */ Float.valueOf("+ 1.0");
harness.check(false);
}
catch (NumberFormatException e)
{
harness.check(true);
}
try
{
/* Float f = */ Float.valueOf("- 1.0");
harness.check(false);
}
catch (NumberFormatException e)
{
harness.check(true);
}
// null argument should throw NullPointerException
try
{
/* Float f = */ Float.valueOf(null);
harness.check(false);
}
catch (NullPointerException e)
{
harness.check(true);
}
}
/**
* Some checks for values that should parse to Double.POSITIVE_INFINITY
* or Double.NEGATIVE_INFINITY.
*
* @param harness the test harness.
*/
public void testInfinities(TestHarness harness)
{
try
{
harness.check(Float.valueOf("Infinity"), new Float(Float.POSITIVE_INFINITY));
harness.check(Float.valueOf("+Infinity"), new Float(Float.POSITIVE_INFINITY));
harness.check(Float.valueOf("-Infinity"), new Float(Float.NEGATIVE_INFINITY));
harness.check(Float.valueOf(" +Infinity "), new Float(Float.POSITIVE_INFINITY));
harness.check(Float.valueOf(" -Infinity "), new Float(Float.NEGATIVE_INFINITY));
}
catch (Exception e)
{
harness.check(false);
harness.debug(e);
}
harness.check(Float.valueOf("1e1000"), new Float(Float.POSITIVE_INFINITY));
harness.check(Float.valueOf("-1e1000"), new Float(Float.NEGATIVE_INFINITY));
}
/**
* Some checks for 'NaN' values.
*
* @param harness the test harness.
*/
public void testNaN(TestHarness harness)
{
try
{
harness.check(Float.isNaN(Float.valueOf("NaN").floatValue()));
harness.check(Float.isNaN(Float.valueOf("+NaN").floatValue()));
harness.check(Float.isNaN(Float.valueOf("-NaN").floatValue()));
harness.check(Float.isNaN(Float.valueOf(" +NaN ").floatValue()));
harness.check(Float.isNaN(Float.valueOf(" -NaN ").floatValue()));
}
catch (Exception e)
{
harness.check(false);
harness.debug(e);
}
}
}