R packrat снимок: пакет обновления выдает "устаревшие" ошибки - PullRequest
0 голосов
/ 17 мая 2019

Я использую packrat, чтобы заморозить все версии зависимостей для приложения. Иногда я сталкиваюсь с неприятностями из-за "застоя".

Например, сегодня я обновил один пакет до более новой версии. Я сделал это, запустив R в packrat -управляемом проекте:

% 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,, в которой Кевин Уши (автор / сопровождающий packrat) говорит, что «возможно, что логика вокруг« устаревших »пакетов может просто уходи. "

1 Ответ

0 голосов
/ 17 мая 2019

Вот обходные пути, которые я использую, чтобы вернуться на свой путь:

  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
...
...