|
@@ -1,9 +1,8 @@
|
|
|
import datetime
|
|
import datetime
|
|
|
import json
|
|
import json
|
|
|
-import urllib
|
|
|
|
|
from collections import OrderedDict
|
|
from collections import OrderedDict
|
|
|
|
|
+from decimal import Decimal
|
|
|
from itertools import count, groupby
|
|
from itertools import count, groupby
|
|
|
-from typing import Any, Dict, List, Tuple
|
|
|
|
|
|
|
|
|
|
from django.core.serializers import serialize
|
|
from django.core.serializers import serialize
|
|
|
from django.db.models import Count, OuterRef, Subquery
|
|
from django.db.models import Count, OuterRef, Subquery
|
|
@@ -195,15 +194,15 @@ def to_meters(length, unit):
|
|
|
"""
|
|
"""
|
|
|
Convert the given length to meters.
|
|
Convert the given length to meters.
|
|
|
"""
|
|
"""
|
|
|
- length = int(length)
|
|
|
|
|
- if length < 0:
|
|
|
|
|
- raise ValueError("Length must be a positive integer")
|
|
|
|
|
|
|
+ try:
|
|
|
|
|
+ if length < 0:
|
|
|
|
|
+ raise ValueError("Length must be a positive number")
|
|
|
|
|
+ except TypeError:
|
|
|
|
|
+ raise TypeError(f"Invalid value '{length}' for length (must be a number)")
|
|
|
|
|
|
|
|
valid_units = CableLengthUnitChoices.values()
|
|
valid_units = CableLengthUnitChoices.values()
|
|
|
if unit not in valid_units:
|
|
if unit not in valid_units:
|
|
|
- raise ValueError(
|
|
|
|
|
- "Unknown unit {}. Must be one of the following: {}".format(unit, ', '.join(valid_units))
|
|
|
|
|
- )
|
|
|
|
|
|
|
+ raise ValueError(f"Unknown unit {unit}. Must be one of the following: {', '.join(valid_units)}")
|
|
|
|
|
|
|
|
if unit == CableLengthUnitChoices.UNIT_KILOMETER:
|
|
if unit == CableLengthUnitChoices.UNIT_KILOMETER:
|
|
|
return length * 1000
|
|
return length * 1000
|
|
@@ -212,11 +211,11 @@ def to_meters(length, unit):
|
|
|
if unit == CableLengthUnitChoices.UNIT_CENTIMETER:
|
|
if unit == CableLengthUnitChoices.UNIT_CENTIMETER:
|
|
|
return length / 100
|
|
return length / 100
|
|
|
if unit == CableLengthUnitChoices.UNIT_MILE:
|
|
if unit == CableLengthUnitChoices.UNIT_MILE:
|
|
|
- return length * 1609.344
|
|
|
|
|
|
|
+ return length * Decimal(1609.344)
|
|
|
if unit == CableLengthUnitChoices.UNIT_FOOT:
|
|
if unit == CableLengthUnitChoices.UNIT_FOOT:
|
|
|
- return length * 0.3048
|
|
|
|
|
|
|
+ return length * Decimal(0.3048)
|
|
|
if unit == CableLengthUnitChoices.UNIT_INCH:
|
|
if unit == CableLengthUnitChoices.UNIT_INCH:
|
|
|
- return length * 0.3048 * 12
|
|
|
|
|
|
|
+ return length * Decimal(0.3048) * 12
|
|
|
raise ValueError(f"Unknown unit {unit}. Must be 'km', 'm', 'cm', 'mi', 'ft', or 'in'.")
|
|
raise ValueError(f"Unknown unit {unit}. Must be 'km', 'm', 'cm', 'mi', 'ft', or 'in'.")
|
|
|
|
|
|
|
|
|
|
|