From 668ddad2ead9b09e0bc35c86fa6e233a9916b7c6 Mon Sep 17 00:00:00 2001 From: ggould-tri Date: Thu, 11 Jun 2020 10:28:14 -0400 Subject: [PATCH] Force older and newer yaml.dump to give the same output * pyyaml changed its default flow semantics in https://github.com/yaml/pyyaml/pull/256 * We must override the default with the magic tribool value `None` * Fixes #13541 --- examples/acrobot/dev/BUILD.bazel | 6 ------ examples/acrobot/dev/acrobot_io.py | 13 +++++++++++-- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/examples/acrobot/dev/BUILD.bazel b/examples/acrobot/dev/BUILD.bazel index 48f7f552a9d0..f5b04de1b30c 100644 --- a/examples/acrobot/dev/BUILD.bazel +++ b/examples/acrobot/dev/BUILD.bazel @@ -43,12 +43,6 @@ drake_py_unittest( data = [ ":test/example_scenario.yaml", ], - tags = [ - # TODO(jwnimmer-tri) This test is disabled because it fails on macOS - # due to formatting differences. We should make it more robust and - # then re-enable it. - "manual", - ], deps = [ ":acrobot_io", "//bindings/pydrake", diff --git a/examples/acrobot/dev/acrobot_io.py b/examples/acrobot/dev/acrobot_io.py index 3d455de999da..dd179126821e 100644 --- a/examples/acrobot/dev/acrobot_io.py +++ b/examples/acrobot/dev/acrobot_io.py @@ -2,6 +2,12 @@ import numpy as np +# This is a magic tribool value described at +# https://github.com/yaml/pyyaml/pull/256 +# and must be set this way for post- and pre- pyyaml#256 yaml dumpers to give +# the same output. +_FLOW_STYLE = None + def load_scenario(*, filename=None, data=None, scenario_name=None): """Given a scenario `filename` xor `data`, and optionally `scenario_name`, @@ -42,7 +48,9 @@ def save_scenario(*, scenario, scenario_name): ] else: scrubbed[key] = [float(x) for x in scenario[key]] - return yaml.dump({scenario_name: scrubbed}, Dumper=yaml.CDumper) + return yaml.dump({scenario_name: scrubbed}, + Dumper=yaml.CDumper, + default_flow_style=_FLOW_STYLE) def load_output(*, filename=None, data=None): @@ -68,4 +76,5 @@ def load_output(*, filename=None, data=None): def save_output(*, x_tape): """Given an acrobot output `x_tape`, returns a yaml-formatter str for it. """ - return yaml.dump({"x_tape": x_tape.tolist()}) + return yaml.dump({"x_tape": x_tape.tolist()}, + default_flow_style=_FLOW_STYLE)