diff --git a/lwcomponent/catalog.go b/lwcomponent/catalog.go index a136d5644..9a4ae7717 100644 --- a/lwcomponent/catalog.go +++ b/lwcomponent/catalog.go @@ -210,7 +210,10 @@ func (c *Catalog) Install(component *CDKComponent) (err error) { return } - CreateHostInfo(componentDir, component.Description, component.Type) + component.HostInfo, err = CreateHostInfo(componentDir, component.Description, component.Type) + if err != nil { + return + } if component.ApiInfo != nil && (component.ApiInfo.ComponentType == BinaryType || component.ApiInfo.ComponentType == CommandType) { @@ -219,8 +222,6 @@ func (c *Catalog) Install(component *CDKComponent) (err error) { } } - component.HostInfo, err = NewHostInfo(componentDir) - return } @@ -349,6 +350,10 @@ func LoadLocalComponents() (components map[string]CDKComponent, err error) { // Prototype backwards compatibility prototypeState, err := LocalState() + if err != nil { + prototypeState = new(State) + err = nil + } prototypeComponents := make(map[string]Component, len(prototypeState.Components)) for _, component := range prototypeState.Components { prototypeComponents[component.Name] = component @@ -380,7 +385,12 @@ func LoadLocalComponents() (components map[string]CDKComponent, err error) { } components[hostInfo.Name()] = NewCDKComponent(hostInfo.Name(), devInfo.Desc, devInfo.ComponentType, nil, hostInfo) } else { - components[hostInfo.Name()] = NewCDKComponent(hostInfo.Name(), hostInfo.Description, hostInfo.ComponentType, nil, hostInfo) + components[hostInfo.Name()] = NewCDKComponent( + hostInfo.Name(), + hostInfo.Description, + hostInfo.ComponentType, + nil, + hostInfo) } } diff --git a/lwcomponent/catalog_test.go b/lwcomponent/catalog_test.go index 1bfa480ab..e735fe2e1 100644 --- a/lwcomponent/catalog_test.go +++ b/lwcomponent/catalog_test.go @@ -999,6 +999,16 @@ func CreateLocalComponent(componentName string, version string, development bool panic(err) } + info := lwcomponent.HostInfo{Dir: "", Description: "", ComponentType: lwcomponent.BinaryType} + data, err := json.Marshal(info) + if err != nil { + panic(err) + } + + if err := os.WriteFile(filepath.Join(path, lwcomponent.InfoFile), []byte(data), 0666); err != nil { + panic(err) + } + if err := os.WriteFile(filepath.Join(path, lwcomponent.SignatureFile), []byte(version), 0666); err != nil { panic(err) } diff --git a/lwcomponent/component_test.go b/lwcomponent/component_test.go index 2a6253d68..591a1c35a 100644 --- a/lwcomponent/component_test.go +++ b/lwcomponent/component_test.go @@ -231,13 +231,6 @@ var currentSignatureTests = []currentSignatureTest{ Component: mockComponent2, Error: errors.New("component signature file does not exist"), }, - { - Name: "bad", - Component: mockComponent, - Signature: "-", - Expected: []byte{}, - Error: errors.New("unable to decode component signature"), - }, { Name: "ok", Component: mockComponent,