-
Notifications
You must be signed in to change notification settings - Fork 213
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
Convert components to a go module #933
Comments
Can you share a bit more detail about why the cyclic dependencies break what you are trying to achieve? If they are on the package level I would expect that go refuses to build them no matter how the modules are set up. But if they are cyclic on the module level they should not cause issues if I understand the situation correctly. |
@maxmoehl hmm, I am not sure if I follow your question, but let me re-iterate it differently. I am only going to use the following two That said, you are more than welcome to experiment with other ways of solving this problem. I am only sharing what has been our experience solving this issue thus far. |
I would like to know which issue this causes, do you have some error message you encountered? |
When we first looked at this it was 3 years ago when we had to migrate to a go.mod and migrate off of GOPATH, so I don't have the specific error messages I was seeing. If we now have the community support behind this, we should re-start that effort and document it along the way for future. |
Okay, I'll try to reserve some time to play around and report back with my findings. |
After some investigations into this issue I think the current setup is good enough and splitting the module definitions would probably lead to additional effort with limited return:
I won't continue to investigate this topic for now. |
Proposed Change
As a developer
I would like the ability to build diego-release's components (e.g. bbs) as a standalone module
So that when I run
go install code.cloudfoundry.org/bbs/cmd/bbs@latest
and it will install the latest version of the binarydiego-release
components were built at a time before go modules existence. It was built with the assumption ofGOPATH
. As a result, most modules import each other, creating a circular dependencies wherebbs
needs to importlocket
andlcoket
needs to importbbs
. This is because it was easier to use helper libraries that each repo created originally. In order to be able to do this work we need to do the following to break out the circular import and allow each of those modules to be independent.Here are the list of components that will have to be converted
bbs
, most of the consumers are just looking for models or sqlhelpers. In this case, we would extract out the logic into it's own independent repository and update downstream consumers.bbs
, it's importinglocket
,auctioneer
,ecrhelper
,executor
,inigo
, andworkpool
. Here is a branch for bbs and a branch for locket that removed the circular dependency between the two of them.Acceptance criteria
diego-release will no longer have any submodules and I can deploy diego-release with cf-deployment, so that I cf push and run all acceptance tests.
Related links
The text was updated successfully, but these errors were encountered: