storm-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "Jungtaek Lim (JIRA)" <>
Subject [jira] [Commented] (STORM-328) and Utils.get{Int,Long} are not in sync for floating point
Date Wed, 09 Jul 2014 08:16:05 GMT


Jungtaek Lim commented on STORM-328:

I'm also investigating this issue.

Definitely using Utils.getInt() with long value leads problem.

        System.out.println(new Long(Long.MAX_VALUE));
        System.out.println(new Long(Long.MAX_VALUE).intValue());

        System.out.println(new Long(Long.MIN_VALUE));
        System.out.println(new Long(Long.MIN_VALUE).intValue());

prints below
(My develop environment is OSX 10.8 with JDK 1.7.0_55.)

Implementation of Long.intValue(), it just type-cast long value to int.
It means type-casting picks upper? lower? 4 bytes from long but many situations we don't intend

> and Utils.get{Int,Long} are not in sync for floating point
> ----------------------------------------------------------------------
>                 Key: STORM-328
>                 URL:
>             Project: Apache Storm (Incubating)
>          Issue Type: Bug
>    Affects Versions: 0.9.2-incubating, 0.9.1-incubating,
>            Reporter: Robert Joseph Evans
>              Labels: newbie
> For most numeric configuration values has a type of Number listed, but the
values are parsed using Utils.getInt or Utils.getLong, which means if someone gave a floating
point number it would pass the ConfigValidation, but would blow up when it is used.  This
is most critical for values that Nimbus reads, but would be good to have them consistent everywhere.
> We should also check that getInt works properly for numbers that are larger then would
fit in an integer.
> Either we need to update Utils to be more lenient when looking at doubles, or we need
to make Config more strict, which may be difficult with the YAML and JSON parsing that happens,
where ints are often converted into longs.

This message was sent by Atlassian JIRA

View raw message