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

Add override_for to dep options #14156

Open
wants to merge 3 commits into
base: main
Choose a base branch
from
Open

Conversation

TylerWitt
Copy link
Contributor

override_for gives more information about when deps should explicitly be overridden or not.

If a dep no longer needs an override, a message will be written indicating so. Alternatively, if a dep needs an override when a dep is already using override_for, it will alert the dev.

With override: true set, if a user were to add a new dep that depends on the overridden app, there would be no indication of a potential issue.

override_for gives more information about when deps should explicitly be overridden or not.

If a dep no longer needs an override, a message will be written indicating so.
Alternatively, if a dep needs an override when a dep is already using override_for, it will alert the dev.

With override: true set, if a user were to add a new dep that depends on the overridden app, there would be no indication of a potential issue.
@TylerWitt
Copy link
Contributor Author

An attempt at implementing #14082

I'm not familiar enough to get override_for: to fail in the same way as a missing override would, though I'm not sure if that is desired based on the conversations in the issue.

I primarily tried to only add messaging in the do_finalize step.

Will update docs and polish the work up if it looks like the right approach!

@@ -299,7 +299,7 @@ defmodule Mix.Dep.Converger do
end

cond do
in_upper? && other_opts[:override] ->
in_upper? && (other_opts[:override] || override_for?(other_opts, app)) ->
Copy link
Contributor Author

Choose a reason for hiding this comment

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

I was most confused in this section of the converge logic.

If a dep passes this check once, does it never fail/process again? I initially had a test where I wanted dependency resolution to fail if override_for: [:foo] is specified, but :baz also required the override.

@@ -0,0 +1,11 @@
defmodule OverrideForRepo do
Copy link
Member

Choose a reason for hiding this comment

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

Instead of adding a new fixture, could we use one of the existing ones? In particular, some fixtures allows you to configure them dynamically by passing some options.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I tried to find a fixture that would let me configure it, but I'm only seeing opts as configurable, and not the actual requirement for the dependencies themselves to force an override requirement.

I ended up just having override_for: [] and using git_repo and deps_repo like most of the other tests currently do.

@josevalim
Copy link
Member

Thank you for the PR! ❤️ To align expectations, my priorities for Elixir is:

  1. Release a new v1.18.x
  2. Wrap up the type inference branch
  3. Look at new features for v1.19

So it make take a while (e.g. weeks). The code here is also complex, so it may be the best approach for me to validate this is by actually implementing it too, so I may end-up reusing tests mostly if our implementations diverge considerably.

@TylerWitt
Copy link
Contributor Author

No worries!

It was a nice excuse to understand the inner workings of Elixir/dependency resolution more in any case.

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

Successfully merging this pull request may close these issues.

2 participants