oz icon indicating copy to clipboard operation
oz copied to clipboard

Build Fails Due to Dependency Version Mismatch

Open deer8888 opened this issue 1 week ago • 1 comments

Description

While rebuilding the project using the latest version of Go, with Go's official recommendation to use gomodule for initialization and building, we found that the build process fails due to mismatched module path.

The following error log was produced during the build process:

......
go: found github.com/twtiger/gosecco in github.com/twtiger/gosecco v0.0.0-20170412154010-06b8323873a0
go: found golang.org/x/sys/unix in golang.org/x/sys v0.24.0
go: github.com/subgraph/oz/cmd/oz-setup imports
        github.com/codegangsta/cli: github.com/codegangsta/[email protected]: parsing go.mod:
        module declares its path as: github.com/urfave/cli
                but was required as: github.com/codegangsta/cli

Result

The build fails with errors related to mismatched module path.

The error dependency is github.com/codegangsta/cli.

Reason

The error log suggests module path declaration github.com/urfave/cli in go.mod, which is inconsistent with import path github.com/codegangsta/cli .

Proposed Solution

To resolve this issue, we analyzed the project and identified the correct versions of the required dependencies.

The analysis shows that the correct declaration for the dependency is replace github.com/codegangsta/cli => github.com/urfave/cli v1.21.0.

Consider adopting this suggested version to prevent other developers from encountering build failures when constructing the project.

This information can be documented in the README.md file or another relevant location.

Additional Suggestions

To ensure reproducible builds and align with the evolving trends of the Go programming language, it is recommended that the current project be migrated to the Go module mechanism.

Updating to the go module mechanism allows for managing third-party dependency versions through the go.mod file, which provides a centralized and consistent way to specify dependency constraints.

We have generated a go.mod file with the correct versions of the third-party dependencies needed for this project.

The suggested go.mod file is as follows:


replace github.com/milosgajdos83/tenus => github.com/milosgajdos/tenus v0.0.0-20200402080617-5d40bc50b726

require github.com/kr/pty v0.0.0-20130926155747-3b1f6487b7fc

require github.com/gotk3/gotk3 v0.0.0-20190727115315-66ac52256247

replace github.com/cpuguy83/go-md2man => github.com/cpuguy83/go-md2man/v2 v2.0.3

require github.com/j-keck/arping v1.0.3-0.20210601060012-686632245946

require github.com/docker/libcontainer v2.2.2-0.20150701164209-83a102cc68a0+incompatible // indirect

replace github.com/codegangsta/cli => github.com/urfave/cli v1.21.0

require github.com/op/go-logging v0.0.0-20160315200505-970db520ece7

require (
	github.com/codegangsta/cli v0.0.0-00010101000000-000000000000
	github.com/milosgajdos83/tenus v0.0.0-00010101000000-000000000000
	github.com/naegelejd/go-acl v0.0.0-20200406162857-ebe394c522e5
	github.com/subgraph/constants v0.0.0-20160901231004-979abf7df6e0
	github.com/subgraph/go-xdgdirs v0.0.0-20160329064927-42db8d15c28b
	github.com/twtiger/gosecco v0.0.0-20170412154010-06b8323873a0
	golang.org/x/sys v0.30.0
)

require github.com/BurntSushi/xdg v0.0.0-20130804141135-e80d3446fea1 // indirect

Additional Information:

This issue was identified as part of our research project focused on automating the analysis of GOPATH projects to provide accurate dependency versions for seamless migration to Go Modules. We value your feedback and would appreciate any comments or suggestions regarding this approach.

deer8888 avatar Feb 24 '25 11:02 deer8888