Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

"undeclared name" while loading package #71

Open
gregLibert opened this issue Jan 7, 2019 · 5 comments
Open

"undeclared name" while loading package #71

gregLibert opened this issue Jan 7, 2019 · 5 comments

Comments

@gregLibert
Copy link

Hi,

I've got an error while executing the following command:

> go-mutesting --verbose --debug .
Enable mutator "branch/case"
Enable mutator "branch/else"
Enable mutator "branch/if"
Enable mutator "expression/comparison"
Enable mutator "expression/remove"
Enable mutator "statement/remove"
Save mutations into "/tmp/go-mutesting-389248154"
Mutate "config.go"
/tmp/sql/config.go:23:10: undeclared name: newConfigError
/tmp/sql/config.go:27:10: undeclared name: newConfigError
/tmp/sql/config.go:31:10: undeclared name: newConfigError
Could not load package of file "config.go": couldn't load packages due to errors: /tmp/sql

newConfigError is in my scenario a function defined in the same package, but in another file.

Playing with the code, I found out here that you are only loading one file if importPath is equal to ".".
As only one file is loaded (instead of all go files in the module), every entities not present in the same file raised exception.

Replacing conf.CreateFromFilenames(dir, fileAbs) with conf.Import(buildPkg.ImportPath) in parse.go solved my problem, but I'm not sure that the best thing to do as I don't really know the inner logic...

@apgrucza
Copy link

I had the same problem. After moving my Go code into the proper location (a directory under $GOPATH/src), the problem went away.

@smoyer64
Copy link

After moving my Go code into the proper location

That's not necessarily the proper location for code that's versioned using Go modules. I'm having this problem in libraries that are built this way.

@apgrucza
Copy link

Yes, it does seem that go-mutesting doesn't really support projects with Go modules and this needs to be fixed.

The only way I've found to work around this problem is to copy the Go code into a directory under $GOPATH/src, and then run (in the project directory under $GOPATH/src):

GO111MODULE=off go get -t -v .
GO111MODULE=on go-mutesting .

When creating mutants, go-mutesting temporarily modifies the source code in-place, so copying the source code to another directory has the added benefit of ensuring that those mutations are not kept if go-mutesting terminates prematurely.

@smoyer64
Copy link

It seems like it would be wise to copy the code to a temporary folder before creating the mutants ... should this be another issue?

@benmoss
Copy link

benmoss commented May 29, 2020

this was fixed for me by using the fork from #77

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants