From 6def7776203b694aa3ab40f22a763fd48bb127d2 Mon Sep 17 00:00:00 2001 From: Kristin Laemmert Date: Tue, 23 Jul 2019 10:55:42 -0400 Subject: [PATCH] configs/configupgrade: fix panic on nil hilNode In some cases (see #22020 for a specific example), the parsed hilNode can be nil. This causes a series of panics. Instead, return an error and move on. --- configs/configupgrade/upgrade_expr.go | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/configs/configupgrade/upgrade_expr.go b/configs/configupgrade/upgrade_expr.go index 6bfa2566891c..d81ab42e87f6 100644 --- a/configs/configupgrade/upgrade_expr.go +++ b/configs/configupgrade/upgrade_expr.go @@ -110,17 +110,21 @@ Value: Subject: hcl1PosRange(filename, tv.Pos).Ptr(), }) } - if _, ok := hilNode.(*hilast.Output); !ok { - // hil.Parse usually produces an output, but it can sometimes - // produce an isolated expression if the input is entirely - // a single interpolation. - hilNode = &hilast.Output{ - Exprs: []hilast.Node{hilNode}, - Posx: hilNode.Pos(), + if hilNode != nil { + if _, ok := hilNode.(*hilast.Output); !ok { + // hil.Parse usually produces an output, but it can sometimes + // produce an isolated expression if the input is entirely + // a single interpolation. + if hilNode != nil { + hilNode = &hilast.Output{ + Exprs: []hilast.Node{hilNode}, + Posx: hilNode.Pos(), + } + } } + interpDiags := upgradeHeredocBody(&buf, hilNode.(*hilast.Output), filename, an) + diags = diags.Append(interpDiags) } - interpDiags := upgradeHeredocBody(&buf, hilNode.(*hilast.Output), filename, an) - diags = diags.Append(interpDiags) } if !strings.HasSuffix(body, "\n") { // The versions of HCL1 vendored into Terraform <=0.11