forked from TrueCloudLab/neoneo-go
scripts: dump diff for OnPersist and PostPersist applog
Related to #3424. Signed-off-by: Anna Shaleva <shaleva.ann@nspcc.ru>
This commit is contained in:
parent
02ecbeb519
commit
0a3bf01a8f
1 changed files with 31 additions and 21 deletions
|
@ -118,32 +118,42 @@ func cliMain(c *cli.Context) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
fmt.Printf("state differs at %d, block %s\n", h, blk.Hash().StringLE())
|
fmt.Printf("state differs at %d, block %s\n", h, blk.Hash().StringLE())
|
||||||
|
dumpApplogDiff(true, blk.Hash(), a, b, ca, cb)
|
||||||
for _, t := range blk.Transactions {
|
for _, t := range blk.Transactions {
|
||||||
fmt.Printf("transaction %s:\n", t.Hash().StringLE())
|
dumpApplogDiff(false, t.Hash(), a, b, ca, cb)
|
||||||
la, err := ca.GetApplicationLog(t.Hash(), nil)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
lb, err := cb.GetApplicationLog(t.Hash(), nil)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
da := spew.Sdump(la)
|
|
||||||
db := spew.Sdump(lb)
|
|
||||||
diff, _ := difflib.GetUnifiedDiffString(difflib.UnifiedDiff{
|
|
||||||
A: difflib.SplitLines(da),
|
|
||||||
B: difflib.SplitLines(db),
|
|
||||||
FromFile: a,
|
|
||||||
FromDate: "",
|
|
||||||
ToFile: b,
|
|
||||||
ToDate: "",
|
|
||||||
Context: 1,
|
|
||||||
})
|
|
||||||
fmt.Println(diff)
|
|
||||||
}
|
}
|
||||||
return errors.New("different state found")
|
return errors.New("different state found")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func dumpApplogDiff(isBlock bool, container util.Uint256, a string, b string, ca *rpcclient.Client, cb *rpcclient.Client) error {
|
||||||
|
if isBlock {
|
||||||
|
fmt.Printf("block %s:\n", container.StringLE())
|
||||||
|
} else {
|
||||||
|
fmt.Printf("transaction %s:\n", container.StringLE())
|
||||||
|
}
|
||||||
|
la, err := ca.GetApplicationLog(container, nil)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
lb, err := cb.GetApplicationLog(container, nil)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
da := spew.Sdump(la)
|
||||||
|
db := spew.Sdump(lb)
|
||||||
|
diff, _ := difflib.GetUnifiedDiffString(difflib.UnifiedDiff{
|
||||||
|
A: difflib.SplitLines(da),
|
||||||
|
B: difflib.SplitLines(db),
|
||||||
|
FromFile: a,
|
||||||
|
FromDate: "",
|
||||||
|
ToFile: b,
|
||||||
|
ToDate: "",
|
||||||
|
Context: 1,
|
||||||
|
})
|
||||||
|
fmt.Println(diff)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
ctl := cli.NewApp()
|
ctl := cli.NewApp()
|
||||||
ctl.Name = "compare-states"
|
ctl.Name = "compare-states"
|
||||||
|
|
Loading…
Reference in a new issue