2017-08-05 18:37:14 +00:00
|
|
|
// Copyright 2016-2017, Pulumi Corporation. All rights reserved.
|
|
|
|
|
|
|
|
package integration
|
2017-07-13 19:19:17 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
2018-01-06 01:40:41 +00:00
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
"os/exec"
|
|
|
|
"path/filepath"
|
2017-07-13 19:19:17 +00:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2017-07-13 19:40:10 +00:00
|
|
|
|
2017-09-22 02:18:21 +00:00
|
|
|
"github.com/pulumi/pulumi/pkg/util/contract"
|
2017-07-13 19:19:17 +00:00
|
|
|
)
|
|
|
|
|
2017-08-05 18:37:14 +00:00
|
|
|
func TestPrefixer(t *testing.T) {
|
2017-07-13 19:19:17 +00:00
|
|
|
byts := make([]byte, 0, 1000)
|
|
|
|
buf := bytes.NewBuffer(byts)
|
|
|
|
prefixer := newPrefixer(buf, "OK: ")
|
2017-07-13 19:40:10 +00:00
|
|
|
_, err := prefixer.Write([]byte("\nsadsada\n\nasdsadsa\nasdsadsa\n"))
|
2018-01-08 21:12:50 +00:00
|
|
|
contract.AssertNoError(err)
|
2017-07-13 19:19:17 +00:00
|
|
|
assert.Equal(t, []byte("OK: \nOK: sadsada\nOK: \nOK: asdsadsa\nOK: asdsadsa\n"), buf.Bytes())
|
|
|
|
}
|
2018-01-06 01:40:41 +00:00
|
|
|
|
|
|
|
// Test that RunCommand writes the command's output to a log file.
|
|
|
|
func TestRunCommandLog(t *testing.T) {
|
|
|
|
// Try to find node on the path. We need a program to run, and node is probably
|
|
|
|
// available on all platforms where we're testing. If it's not found, skip the test.
|
|
|
|
node, err := exec.LookPath("node")
|
|
|
|
if err != nil {
|
|
|
|
t.Skip("Couldn't find Node on PATH")
|
|
|
|
}
|
|
|
|
|
|
|
|
opts := &ProgramTestOptions{
|
|
|
|
Stdout: os.Stdout,
|
|
|
|
Stderr: os.Stderr,
|
|
|
|
}
|
|
|
|
|
|
|
|
tempdir, err := ioutil.TempDir("", "test")
|
2018-01-08 21:12:50 +00:00
|
|
|
contract.AssertNoError(err)
|
2018-01-06 01:40:41 +00:00
|
|
|
defer os.RemoveAll(tempdir)
|
|
|
|
|
|
|
|
args := []string{node, "-e", "console.log('output from node');"}
|
|
|
|
err = RunCommand(nil, "node", args, tempdir, opts)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
|
|
|
|
matches, err := filepath.Glob(filepath.Join(tempdir, "command-output", "node.*"))
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.Equal(t, 1, len(matches))
|
|
|
|
|
|
|
|
output, err := ioutil.ReadFile(matches[0])
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.Equal(t, "output from node\n", string(output))
|
|
|
|
}
|