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

[Discussion/Question]: How to deal with indirect dependencies that are not on CRAN #38

Open
2 tasks done
averissimo opened this issue Sep 21, 2023 · 3 comments
Open
2 tasks done
Labels
question Further information is requested

Comments

@averissimo
Copy link
Contributor

averissimo commented Sep 21, 2023

What is your question?

Example

Context:

  • pkg.a depends on pkg.b but not on pkg.c.
  • pkg.c is not defined on DESCRIPTION file of pkg.a
  • pkg.c is only released on GitHub / R-Universe

For an actual case, pkg.a is teal.modules.clinical, pkg.b is teal.slice and pkg.c is teal.data

Outcome

  • ❌ Check fails as it cannot find an install candidate for pkg.c

Solutions

  1. Add entry for Config/Needs/verdepcheck of pkg.a to serve as hint on where to find pkg.c
    • Right now it discards any entry that is not on Depends/Imports/Suggests
    • We could use optional flag to enable this behavior
  2. Re-add Remotes section to insightsengineering packages
    • Needs research how to mitigate issue with R-Universe
  3. Wait until pkg.c is released on CRAN
    • teal.data should be released in next few months

Code of Conduct

  • I agree to follow this project's Code of Conduct.

Contribution Guidelines

  • I agree to follow this project's Contribution Guidelines.
@averissimo averissimo added the question Further information is requested label Sep 21, 2023
@averissimo
Copy link
Contributor Author

averissimo commented Sep 21, 2023

(moving discussion from chat to issue @pawelru)

I've already tested a solution of 1.: That would create some clutter.

However, there's a positive side-effect as it would make the max strategy more effective, as it would use pkg.c/teal.data development version.

@pawelru
Copy link
Contributor

pawelru commented Oct 3, 2023

I personally leaning towards 2. This would be a clean solution because something wrong is with pkg.b hence any fixes needs to be done there.

I have some bad feeling about 1 as this would break encapsulation. I don't want people to specify all indirect deps there. On the other hand, we can change the behaviour in a way that the entry will be used on a match with any (!) of all (!) dependencies (currently it is used on a match with direct dependencies only). I see the value (not to mention max strategy as you pointed out) but this is quite a messy logic to be honest. If done, this needs to be very well documented.

@averissimo
Copy link
Contributor Author

I think there's a third option that was right in front of us, which is to manipulate the repos option to extend the package versions of indirect dependencies

See insightsengineering/r-verdepcheck-action#22

We can do the same as that PR when using verdepcheck manually.

averissimo added a commit to insightsengineering/r-verdepcheck-action that referenced this issue Jan 8, 2025
Related to insightsengineering/verdepcheck#38

In scenarios where the `DESCRIPTION` file has top-level dependencies
(`Depends`, `Imports`, `Suggests`, `Extends`) that depend on packages
not yet released on CRAN, this new option allows to define repositories
that may fill the gap.

In particular, this is important on `max` strategy, as they might depend
on secondary packages that have changes that only exist on the
repository.

### Changes description

- Adds new option to add extra repositories
- If user wants to fully override default repository, they can replace
environmental variables
- Adds styling to first (manual) header
- Better organizes readme

### TODO:

- [ ] Understand how to use this new option in github action `matrix`

### Use case examples

This will be especially helpful with `max` strategy to allow more
packages to be compiled with latest development versions

- `insightsengineering` packages can use `r-universe.dev` to pull
secondary dependencies such as `formatters`
- Pull all latest development from tidyverse packages by using
https://tidyverse.r-universe.dev/builds

`release` strategy can also use this if downstream packages are not
being release on CRAN

`min_***` strategy shouldn't use this option
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
question Further information is requested
Projects
None yet
Development

No branches or pull requests

2 participants