From 241cc37c9b3b57489fc57b347300a5cacefb6b9b Mon Sep 17 00:00:00 2001 From: Joe Fitzgerald Date: Wed, 9 Oct 2024 18:37:05 -0600 Subject: [PATCH] add integration test to validate type aliases are treated correctly Signed-off-by: Joe Fitzgerald --- fixtures/dup_packages/go.mod | 2 +- fixtures/type_aliases/extra/m.go | 5 +++++ fixtures/type_aliases/extra/primitive/m.go | 3 +++ fixtures/type_aliases/go.mod | 3 +++ fixtures/type_aliases/interface.go | 14 ++++++++++++++ integration/roundtrip_test.go | 19 +++++++++++++++++++ 6 files changed, 45 insertions(+), 1 deletion(-) create mode 100644 fixtures/type_aliases/extra/m.go create mode 100644 fixtures/type_aliases/extra/primitive/m.go create mode 100644 fixtures/type_aliases/go.mod create mode 100644 fixtures/type_aliases/interface.go diff --git a/fixtures/dup_packages/go.mod b/fixtures/dup_packages/go.mod index e5fc549..b49ab2a 100644 --- a/fixtures/dup_packages/go.mod +++ b/fixtures/dup_packages/go.mod @@ -1,3 +1,3 @@ module github.com/maxbrunsfeld/counterfeiter/v6/fixtures/dup_packages -go 1.12 +go 1.22 diff --git a/fixtures/type_aliases/extra/m.go b/fixtures/type_aliases/extra/m.go new file mode 100644 index 0000000..bc0623b --- /dev/null +++ b/fixtures/type_aliases/extra/m.go @@ -0,0 +1,5 @@ +package extra // import "github.com/maxbrunsfeld/counterfeiter/v6/fixtures/type_aliases/extra" + +import "github.com/maxbrunsfeld/counterfeiter/v6/fixtures/type_aliases/extra/primitive" + +type M = primitive.M diff --git a/fixtures/type_aliases/extra/primitive/m.go b/fixtures/type_aliases/extra/primitive/m.go new file mode 100644 index 0000000..9cebc01 --- /dev/null +++ b/fixtures/type_aliases/extra/primitive/m.go @@ -0,0 +1,3 @@ +package primitive // import "github.com/maxbrunsfeld/counterfeiter/v6/fixtures/type_aliases/primitive" + +type M map[string]interface{} diff --git a/fixtures/type_aliases/go.mod b/fixtures/type_aliases/go.mod new file mode 100644 index 0000000..b9bd99b --- /dev/null +++ b/fixtures/type_aliases/go.mod @@ -0,0 +1,3 @@ +module github.com/maxbrunsfeld/counterfeiter/v6/fixtures/type_aliases + +go 1.22 diff --git a/fixtures/type_aliases/interface.go b/fixtures/type_aliases/interface.go new file mode 100644 index 0000000..d75bd9e --- /dev/null +++ b/fixtures/type_aliases/interface.go @@ -0,0 +1,14 @@ +package type_aliases // import "github.com/maxbrunsfeld/counterfeiter/v6/fixtures/type_aliases" + +import ( + "context" + + "github.com/maxbrunsfeld/counterfeiter/v6/fixtures/type_aliases/extra" +) + +//go:generate go run github.com/maxbrunsfeld/counterfeiter/v6 -generate + +//counterfeiter:generate . WithAliasedType +type WithAliasedType interface { + FindExample(ctx context.Context, filter extra.M) ([]string, error) +} diff --git a/integration/roundtrip_test.go b/integration/roundtrip_test.go index 45939f3..5dafaa0 100644 --- a/integration/roundtrip_test.go +++ b/integration/roundtrip_test.go @@ -121,6 +121,25 @@ func runTests(t *testing.T, when spec.G, it spec.S) { }) }) + when("generating interfaces using type aliases", func() { + it.Before(func() { + relativeDir = filepath.Join(relativeDir, "type_aliases") + copyDirFunc() + }) + it("imports the aliased type, not the underlying type", func() { + cache := &generator.FakeCache{} + pkgPath := "github.com/maxbrunsfeld/counterfeiter/v6/fixtures/type_aliases" + interfaceName := "WithAliasedType" + fakePackageName := "type_aliasesfakes" + f, err := generator.NewFake(generator.InterfaceOrFunction, interfaceName, pkgPath, "Fake"+interfaceName, fakePackageName, "", baseDir, cache) + Expect(err).NotTo(HaveOccurred()) + b, err := f.Generate(false) + Expect(err).NotTo(HaveOccurred()) + Expect(string(b)).NotTo(ContainSubstring("primitive")) + Expect(string(b)).To(ContainSubstring(`"github.com/maxbrunsfeld/counterfeiter/v6/fixtures/type_aliases/extra"`)) + }) + }) + when(name, func() { t := func(interfaceName string, filename string, subDir string, files ...string) { when("working with "+filename, func() {