Skip to content

Commit

Permalink
Use lists instead of sets, which SHOULD BE safe, and preserve order
Browse files Browse the repository at this point in the history
  • Loading branch information
Joey Leingang committed Aug 11, 2017
1 parent ea9d441 commit c193a25
Showing 1 changed file with 6 additions and 6 deletions.
12 changes: 6 additions & 6 deletions temporal_sqlalchemy/clock.py
Original file line number Diff line number Diff line change
Expand Up @@ -202,31 +202,31 @@ def build_clock_table(entity_table: sa.Table,
server_default=sa.func.current_timestamp()),
schema=schema)

entity_keys = set()
entity_keys = list()
for fk in util.foreign_key_to(entity_table, nullable=False):
# this is done to support arbitrary primary key shape on entity
clock_table.append_column(fk)
entity_keys.add(fk.key)
entity_keys.append(fk.key)

tick_entity_unique_name = util.truncate_identifier(
'%s_tick_entity_id_key' % clock_table_name
)
clock_table.append_constraint(
sa.UniqueConstraint(*(entity_keys | {'tick'}),
sa.UniqueConstraint(*(entity_keys + ['tick']),
name=tick_entity_unique_name)
)

if activity_class:
activity_keys = set()
activity_keys = list()
# support arbitrary shaped activity primary keys
for fk in util.foreign_key_to(activity_class.__table__,
prefix='activity',
nullable=False):
clock_table.append_column(fk)
activity_keys.add(fk.key)
activity_keys.append(fk.key)
# ensure we have DB constraint on clock <> activity uniqueness
clock_table.append_constraint(
sa.UniqueConstraint(*(activity_keys | entity_keys))
sa.UniqueConstraint(*(entity_keys + activity_keys))
)

return clock_table
Expand Down

0 comments on commit c193a25

Please sign in to comment.