2017-01-18 01:07:50 +03:00
|
|
|
// Copyright 2017 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2017-01-27 23:39:07 +03:00
|
|
|
package dep
|
2016-12-30 08:39:08 +03:00
|
|
|
|
|
|
|
import (
|
2017-04-26 15:21:11 +03:00
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
2016-12-30 08:39:08 +03:00
|
|
|
"path/filepath"
|
2017-02-27 19:16:42 +03:00
|
|
|
"strings"
|
2016-12-30 08:39:08 +03:00
|
|
|
"testing"
|
2017-01-27 23:39:07 +03:00
|
|
|
|
2017-05-10 07:24:12 +03:00
|
|
|
"github.com/golang/dep/internal/test"
|
2017-03-09 22:28:42 +03:00
|
|
|
"github.com/pkg/errors"
|
2016-12-30 08:39:08 +03:00
|
|
|
)
|
|
|
|
|
2017-02-27 19:16:42 +03:00
|
|
|
const safeWriterProject = "safewritertest"
|
2017-03-21 19:23:53 +03:00
|
|
|
const safeWriterGoldenManifest = "txn_writer/expected_manifest.toml"
|
2017-03-20 21:14:02 +03:00
|
|
|
const safeWriterGoldenLock = "txn_writer/expected_lock.toml"
|
2017-02-27 19:16:42 +03:00
|
|
|
|
|
|
|
func TestSafeWriter_BadInput_MissingRoot(t *testing.T) {
|
2017-01-28 14:24:33 +03:00
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
2017-02-27 19:16:42 +03:00
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
2016-12-30 08:39:08 +03:00
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(nil, nil, nil, VendorOnChanged)
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write("", pc.SourceManager, true, discardLogger())
|
2016-12-30 08:39:08 +03:00
|
|
|
|
2017-02-27 19:16:42 +03:00
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should have errored without a root path, but did not")
|
|
|
|
} else if !strings.Contains(err.Error(), "root path") {
|
|
|
|
t.Fatalf("expected root path error, got %s", err.Error())
|
2016-12-30 08:39:08 +03:00
|
|
|
}
|
2017-02-27 19:16:42 +03:00
|
|
|
}
|
2017-03-09 22:28:42 +03:00
|
|
|
|
2017-02-27 19:16:42 +03:00
|
|
|
func TestSafeWriter_BadInput_MissingSourceManager(t *testing.T) {
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
2017-03-18 04:53:00 +03:00
|
|
|
pc.CopyFile(LockName, safeWriterGoldenLock)
|
|
|
|
pc.Load()
|
2017-02-27 19:16:42 +03:00
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(nil, nil, pc.Project.Lock, VendorAlways)
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write(pc.Project.AbsRoot, nil, true, discardLogger())
|
2017-03-09 22:28:42 +03:00
|
|
|
|
2017-02-27 19:16:42 +03:00
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should have errored without a source manager when forceVendor is true, but did not")
|
|
|
|
} else if !strings.Contains(err.Error(), "SourceManager") {
|
|
|
|
t.Fatalf("expected SourceManager error, got %s", err.Error())
|
2016-12-30 08:39:08 +03:00
|
|
|
}
|
2017-02-27 19:16:42 +03:00
|
|
|
}
|
|
|
|
|
2017-03-18 04:53:00 +03:00
|
|
|
func TestSafeWriter_BadInput_ForceVendorMissingLock(t *testing.T) {
|
2017-02-27 19:16:42 +03:00
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
_, err := NewSafeWriter(nil, nil, nil, VendorAlways)
|
2017-02-27 19:16:42 +03:00
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should have errored without a lock when forceVendor is true, but did not")
|
2017-03-18 04:53:00 +03:00
|
|
|
} else if !strings.Contains(err.Error(), "newLock") {
|
|
|
|
t.Fatalf("expected newLock error, got %s", err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSafeWriter_BadInput_OldLockOnly(t *testing.T) {
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
pc.CopyFile(LockName, safeWriterGoldenLock)
|
|
|
|
pc.Load()
|
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
_, err := NewSafeWriter(nil, pc.Project.Lock, nil, VendorAlways)
|
2017-03-18 04:53:00 +03:00
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should have errored with only an old lock, but did not")
|
|
|
|
} else if !strings.Contains(err.Error(), "oldLock") {
|
|
|
|
t.Fatalf("expected oldLock error, got %s", err.Error())
|
2016-12-30 08:39:08 +03:00
|
|
|
}
|
2017-02-27 19:16:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestSafeWriter_BadInput_NonexistentRoot(t *testing.T) {
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(nil, nil, nil, VendorOnChanged)
|
2017-02-27 19:16:42 +03:00
|
|
|
|
|
|
|
missingroot := filepath.Join(pc.Project.AbsRoot, "nonexistent")
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write(missingroot, pc.SourceManager, true, discardLogger())
|
2017-02-27 19:16:42 +03:00
|
|
|
|
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should have errored with nonexistent dir for root path, but did not")
|
|
|
|
} else if !strings.Contains(err.Error(), "does not exist") {
|
|
|
|
t.Fatalf("expected does not exist error, got %s", err.Error())
|
2017-03-09 22:28:42 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-27 19:16:42 +03:00
|
|
|
func TestSafeWriter_BadInput_RootIsFile(t *testing.T) {
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(nil, nil, nil, VendorOnChanged)
|
2017-02-27 19:16:42 +03:00
|
|
|
|
|
|
|
fileroot := pc.CopyFile("fileroot", "txn_writer/badinput_fileroot")
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write(fileroot, pc.SourceManager, true, discardLogger())
|
2017-02-27 19:16:42 +03:00
|
|
|
|
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should have errored when root path is a file, but did not")
|
|
|
|
} else if !strings.Contains(err.Error(), "does not exist") {
|
|
|
|
t.Fatalf("expected does not exist error, got %s", err.Error())
|
|
|
|
}
|
|
|
|
}
|
2017-03-09 22:28:42 +03:00
|
|
|
|
2017-03-18 04:53:00 +03:00
|
|
|
func TestSafeWriter_Manifest(t *testing.T) {
|
2017-03-09 22:28:42 +03:00
|
|
|
test.NeedsExternalNetwork(t)
|
|
|
|
test.NeedsGit(t)
|
|
|
|
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
pc.CopyFile(ManifestName, safeWriterGoldenManifest)
|
|
|
|
pc.Load()
|
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(pc.Project.Manifest, nil, nil, VendorOnChanged)
|
2017-03-09 22:28:42 +03:00
|
|
|
|
|
|
|
// Verify prepared actions
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasManifest() {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Expected the payload to contain the manifest")
|
|
|
|
}
|
2017-05-01 14:34:38 +03:00
|
|
|
if sw.HasLock() {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Did not expect the payload to contain the lock")
|
|
|
|
}
|
2017-05-17 02:06:54 +03:00
|
|
|
if sw.writeVendor {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Did not expect the payload to contain the vendor directory")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Write changes
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write(pc.Project.AbsRoot, pc.SourceManager, true, discardLogger())
|
2017-03-09 22:28:42 +03:00
|
|
|
h.Must(errors.Wrap(err, "SafeWriter.Write failed"))
|
|
|
|
|
|
|
|
// Verify file system changes
|
|
|
|
if err := pc.ManifestShouldMatchGolden(safeWriterGoldenManifest); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.LockShouldNotExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorShouldNotExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
2016-12-30 08:39:08 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-09 22:28:42 +03:00
|
|
|
func TestSafeWriter_ManifestAndUnmodifiedLock(t *testing.T) {
|
2017-01-27 23:39:07 +03:00
|
|
|
test.NeedsExternalNetwork(t)
|
|
|
|
test.NeedsGit(t)
|
2016-12-30 08:39:08 +03:00
|
|
|
|
2017-01-28 14:24:33 +03:00
|
|
|
h := test.NewHelper(t)
|
2017-02-02 05:18:35 +03:00
|
|
|
defer h.Cleanup()
|
|
|
|
|
2017-03-09 22:28:42 +03:00
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
pc.CopyFile(ManifestName, safeWriterGoldenManifest)
|
|
|
|
pc.CopyFile(LockName, safeWriterGoldenLock)
|
|
|
|
pc.Load()
|
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(pc.Project.Manifest, pc.Project.Lock, pc.Project.Lock, VendorOnChanged)
|
2017-03-09 22:28:42 +03:00
|
|
|
|
|
|
|
// Verify prepared actions
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasManifest() {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Expected the payload to contain the manifest")
|
|
|
|
}
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasLock() {
|
2017-03-18 04:53:00 +03:00
|
|
|
t.Fatal("Expected the payload to contain the lock.")
|
2017-03-09 22:28:42 +03:00
|
|
|
}
|
2017-06-17 06:27:02 +03:00
|
|
|
if sw.writeLock {
|
|
|
|
t.Fatal("Did not expect that the writer should plan to write the lock")
|
|
|
|
}
|
2017-05-17 02:06:54 +03:00
|
|
|
if sw.writeVendor {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Did not expect the payload to contain the vendor directory")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Write changes
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write(pc.Project.AbsRoot, pc.SourceManager, true, discardLogger())
|
2017-03-09 22:28:42 +03:00
|
|
|
h.Must(errors.Wrap(err, "SafeWriter.Write failed"))
|
|
|
|
|
|
|
|
// Verify file system changes
|
|
|
|
if err := pc.ManifestShouldMatchGolden(safeWriterGoldenManifest); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.LockShouldMatchGolden(safeWriterGoldenLock); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorShouldNotExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSafeWriter_ManifestAndUnmodifiedLockWithForceVendor(t *testing.T) {
|
|
|
|
test.NeedsExternalNetwork(t)
|
|
|
|
test.NeedsGit(t)
|
|
|
|
|
|
|
|
h := test.NewHelper(t)
|
2017-01-28 14:24:33 +03:00
|
|
|
defer h.Cleanup()
|
2016-12-30 08:39:08 +03:00
|
|
|
|
2017-03-09 22:28:42 +03:00
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
pc.CopyFile(ManifestName, safeWriterGoldenManifest)
|
|
|
|
pc.CopyFile(LockName, safeWriterGoldenLock)
|
|
|
|
pc.Load()
|
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(pc.Project.Manifest, pc.Project.Lock, pc.Project.Lock, VendorAlways)
|
2017-03-09 22:28:42 +03:00
|
|
|
|
|
|
|
// Verify prepared actions
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasManifest() {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Expected the payload to contain the manifest")
|
2016-12-30 08:39:08 +03:00
|
|
|
}
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasLock() {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Expected the payload to contain the lock")
|
|
|
|
}
|
2017-06-17 06:27:02 +03:00
|
|
|
if sw.writeLock {
|
|
|
|
t.Fatal("Did not expect that the writer should plan to write the lock")
|
|
|
|
}
|
2017-05-17 02:06:54 +03:00
|
|
|
if !sw.writeVendor {
|
2017-03-18 04:53:00 +03:00
|
|
|
t.Fatal("Expected the payload to contain the vendor directory")
|
2017-03-09 22:28:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Write changes
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write(pc.Project.AbsRoot, pc.SourceManager, true, discardLogger())
|
2017-03-09 22:28:42 +03:00
|
|
|
h.Must(errors.Wrap(err, "SafeWriter.Write failed"))
|
|
|
|
|
|
|
|
// Verify file system changes
|
|
|
|
if err := pc.ManifestShouldMatchGolden(safeWriterGoldenManifest); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.LockShouldMatchGolden(safeWriterGoldenLock); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorShouldExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2017-03-18 04:53:00 +03:00
|
|
|
if err := pc.VendorFileShouldExist("github.com/sdboyer/dep-test"); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2017-03-09 22:28:42 +03:00
|
|
|
}
|
|
|
|
|
2017-03-18 04:53:00 +03:00
|
|
|
func TestSafeWriter_ModifiedLock(t *testing.T) {
|
2017-03-09 22:28:42 +03:00
|
|
|
test.NeedsExternalNetwork(t)
|
|
|
|
test.NeedsGit(t)
|
|
|
|
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
pc.CopyFile(LockName, safeWriterGoldenLock)
|
|
|
|
pc.Load()
|
2016-12-30 08:39:08 +03:00
|
|
|
|
2017-03-18 04:53:00 +03:00
|
|
|
originalLock := new(Lock)
|
|
|
|
*originalLock = *pc.Project.Lock
|
2017-05-27 06:50:29 +03:00
|
|
|
originalLock.SolveMeta.InputsDigest = []byte{} // zero out the input hash to ensure non-equivalency
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(nil, originalLock, pc.Project.Lock, VendorOnChanged)
|
2017-03-09 22:28:42 +03:00
|
|
|
|
|
|
|
// Verify prepared actions
|
2017-05-01 14:34:38 +03:00
|
|
|
if sw.HasManifest() {
|
2017-05-22 20:41:13 +03:00
|
|
|
t.Fatal("Did not expect the manifest to be written")
|
2017-03-09 22:28:42 +03:00
|
|
|
}
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasLock() {
|
2017-06-17 06:27:02 +03:00
|
|
|
t.Fatal("Expected the payload to contain the lock")
|
|
|
|
}
|
|
|
|
if !sw.writeLock {
|
2017-05-22 20:41:13 +03:00
|
|
|
t.Fatal("Expected that the writer should plan to write the lock")
|
2017-03-09 22:28:42 +03:00
|
|
|
}
|
2017-05-17 02:06:54 +03:00
|
|
|
if !sw.writeVendor {
|
2017-05-22 20:41:13 +03:00
|
|
|
t.Fatal("Expected that the writer should plan to write the vendor directory")
|
2017-03-09 22:28:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Write changes
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write(pc.Project.AbsRoot, pc.SourceManager, true, discardLogger())
|
2017-03-09 22:28:42 +03:00
|
|
|
h.Must(errors.Wrap(err, "SafeWriter.Write failed"))
|
|
|
|
|
|
|
|
// Verify file system changes
|
|
|
|
if err := pc.ManifestShouldNotExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2017-03-18 04:53:00 +03:00
|
|
|
if err := pc.LockShouldMatchGolden(safeWriterGoldenLock); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorShouldExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorFileShouldExist("github.com/sdboyer/dep-test"); err != nil {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-18 04:53:00 +03:00
|
|
|
func TestSafeWriter_ModifiedLockSkipVendor(t *testing.T) {
|
2017-03-09 22:28:42 +03:00
|
|
|
test.NeedsExternalNetwork(t)
|
|
|
|
test.NeedsGit(t)
|
|
|
|
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
pc.CopyFile(LockName, safeWriterGoldenLock)
|
|
|
|
pc.Load()
|
|
|
|
|
|
|
|
originalLock := new(Lock)
|
|
|
|
*originalLock = *pc.Project.Lock
|
2017-05-27 06:50:29 +03:00
|
|
|
originalLock.SolveMeta.InputsDigest = []byte{} // zero out the input hash to ensure non-equivalency
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(nil, originalLock, pc.Project.Lock, VendorNever)
|
2017-03-09 22:28:42 +03:00
|
|
|
|
|
|
|
// Verify prepared actions
|
2017-05-01 14:34:38 +03:00
|
|
|
if sw.HasManifest() {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Did not expect the payload to contain the manifest")
|
|
|
|
}
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasLock() {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Expected the payload to contain the lock")
|
|
|
|
}
|
2017-06-17 06:27:02 +03:00
|
|
|
if !sw.writeLock {
|
|
|
|
t.Fatal("Expected that the writer should plan to write the lock")
|
|
|
|
}
|
2017-05-17 02:06:54 +03:00
|
|
|
if sw.writeVendor {
|
2017-03-18 04:53:00 +03:00
|
|
|
t.Fatal("Did not expect the payload to contain the vendor directory")
|
2017-03-09 22:28:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Write changes
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write(pc.Project.AbsRoot, pc.SourceManager, true, discardLogger())
|
2017-03-09 22:28:42 +03:00
|
|
|
h.Must(errors.Wrap(err, "SafeWriter.Write failed"))
|
|
|
|
|
|
|
|
// Verify file system changes
|
|
|
|
if err := pc.ManifestShouldNotExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.LockShouldMatchGolden(safeWriterGoldenLock); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2017-03-18 04:53:00 +03:00
|
|
|
if err := pc.VendorShouldNotExist(); err != nil {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSafeWriter_ForceVendorWhenVendorAlreadyExists(t *testing.T) {
|
|
|
|
test.NeedsExternalNetwork(t)
|
|
|
|
test.NeedsGit(t)
|
|
|
|
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
pc.CopyFile(LockName, safeWriterGoldenLock)
|
|
|
|
pc.Load()
|
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(nil, pc.Project.Lock, pc.Project.Lock, VendorAlways)
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write(pc.Project.AbsRoot, pc.SourceManager, true, discardLogger())
|
2017-03-09 22:28:42 +03:00
|
|
|
h.Must(errors.Wrap(err, "SafeWriter.Write failed"))
|
|
|
|
|
|
|
|
// Verify prepared actions
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ = NewSafeWriter(nil, nil, pc.Project.Lock, VendorAlways)
|
2017-05-01 14:34:38 +03:00
|
|
|
if sw.HasManifest() {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Did not expect the payload to contain the manifest")
|
|
|
|
}
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasLock() {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal("Expected the payload to contain the lock")
|
|
|
|
}
|
2017-06-17 06:27:02 +03:00
|
|
|
if !sw.writeLock {
|
|
|
|
t.Fatal("Expected that the writer should plan to write the lock")
|
|
|
|
}
|
2017-05-17 02:06:54 +03:00
|
|
|
if !sw.writeVendor {
|
2017-03-18 04:53:00 +03:00
|
|
|
t.Fatal("Expected the payload to contain the vendor directory ")
|
2017-03-09 22:28:42 +03:00
|
|
|
}
|
|
|
|
|
2017-09-13 16:44:48 +03:00
|
|
|
err = sw.Write(pc.Project.AbsRoot, pc.SourceManager, true, discardLogger())
|
2017-03-09 22:28:42 +03:00
|
|
|
h.Must(errors.Wrap(err, "SafeWriter.Write failed"))
|
|
|
|
|
|
|
|
// Verify file system changes
|
|
|
|
if err := pc.ManifestShouldNotExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.LockShouldMatchGolden(safeWriterGoldenLock); err != nil {
|
2017-03-15 19:00:05 +03:00
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorShouldExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorFileShouldExist("github.com/sdboyer/dep-test"); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSafeWriter_NewLock(t *testing.T) {
|
|
|
|
test.NeedsExternalNetwork(t)
|
|
|
|
test.NeedsGit(t)
|
|
|
|
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
pc.Load()
|
|
|
|
|
|
|
|
lf := h.GetTestFile(safeWriterGoldenLock)
|
|
|
|
defer lf.Close()
|
|
|
|
newLock, err := readLock(lf)
|
|
|
|
h.Must(err)
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(nil, nil, newLock, VendorOnChanged)
|
2017-03-15 19:00:05 +03:00
|
|
|
|
|
|
|
// Verify prepared actions
|
2017-05-01 14:34:38 +03:00
|
|
|
if sw.HasManifest() {
|
2017-03-15 19:00:05 +03:00
|
|
|
t.Fatal("Did not expect the payload to contain the manifest")
|
|
|
|
}
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasLock() {
|
2017-03-15 19:00:05 +03:00
|
|
|
t.Fatal("Expected the payload to contain the lock")
|
|
|
|
}
|
2017-06-17 06:27:02 +03:00
|
|
|
if !sw.writeLock {
|
|
|
|
t.Fatal("Expected that the writer should plan to write the lock")
|
|
|
|
}
|
2017-05-17 02:06:54 +03:00
|
|
|
if !sw.writeVendor {
|
2017-03-18 04:53:00 +03:00
|
|
|
t.Fatal("Expected the payload to contain the vendor directory")
|
2017-03-15 19:00:05 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Write changes
|
2017-09-13 16:44:48 +03:00
|
|
|
err = sw.Write(pc.Project.AbsRoot, pc.SourceManager, true, discardLogger())
|
2017-03-15 19:00:05 +03:00
|
|
|
h.Must(errors.Wrap(err, "SafeWriter.Write failed"))
|
|
|
|
|
|
|
|
// Verify file system changes
|
|
|
|
if err := pc.ManifestShouldNotExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.LockShouldMatchGolden(safeWriterGoldenLock); err != nil {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorShouldExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2017-03-18 04:53:00 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestSafeWriter_NewLockSkipVendor(t *testing.T) {
|
|
|
|
test.NeedsExternalNetwork(t)
|
|
|
|
test.NeedsGit(t)
|
|
|
|
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
pc.Load()
|
|
|
|
|
|
|
|
lf := h.GetTestFile(safeWriterGoldenLock)
|
|
|
|
defer lf.Close()
|
|
|
|
newLock, err := readLock(lf)
|
|
|
|
h.Must(err)
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(nil, nil, newLock, VendorNever)
|
2017-03-18 04:53:00 +03:00
|
|
|
|
|
|
|
// Verify prepared actions
|
2017-05-01 14:34:38 +03:00
|
|
|
if sw.HasManifest() {
|
2017-03-18 04:53:00 +03:00
|
|
|
t.Fatal("Did not expect the payload to contain the manifest")
|
|
|
|
}
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasLock() {
|
2017-03-18 04:53:00 +03:00
|
|
|
t.Fatal("Expected the payload to contain the lock")
|
|
|
|
}
|
2017-06-17 06:27:02 +03:00
|
|
|
if !sw.writeLock {
|
|
|
|
t.Fatal("Expected that the writer should plan to write the lock")
|
|
|
|
}
|
2017-05-17 02:06:54 +03:00
|
|
|
if sw.writeVendor {
|
2017-03-18 04:53:00 +03:00
|
|
|
t.Fatal("Did not expect the payload to contain the vendor directory")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Write changes
|
2017-09-13 16:44:48 +03:00
|
|
|
err = sw.Write(pc.Project.AbsRoot, pc.SourceManager, true, discardLogger())
|
2017-03-18 04:53:00 +03:00
|
|
|
h.Must(errors.Wrap(err, "SafeWriter.Write failed"))
|
|
|
|
|
|
|
|
// Verify file system changes
|
|
|
|
if err := pc.ManifestShouldNotExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.LockShouldMatchGolden(safeWriterGoldenLock); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorShouldNotExist(); err != nil {
|
2017-03-09 22:28:42 +03:00
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2016-12-30 08:39:08 +03:00
|
|
|
}
|
2017-03-01 23:52:09 +03:00
|
|
|
|
|
|
|
func TestSafeWriter_DiffLocks(t *testing.T) {
|
|
|
|
test.NeedsExternalNetwork(t)
|
|
|
|
test.NeedsGit(t)
|
|
|
|
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
2017-03-21 19:23:53 +03:00
|
|
|
pc.CopyFile(LockName, "txn_writer/original_lock.toml")
|
2017-03-01 23:52:09 +03:00
|
|
|
pc.Load()
|
|
|
|
|
2017-03-21 19:23:53 +03:00
|
|
|
ulf := h.GetTestFile("txn_writer/updated_lock.toml")
|
2017-03-01 23:52:09 +03:00
|
|
|
defer ulf.Close()
|
|
|
|
updatedLock, err := readLock(ulf)
|
|
|
|
h.Must(err)
|
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(nil, pc.Project.Lock, updatedLock, VendorOnChanged)
|
2017-03-01 23:52:09 +03:00
|
|
|
|
|
|
|
// Verify lock diff
|
2017-05-17 03:41:19 +03:00
|
|
|
diff := sw.lockDiff
|
2017-03-01 23:52:09 +03:00
|
|
|
if diff == nil {
|
|
|
|
t.Fatal("Expected the payload to contain a diff of the lock files")
|
|
|
|
}
|
2017-04-11 18:38:50 +03:00
|
|
|
|
|
|
|
output, err := formatLockDiff(*diff)
|
2017-03-01 23:52:09 +03:00
|
|
|
h.Must(err)
|
|
|
|
goldenOutput := "txn_writer/expected_diff_output.txt"
|
|
|
|
if err = pc.ShouldMatchGolden(goldenOutput, output); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
2017-04-26 15:21:11 +03:00
|
|
|
|
|
|
|
func TestHasDotGit(t *testing.T) {
|
|
|
|
// Create a tempdir with .git file
|
|
|
|
td, err := ioutil.TempDir(os.TempDir(), "dotGitFile")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
defer os.RemoveAll(td)
|
|
|
|
|
|
|
|
os.OpenFile(td+string(filepath.Separator)+".git", os.O_CREATE, 0777)
|
|
|
|
if !hasDotGit(td) {
|
|
|
|
t.Fatal("Expected hasDotGit to find .git")
|
|
|
|
}
|
|
|
|
}
|
2017-04-26 22:19:09 +03:00
|
|
|
|
|
|
|
func TestSafeWriter_VendorDotGitPreservedWithForceVendor(t *testing.T) {
|
|
|
|
h := test.NewHelper(t)
|
|
|
|
defer h.Cleanup()
|
|
|
|
|
|
|
|
pc := NewTestProjectContext(h, safeWriterProject)
|
|
|
|
defer pc.Release()
|
|
|
|
|
|
|
|
gitDirPath := filepath.Join(pc.Project.AbsRoot, "vendor", ".git")
|
|
|
|
os.MkdirAll(gitDirPath, 0777)
|
|
|
|
dummyFile := filepath.Join("vendor", ".git", "badinput_fileroot")
|
|
|
|
pc.CopyFile(dummyFile, "txn_writer/badinput_fileroot")
|
|
|
|
pc.CopyFile(ManifestName, safeWriterGoldenManifest)
|
|
|
|
pc.CopyFile(LockName, safeWriterGoldenLock)
|
|
|
|
pc.Load()
|
|
|
|
|
2017-05-01 00:35:43 +03:00
|
|
|
sw, _ := NewSafeWriter(pc.Project.Manifest, pc.Project.Lock, pc.Project.Lock, VendorAlways)
|
2017-04-26 22:19:09 +03:00
|
|
|
|
|
|
|
// Verify prepared actions
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasManifest() {
|
2017-04-26 22:19:09 +03:00
|
|
|
t.Fatal("Expected the payload to contain the manifest")
|
|
|
|
}
|
2017-05-01 14:34:38 +03:00
|
|
|
if !sw.HasLock() {
|
2017-04-26 22:19:09 +03:00
|
|
|
t.Fatal("Expected the payload to contain the lock")
|
|
|
|
}
|
2017-06-17 06:27:02 +03:00
|
|
|
if sw.writeLock {
|
|
|
|
t.Fatal("Did not expect that the writer should plan to write the lock")
|
|
|
|
}
|
2017-05-17 02:06:54 +03:00
|
|
|
if !sw.writeVendor {
|
2017-04-26 22:19:09 +03:00
|
|
|
t.Fatal("Expected the payload to contain the vendor directory")
|
|
|
|
}
|
|
|
|
|
2017-09-13 16:44:48 +03:00
|
|
|
err := sw.Write(pc.Project.AbsRoot, pc.SourceManager, true, discardLogger())
|
2017-04-26 22:19:09 +03:00
|
|
|
h.Must(errors.Wrap(err, "SafeWriter.Write failed"))
|
|
|
|
|
|
|
|
// Verify file system changes
|
|
|
|
if err := pc.ManifestShouldMatchGolden(safeWriterGoldenManifest); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.LockShouldMatchGolden(safeWriterGoldenLock); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorShouldExist(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorFileShouldExist("github.com/sdboyer/dep-test"); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := pc.VendorFileShouldExist(".git/badinput_fileroot"); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|