Max Neunhöffer created MESOS-3518:
-------------------------------------

             Summary: Assertions that compare doubles with == can fail due to 
rounding issues and can crash the master.
                 Key: MESOS-3518
                 URL: https://issues.apache.org/jira/browse/MESOS-3518
             Project: Mesos
          Issue Type: Bug
          Components: master
    Affects Versions: 0.24.1, 0.24.0, 0.23.1, 0.23.0
            Reporter: Max Neunhöffer
            Priority: Minor


mesos-0.23.0/src/common/resources.cpp has
  CHECK(result.cpus() == cpus() &&
        result.mem() == mem() &&
        result.disk() == disk() &&
        result.ports() == ports());
at around line 869. Sometimes, rounding errors can trigger this check to fail 
because of the cpus() part. One should take the absolute value of the 
difference and compare with a small value to avoid this problem. The same 
problem could be true in various places, so far I have not yet checked.
Seems to be present in all versions I checked. I could trigger this by asking 
for some resource value of cpus(*):0.2



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to