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

Change @rules_pkg// to @// to allow users to name the repo what they want. #154

Merged
merged 18 commits into from
May 28, 2020

Conversation

aiuto
Copy link
Collaborator

@aiuto aiuto commented Apr 15, 2020

This allows users to include the rules and remap the repo to a new name
I used the @// to give a visual reminder that this is interpreted
w.r.t. to the repo, and not your workspace root.

This requires Bazel 2.x or above.

This allows users to include the rules and remap the repo to a new name
I used the @// to give a visual reminder that this is interpreted
w.r.t. to the repo, and not your workspace root.
@aiuto aiuto added the WIP label Apr 16, 2020
@nacl
Copy link
Collaborator

nacl commented Apr 27, 2020

Out of curiosity, what is the change in 3.x that makes this possible? I can't seem to find it (glanced through the closed issue list and the git changelog).

@aiuto
Copy link
Collaborator Author

aiuto commented Apr 27, 2020 via email

@aiuto aiuto removed the WIP label Apr 27, 2020
@aiuto aiuto requested review from dannysullivan and nacl April 28, 2020 15:23
@aiuto
Copy link
Collaborator Author

aiuto commented Apr 28, 2020

Since there is pressure for a new named release, I want to roll this into the code before doing that.

Copy link
Collaborator

@nacl nacl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

When I try to load this from a repo that very simply tests the experimental rpm packaging rules (via local_repository), I get errors like this:

ERROR: error loading package '': in /home/apsaltis/.cache/bazel/_bazel_apsaltis/604301d63bf9174c7d4397ed3b43f6f0/external/rules_pkg/experimental/rpm.bzl: Label '//experimental:pkg_filegroup.bzl' is invalid because 'experimental' is not a package; perhaps you meant to put the colon here: '//:experimental/pkg_filegroup.bzl'?

This is from within rules_pkg itself, so there may be something wrong with this change (or bazel, maybe). I'm not completely sure.

Reproduced using this example. WORKSPACE needs to be changed to point to your rules_pkg checkout (see README.md)

Copy link
Collaborator

@nacl nacl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copyrights should probably be added or updated everywhere. Maybe this should be done in another change?

@aiuto
Copy link
Collaborator Author

aiuto commented Apr 29, 2020

I think the best path is merge this with your goal of #142, and the source reorg, and make this version 0.3.0. I'll get back to it in a day or so.

@achew22
Copy link
Member

achew22 commented Apr 29, 2020

@aiuto, forgive my naiveté, especially on a driveby, but isn't @// the path to the "main repo"? Wouldn't you want to change these to just // to use current-repo relative resolution?

Unfortunately I can't find better docs when grepping around about this than this

@aiuto
Copy link
Collaborator Author

aiuto commented May 27, 2020

Copyrights should probably be added or updated everywhere. Maybe this should be done in another change?

Copyrights do not have to be updated each year.

@aiuto
Copy link
Collaborator Author

aiuto commented May 27, 2020

@aiuto, forgive my naiveté, especially on a driveby, but isn't @// the path to the "main repo"? Wouldn't you want to change these to just // to use current-repo relative resolution?

Unfortunately I can't find better docs when grepping around about this than this

// and @// are the same. I was trying to signal something in path names but I'm less keen on that idea now. Reverted to '//'

@aiuto
Copy link
Collaborator Author

aiuto commented May 27, 2020

When I try to load this from a repo that very simply tests the experimental rpm packaging rules (via local_repository), I get errors like this:


That seems to happen if I run tests from experimental/tests/external_repo, but we shouldn't be doing that. We can't have multiple WORKSPACE files or things are too confusing. Integration tests that need a workspace will have to create their own as part of the test.

@aiuto aiuto requested a review from nacl May 27, 2020 02:24
@aiuto
Copy link
Collaborator Author

aiuto commented May 27, 2020

When I try to load this from a repo that very simply tests the experimental rpm packaging rules (via local_repository), I get errors like this:

