Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Windows side-effects for install.packages with dependencies on to-be-checked package #134

Closed
hsloot opened this issue Dec 17, 2020 · 4 comments
Labels
bug an unexpected problem or unintended behavior
Milestone

Comments

@hsloot
Copy link

hsloot commented Dec 17, 2020

Description

If install.packages or remotes::install_* are called in the testthat setup for a package that imports the package on which rcmdcheck is run, the install command seems to behave differently on Windows. In particular, the temporary library of the to-be-checked package seems to be ignored. The consequence is either that this package is installed a second time (if the upgrade is possible and sources are available) or that the install fails. This error only appears if the to-be-checked package is not installed already when rcmdcheck is called. This does not happen if R CMD build and R CMD check are run on the terminal directly.

I am not entirely sure if that is a bug of rcmdcheck, but since it does not happen with R CMD build and R CMD check, it is at least unexpected behaviour.

Background

I have a package for which I have bundled lots of (dependent) code only relevant for testing in a separate package. Since this code is only relevant for the package itself, I stored it in the tests/testthat directory and tried to install in the testthat setup. This broke my GH action CI check on Windows.

Example

I created an example with two commits on https://github.com/hsloot/rtestlib which both run an action with rcmdcheck on Windows, Linux and Mac, the last commit fixes the problem on Windows, but only by allowing remotes::install_* to install missing dependencies.

@gaborcsardi
Copy link
Member

Installing packages is a flaky thing, and I would run it during tests. You can also add extra functions that are only used in tests to a tests/testthat/helper.R file.

@gaborcsardi gaborcsardi added the bug an unexpected problem or unintended behavior label Dec 18, 2020
@gaborcsardi
Copy link
Member

@hsloot Is this still a problem? DO you have an example package that demonstrates the issue?

@hsloot
Copy link
Author

hsloot commented Sep 8, 2021

@gaborcsardi Yes, it is still a problem. In the original description, I linked a Github repository with an example. Unfortunately, the logs were deleted by now, but I created two new branches corresponding the commits that I mentioned in the original description (succeeding with the fix and failing without the fix) to re-run the actions.

The example is not perfect since I could not find the root cause of why the command is behaving differently on Windows and why it does not happen with R CMD BUILD and R CMD CHECK. In my understanding, the issue occurs if the package on which rcmdcheck is run is not itself installed (which will often be the case in CI), and the package I try to install in the test setup depends on the to-be-checked package (you can think of the additional package as a support package for testing; e.g. with fuzzing functions for the parameter domains of various implemented functions). Since the to-be-checked package is built and installed by rcmdcheck before the tests are run, this should not be an issue (it is only one for Windows with rcmdcheck). Apparently, the temporary library, in which the to-be-checked package is installed, is not visible in calls to remotes::install_* or install.packages.

@gaborcsardi gaborcsardi added this to the 2.0.0 milestone Sep 9, 2021
@gaborcsardi
Copy link
Member

OK, I managed to hunt this down. It happens because callr sets R_ENVIRON etc. in the R sub-process, and although this is not used by the check process, it is apparently used in some of its sub-processes, e.g. the processes started for the test files on Windows.

I think I can fix this.

For FWIW your workaround does not work for me, but putting this in setup.R before the installation does:

Sys.unsetenv("R_ENVIRON")
Sys.unsetenv("R_ENVIRON_USER")
Sys.unsetenv("R_PROFILE")
Sys.unsetenv("R_PROFILE_USER")

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
bug an unexpected problem or unintended behavior
Projects
None yet
Development

No branches or pull requests

2 participants