Merge pull request #7633 from hashicorp/fix_vagrant_libvirt_package

Work around bug in libvirt-vagrant plugin
This commit is contained in:
Adrien Delorme 2019-05-13 15:02:27 +02:00 committed by GitHub
commit 8d4b9116b5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 10 additions and 2 deletions

View File

@ -6,7 +6,6 @@ import (
"log" "log"
"os" "os"
"os/exec" "os/exec"
"path/filepath"
"regexp" "regexp"
"strings" "strings"
@ -71,7 +70,16 @@ func (d *Vagrant_2_2_Driver) Destroy(id string) error {
// Calls "vagrant package" // Calls "vagrant package"
func (d *Vagrant_2_2_Driver) Package(args []string) error { func (d *Vagrant_2_2_Driver) Package(args []string) error {
args = append(args, "--output", filepath.Join(d.VagrantCWD, "package.box")) // Ideally we'd pass vagrantCWD into the package command but
// we have to change directory into the vagrant cwd instead in order to
// work around an upstream bug with the vagrant-libvirt plugin.
// We can stop doing this when
// https://github.com/vagrant-libvirt/vagrant-libvirt/issues/765
// is fixed.
oldDir, _ := os.Getwd()
os.Chdir(d.VagrantCWD)
defer os.Chdir(oldDir)
args = append(args, "--output", "package.box")
_, _, err := d.vagrantCmd(append([]string{"package"}, args...)...) _, _, err := d.vagrantCmd(append([]string{"package"}, args...)...)
return err return err
} }