【问题标题】:R packrat snapshot: upgrading package gives "stale" errorsR packrat 快照:升级包给出“陈旧”错误
【发布时间】:2019-05-16 21:58:31
【问题描述】:

我正在使用packrat 来冻结应用程序的所有依赖项版本。有时我会遇到“陈旧”的问题。

例如,今天我将一个软件包升级到了较新的版本。我通过在 packrat-managed 项目中启动 R 来做到这一点:

% R --quiet
Packrat mode on. Using library in directory:
- "~/git/myapp/app/packrat/lib"
> install.packages('MyPackage')
Installing package into ‘/Users/kwilliams/git/myapp/app/packrat/lib/x86_64-apple-darwin17.7.0/3.5.3’
(as ‘lib’ is unspecified)
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100 3537k  100 3537k    0     0  5530k      0 --:--:-- --:--:-- --:--:-- 5527k
* installing *source* package ‘MyPackage’ ...
** R
** data
*** moving datasets to lazyload DB
** inst
** byte-compile and prepare package for lazy loading
** help
*** installing help indices
** building package indices
** installing vignettes
** testing if installed package can be loaded
* DONE (MyPackage)

The downloaded source packages are in
    ‘/private/var/folders/zp/hj5hqfw970z0_78mrb_802lm0001z9/T/RtmpzfYDUz/downloaded_packages’

但是,当我尝试生成新的快照文件时,没有任何反应:

> packrat::snapshot()
Snapshot written to '/Users/kwilliams/git/myapp/app/packrat/packrat.lock'

(文件和以前没有什么不同 - 仍然列出了旧版本的MyPackage。)

我确认确实安装了新版本,并再次尝试快照:

> packageVersion('MyPackage')
[1] ‘7.4’
> packrat::snapshot()

The following packages are stale:
              _    
    MyPackage   7.4

These packages must be updated by calling packrat::restore() before
snapshotting. If you are sure you want the installed versions of these
packages to be snapshotted, call packrat::snapshot() again with
ignore.stale=TRUE.
--
Snapshot operation was cancelled, no changes were made.

嗯?不知道为什么两次之间的结果不同。

status() 似乎确实了解情况:

> packrat::status()

The following packages are out of sync between packrat and your current library:
                    packrat   library
    MyPackage   7.3.1-22287       7.4

Use packrat::snapshot() to set packrat to use the current library, or use
packrat::restore() to reset the library to the last snapshot.

我想我会强迫它,所以我添加ignore.stale=TRUE

> packrat::snapshot(ignore.stale=TRUE)

Upgrading these packages already present in packrat:
                       from    to
    MyPackage   7.3.1-22287   7.4

Fetching sources for MyPackage (7.4) ... FAILED
Error in snapshotSources(project, activeRepos(project), allRecordsFlat) : 
  Errors occurred when fetching source files:
Error in getSourceForPkgRecord(pkgRecord, sourceDir, availablePkgs, repos) : 
  Could not find sources for MyPackage (7.4).

无赖。这可能与这是一个本地创建的包,从类似本地 CRAN 安装的事实有关吗?这将是一个packrat 错误,因为(如上所述)install.packages() 可以很好地找到源包。

所以我认为这里有两个潜在的packrat 错误:

  1. 无法对新安装的软件包进行快照
  2. 无法下载软件包的源代码

FWIW,我认为第一个问题与这里的情况相同:https://groups.google.com/forum/#!topic/packrat-discuss/HvD45u6w4Zg,其中 Kevin Ushey(packrat 的作者/维护者)说“围绕‘陈旧’包的逻辑可能会消失。”

【问题讨论】:

    标签: r package packrat


    【解决方案1】:

    以下是我正在使用的解决方法:

    1. 如上所述,使用ignore.stale=TRUE 强制创建快照,即使它认为事情已过时。

    2. 手动复制源码包到packrat/src/MyPackage/

    现在成功了:

    > packrat::snapshot(ignore.stale=TRUE)
    
    Upgrading these packages already present in packrat:
                           from    to
        MyPackage   7.3.1-22287   7.4
    
    Snapshot written to '/Users/kwilliams/git/myapp/app/packrat/packrat.lock'
    

    packrat/packrat.lock 文件已正确更新:

    % git diff
    diff --git a/app/packrat/packrat.lock b/app/packrat/packrat.lock
    index 6c17020..f717d29 100644
    --- a/app/packrat/packrat.lock
    +++ b/app/packrat/packrat.lock
    @@ -30,9 +30,9 @@ Hash: 9772da3bc51603a19a2b75f008fd63e3
    
     Package: MyPackage
     Source: source
    -Version: 7.3.1-22287
    +Version: 7.4
     SourcePath: lib/MyPackage
    -Hash: 4fe20417f5711b3c7c90a4efe3bb4bc7
    +Hash: 880a308537e8de571106893e839386f6
    ...
    

    【讨论】:

    • 手动复制源码好像在玩火。更谨慎的解决方案是将源代码复制到本地仓库并使用packrat::set_opts(local.repos = "<path_to_repo>")(“安装本地源代码包”部分here)。
    • 我有兴趣将您的安装问题与快照问题分开。如果你使用 ignore.stale=TRUE 但不将新的包源复制到 packrat 目录会发生什么?
    猜你喜欢
    • 1970-01-01
    • 2012-08-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-01-23
    • 1970-01-01
    • 2013-05-25
    • 1970-01-01
    相关资源
    最近更新 更多