summaryrefslogtreecommitdiff
path: root/main.go
diff options
context:
space:
mode:
authorFlavio Castelli <fcastelli@suse.com>2018-02-18 14:25:07 +0100
committerFlavio Castelli <flavio@castelli.me>2018-02-19 15:01:10 +0100
commit0c5cd9c0460accc52e7bdca625d455741f1f6b3a (patch)
treeb7f1b39eda18e6548fdc9ff84f8c854f390bdc00 /main.go
parentae717e132bec9b3d829b3725b29a37a8655ad9a8 (diff)
downloadterraform-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.go18
1 files changed, 18 insertions, 0 deletions
diff --git a/main.go b/main.go
index 08194c95..d84366ac 100644
--- a/main.go
+++ b/main.go
@@ -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,
})