ERROR: error loading package '': in /home/apsaltis/.cache/bazel/_bazel_apsaltis/604301d63bf9174c7d4397ed3b43f6f0/external/rules_pkg/experimental/rpm.bzl: Label '//experimental:pkg_filegroup.bzl' is invalid because 'experimental' is not a package; perhaps you meant to put the colon here: '//:experimental/pkg_filegroup.bzl'?

This is from within rules_pkg itself, so there may be something wrong with this change (or bazel, maybe). I'm not completely sure.

Reproduced using this example. WORKSPACE needs to be changed to point to your rules_pkg checkout (see README.md)

bazel test ... works for me.
But your external_repo tests need to be changed. We can't have more than one WORKSPACE file in a tree or things become impossible to test.

@nacl
Copy link
Collaborator

nacl commented May 27, 2020

Copyrights should probably be added or updated everywhere. Maybe this should be done in another change?

Copyrights do not have to be updated each year.

True. By "everywhere", I should have said "in the files that were changed for this PR."

@aiuto
Copy link
Collaborator Author

aiuto commented May 27, 2020

Copyrights should probably be added or updated everywhere. Maybe this should be done in another change?

Copyrights do not have to be updated each year.

True. By "everywhere", I should have said "in the files that were changed for this PR."

But they do not have to change in the files edited in this PR. A copy right notice need the year of first publication of the work. Changing copyright lines just because the file was touched creates needless churn.

@nacl
Copy link
Collaborator

nacl commented May 27, 2020

But they do not have to change in the files edited in this PR. A copy right notice need the year of first publication of the work. Changing copyright lines just because the file was touched creates needless churn.

Fair enough. Thanks for the clarification.

@nacl
Copy link
Collaborator

nacl commented May 27, 2020

When I try to load this from a repo that very simply tests the experimental rpm packaging rules (via local_repository), I get errors like this:


That seems to happen if I run tests from experimental/tests/external_repo, but we shouldn't be doing that. We can't have multiple WORKSPACE files or things are too confusing. Integration tests that need a workspace will have to create their own as part of the test.

The issue there is that this WORKSPACE assumes that there is a previously loaded workspace called "rules_pkg", and is simply there for demarcation purposes. It does not load rules_pkg on its own. My example actually tries to load rules_pkg as a local_repository

I'm happy to make changes to that experimental repository test regardless; it does need to be in some sort of external repository. What's your recommend way forward on this? Generating a test WORKSPACE like how pkg/releasing/release_tools.py does it?

@nacl
Copy link
Collaborator

nacl commented May 27, 2020

When I try to load this from a repo that very simply tests the experimental rpm packaging rules (via local_repository), I get errors like this:

ERROR: error loading package '': in /home/apsaltis/.cache/bazel/_bazel_apsaltis/604301d63bf9174c7d4397ed3b43f6f0/external/rules_pkg/experimental/rpm.bzl: Label '//experimental:pkg_filegroup.bzl' is invalid because 'experimental' is not a package; perhaps you meant to put the colon here: '//:experimental/pkg_filegroup.bzl'?

This is from within rules_pkg itself, so there may be something wrong with this change (or bazel, maybe). I'm not completely sure.
Reproduced using this example. WORKSPACE needs to be changed to point to your rules_pkg checkout (see README.md)

bazel test ... works for me.

It does for me too. The issue was with external use of rules_pkg.

FWIW, the repro example works with HEAD on your topic branch. However, it didn't work the last time I tried it, or at a02e872 when I checked it out locally. It looks like the change from @// to // fixed the issue I was having.

I don't know if there's something wrong with my example, but it looks like @// is behaving differently than // here.

@aiuto aiuto merged commit 2977b08 into bazelbuild:master May 28, 2020
@aiuto aiuto deleted the rmr branch May 28, 2020 01:22
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

Successfully merging this pull request may close these issues.

3 participants