- identity.record_id() should never return unhashable types!
- copy constructor (teaching
__init__()
to take an object might work), to be used byMultiFieldSelector([]).get()
FieldSelector
should define__or__()
to return aMultiFieldSelector
- exceptions:
- should return context information when marshaling in (perhaps
containing
FieldSelector
objects)
- should return context information when marshaling in (perhaps
containing
- dealing with unexpectedly bad input data:
from_json
variant/option which scrubs data which fails in any way, returning objects which could be parsed and left-over JSON which couldn't be parsed.- support for polymorphic JSON, either through a flag field (special field is mapped to type) or via subclass duck-typing (subclass is selected automatically based on keys seen on input)
- collections:
- Support
DictCollection
key typing - implement
SetCollection
(probably as DictCollection's that map values to themselves)
- Support
- property traits for basic XML marshal support (in case the 90's calls and wants to send us some data)
- the diff iterator could notice if items have moved keys in a
collection and emit a MOVED or RENAMED
DiffInfo
- refactor all the ugly
if isinstance(x, Y):
blocks to usesimplegeneric
instead - provide a collection of ready-made typed properties; this will probably involve changing the way that property types are distinguished and selected
- avro marshaling
- property traits for schema systems which number attributes, to support thrift
The following cases are known to be missing tests:
- the examples in the intro could do with a regression test
- JSON marshaling tests;
Record
types with attributes which areRecord
types that implementjson_data
without derivingJsonRecord
, with and without theextraneous
parameter.RecordList
types with a member type which implementsjson_data
- marshaling out native dicts/lists with
Record
members (marshall in will not be supported without customjson_to_initkwargs
methods) - marshaling in & out
long
values - check
json_name=None
suppresses marshal out via JSON - using
from_json
with json strings (not JSON data) - double-check setting
extraneous
suppresses marshal out
- required, but lazy attributes
del record.property
andrecord.property = None
FieldSelector
withNone
components indicating "all members of a collection"MultiFieldSelector
unspecifically needs more tests, because parts of its recursive constructor aren't reached that I thought should be by its test case. They should be reached, or the code simplified.- Untested Exception Paths:
- bad combinations of attribute traits
DiffInfo
made with missing field selector properties- mis-use of
ListProperty
- multiple inheritance between
Record
types defining clashing properties