diff options
author | Flavio Castelli <fcastelli@suse.com> | 2018-02-18 14:25:07 +0100 |
---|---|---|
committer | Flavio Castelli <flavio@castelli.me> | 2018-02-19 15:01:10 +0100 |
commit | 0c5cd9c0460accc52e7bdca625d455741f1f6b3a (patch) | |
tree | b7f1b39eda18e6548fdc9ff84f8c854f390bdc00 /main.go | |
parent | ae717e132bec9b3d829b3725b29a37a8655ad9a8 (diff) | |
download | terraform-provider-libvirt-0c5cd9c0460accc52e7bdca625d455741f1f6b3a.tar terraform-provider-libvirt-0c5cd9c0460accc52e7bdca625d455741f1f6b3a.tar.gz |
Ensure libvirt connection is released
Deallocate the libvirt connect object before exit.
Fixes issue #266
Signed-off-by: Flavio Castelli <fcastelli@suse.com>
Diffstat (limited to 'main.go')
-rw-r--r-- | main.go | 18 |
1 files changed, 18 insertions, 0 deletions
@@ -3,11 +3,29 @@ package main import ( "github.com/dmacvicar/terraform-provider-libvirt/libvirt" "github.com/hashicorp/terraform/plugin" + "log" "math/rand" "time" ) func main() { + defer func() { + if libvirt.LibvirtClient != nil { + alive, err := libvirt.LibvirtClient.IsAlive() + if err != nil { + log.Printf("[ERROR] cannot determine libvirt connection status: %v", err) + } + if alive { + ret, err := libvirt.LibvirtClient.Close() + if err != nil { + log.Printf("[ERROR] cannot close libvirt connection %d - %v", ret, err) + } else { + libvirt.LibvirtClient = nil + } + } + } + }() + plugin.Serve(&plugin.ServeOpts{ ProviderFunc: libvirt.Provider, }) |