From 51868d8161cfac6af8e550e2a0f8d3afa861fe92 Mon Sep 17 00:00:00 2001 From: Roman Khimov Date: Thu, 12 May 2022 12:14:50 +0300 Subject: [PATCH] compare-states: add ignore-height flag and some tolerance to diff --- scripts/compare-states/compare-states.go | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/scripts/compare-states/compare-states.go b/scripts/compare-states/compare-states.go index c4305aa8f..5a5497f51 100644 --- a/scripts/compare-states/compare-states.go +++ b/scripts/compare-states/compare-states.go @@ -95,10 +95,18 @@ func cliMain(c *cli.Context) error { if err != nil { return err } + var refHeight = ha if ha != hb { - return errors.New("chains have different heights") + var diff = hb - ha + if ha > hb { + refHeight = hb + diff = ha - hb + } + if diff > 10 && !c.Bool("ignore-height") { // Allow some height drift. + return fmt.Errorf("chains have different heights: %d vs %d", ha, hb) + } } - h, err := bisectState(ca, cb, ha-1) + h, err := bisectState(ca, cb, refHeight-1) if err != nil { if errors.Is(err, errStateMatches) { return nil @@ -142,6 +150,12 @@ func main() { ctl.Version = "1.0" ctl.Usage = "compare-states RPC_A RPC_B" ctl.Action = cliMain + ctl.Flags = []cli.Flag{ + cli.BoolFlag{ + Name: "ignore-height, g", + Usage: "ignore height difference", + }, + } if err := ctl.Run(os.Args); err != nil { fmt.Fprintln(os.Stderr, err)