diff --git a/.gitignore b/.gitignore index c2bf0c91..fed09c6c 100644 --- a/.gitignore +++ b/.gitignore @@ -2,6 +2,7 @@ vendor dist /getenvoy /build/ +.idea # code generated by `github.com/rakyll/statik` statik.go diff --git a/test/e2e/e2e_suite_test.go b/test/e2e/e2e_suite_test.go index 74d629d2..0ded861d 100644 --- a/test/e2e/e2e_suite_test.go +++ b/test/e2e/e2e_suite_test.go @@ -46,13 +46,19 @@ var ( var tempDir string var _ = BeforeEach(func() { - dir, err := ioutil.TempDir("", "") - Expect(err).NotTo(HaveOccurred()) - dir, err = filepath.EvalSymlinks(dir) + dir, err := newTempDir("") Expect(err).NotTo(HaveOccurred()) tempDir = dir }) +func newTempDir(pattern string) (string, error) { + if dir, err := ioutil.TempDir("", pattern); err != nil { + return "", err + } else { + return filepath.EvalSymlinks(dir) + } +} + var _ = AfterEach(func() { if tempDir != "" { Expect(os.RemoveAll(tempDir)).To(Succeed()) diff --git a/test/e2e/getenvoy_extension_test_test.go b/test/e2e/getenvoy_extension_test_test.go index 9bdc2ea5..468fa758 100644 --- a/test/e2e/getenvoy_extension_test_test.go +++ b/test/e2e/getenvoy_extension_test_test.go @@ -15,60 +15,57 @@ package e2e_test import ( - "os" - "path/filepath" - - . "github.com/onsi/ginkgo" - . "github.com/onsi/ginkgo/extensions/table" - . "github.com/onsi/gomega" - + "github.com/stretchr/testify/require" + "github.com/tetratelabs/getenvoy/pkg/extension/workspace/config/extension" e2e "github.com/tetratelabs/getenvoy/test/e2e/util" + "os" + "regexp" + "testing" ) -var _ = Describe("getenvoy extension test", func() { - - type testCase e2e.CategoryLanguageTuple - - testCases := func() []TableEntry { - testCases := make([]TableEntry, 0) - for _, combination := range e2e.GetCategoryLanguageCombinations() { - testCases = append(testCases, Entry(combination.String(), testCase(combination))) - } - return testCases +// TestGetEnvoyExtensionTest runs the equivalent of "getenvoy extension test" for a matrix of extension.Categories and +// extension.Languages. +// +// "getenvoy extension init" is a prerequisite, so run first. Note: "getenvoy extension test" can be extremely slow due +// to implicit responsibilities such as downloading modules or compilation. This is ultimately a Docker command, so +// changes to the Dockerfile or contents like "commands.sh" effect performance. +func TestGetEnvoyExtensionTest(t *testing.T) { + const extensionName = "my.extension" + var languageToTestOutputRegexp = map[extension.Language]*regexp.Regexp{ + extension.LanguageRust: regexp.MustCompile(`(?s)^.*test result: ok.*$`), + extension.LanguageTinyGo: regexp.MustCompile(`(?s)^.*ok my.extension.*$`), } - const extensionName = "my.extension" + for _, test := range e2e.GetCategoryLanguageCombinations() { + testOutputRegexp := languageToTestOutputRegexp[test.Language] + outputDir, err := newTempDir("getenvoy_extension_test") + require.NoError(t, err) - DescribeTable("should run unit tests", - func(given testCase) { - By("choosing the output directory") - outputDir := filepath.Join(tempDir, "new") - defer CleanUpExtensionDir(outputDir) + // "getenvoy extension init" is a prerequisite, so we don't test the output in this test. + if _, _, err = GetEnvoy("extension init"). + Arg(outputDir). + Arg("--category").Arg(test.Category.String()). + Arg("--language").Arg(test.Language.String()). + Arg("--name").Arg(extensionName). + Exec(); err != nil { + os.RemoveAll(outputDir) + t.Fatal(err) + } - By("running `extension init` command") - _, _, err := GetEnvoy("extension init"). - Arg(outputDir). - Arg("--category").Arg(given.Category.String()). - Arg("--language").Arg(given.Language.String()). - Arg("--name").Arg(extensionName). - Exec() - Expect(err).NotTo(HaveOccurred()) + t.Run(test.String(), func(t *testing.T) { + defer os.RemoveAll(outputDir) - By("changing to the output directory") + // Change to the initialized directory and run "getenvoy extension test" err = os.Chdir(outputDir) - Expect(err).NotTo(HaveOccurred()) - - By("running `extension test` command") + require.NoError(t, err) stdout, stderr, err := GetEnvoy("extension test"). Args(e2e.Env.GetBuiltinContainerOptions()...). Exec() - Expect(err).NotTo(HaveOccurred()) - By("verifying stdout/stderr") // apparently, use of `-t` option in `docker run` causes stderr to be incorporated into stdout - Expect(stdout).NotTo(BeEmpty()) - Expect(stderr).To(BeEmpty()) - }, - testCases()..., - ) -}) + require.Regexp(t, testOutputRegexp, stdout) + require.Equal(t, ``, stderr) + require.NoError(t, err) + }) + } +} diff --git a/test/e2e/getenvoy_test.go b/test/e2e/getenvoy_test.go index e3fe246d..fa440f11 100644 --- a/test/e2e/getenvoy_test.go +++ b/test/e2e/getenvoy_test.go @@ -15,18 +15,14 @@ package e2e_test import ( - . "github.com/onsi/ginkgo" - . "github.com/onsi/gomega" + "github.com/stretchr/testify/require" + "testing" ) -var _ = Describe("getenvoy", func() { - It("should support '--version' flag", func() { - By("running the command") - stdout, stderr, err := GetEnvoy("--version").Exec() - Expect(err).NotTo(HaveOccurred()) +func TestGetEnvoyVersion(t *testing.T) { + stdout, stderr, err := GetEnvoy("--version").Exec() - By("verifying stdout/stderr") - Expect(stdout).To(MatchRegexp(`^getenvoy version ([^\s]+)\n$`)) - Expect(stderr).To(Equal(``)) - }) -}) + require.Regexp(t, `^getenvoy version ([^\s]+)\n$`, stdout) + require.Equal(t, ``, stderr) + require.NoError(t, err) +}