Commit graph

3 commits

Author SHA1 Message Date
Matthew Wild
ae84717255 util.hashring: Support associating arbitrary data with nodes
In this API, a 'node' is always a simple text string. Sometimes the caller may
have a more complex structure representing a node, but the hash ring is really
only concerned with the node's name.

This API change allows :add_nodes() to take a table of `node_name = value`
pairs, as well as the simple array of node names previously accepted.

The 'value' of the selected node is returned as a new second result from
:get_node().

If no value is passed when a node is added, it defaults to `true` (as before,
but this was never previously exposed).
2022-12-02 20:32:36 +00:00
Matthew Wild
d33904f7e9 util.hashring: tests: don't randomize order - they are written in a sequential style 2022-12-02 20:27:32 +00:00
Matthew Wild
46822c54b1 util.hashring: Add tests 2019-05-13 10:36:03 +01:00