Commits

Matt Chaput committed 50e1704

Raise an error if the user passes a Decimal to a NUMERIC field that doesn't
have decimal_places specified.

Comments (0)

Files changed (2)

         dc = self.decimal_places
         if dc and isinstance(x, (string_type, Decimal)):
             x = Decimal(x) * (10 ** dc)
+        elif isinstance(x, Decimal):
+            raise TypeError("Can't index a Decimal object unless you specified "
+                            "decimal_places on the field")
 
         try:
             x = self.numtype(x)

tests/test_indexing.py

             assert paths == ["/a", "/b"]
 
 
+def test_index_decimals():
+    from decimal import Decimal
+
+    schema = fields.Schema(name=fields.KEYWORD(stored=True),
+                           num=fields.NUMERIC(int))
+    ix = RamStorage().create_index(schema)
+
+    with ix.writer() as w:
+        with pytest.raises(TypeError):
+            w.add_document(name=u("hello"), num=Decimal("3.2"))
+
+    schema = fields.Schema(name=fields.KEYWORD(stored=True),
+                           num=fields.NUMERIC(Decimal, decimal_places=5))
+    ix = RamStorage().create_index(schema)
+    with ix.writer() as w:
+        w.add_document(name=u("hello"), num=Decimal("3.2"))
+
+
+