launchd parece ignorar StartCalendarInterval em Yosemite

9

Tentei atualizar o Homebrew a tempo com o launchd. Meu arquivo plist é apresentado aqui:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
  <key>Label</key>
  <string>ms.liu.homebrew.update</string>
  <key>UserName</key>
  <string>LiuMS</string>
  <key>ProcessType</key>
  <string>Background</string>
  <key>EnvironmentVariables</key>
  <key>ProgramArguments</key>
  <array>
    <string>/usr/local/bin/brew</string>
    <string>update</string>
  </array>
  <key>StartCalendarInterval</key>
  <dict>
    <key>Hour</key>
    <integer>20</integer>
    <key>Minute</key>
    <integer>0</integer>
  </dict>
  <key>StandardOutPath</key>
  <string>/usr/local/logs/ms.liu.homebrew.update.out</string>
  <key>StandardErrorPath</key>
  <string>/usr/local/logs/ms.liu.homebrew.update.err</string>
</dict>
</plist>

Funciona de alguma forma: posso executar launchctl start ms.liu.homebrew.updatemanualmente para atualizar meu Homebrew. No entanto, o launchd não executa este serviço periodicamente: as últimas alterações no arquivo para o qual o stdout redireciona são dois dias atrás.

Tentei obter informações sobre este serviço, mas não obtive nada:

> launchctl print user/%MyPID%/ms.liu.homebrew.update`` 
Could not find service "ms.liu.homebrew.update" in domain for uid: %MyPID%

Parece que não carreguei meu serviço com sucesso. Quão? Eu usei, launchctl loadmas parece que foi preterido. A página de manual recomenda a inicialização:

> launchctl bootstrap user/%MyPID% %Path-to-plist%
> %Path-to-plist%: Service cannot load in requested session

O que devo fazer? Como usar corretamente launchctl bootstrape launchctl print?

Estou executando o Candidato 1 do OS X Yosemite GM no MacBookPro com tela Retina (2013).

Minsheng Liu
fonte

Respostas:

2

Estou apenas começando a resolver essas coisas, então essa resposta é provisória - mas espero que seja mais útil do que nenhuma resposta. (Eu o teria deixado como um comentário se tivesse representante suficiente.)

Esta lista está no seu ~/Library/LaunchAgentsdiretório? Parece que eles foram iniciados no seu guidomínio, não no seu userdomínio. Então você pode fazer:

launchctl print gui/%UID%/ms.liu.homebrew.update

e deve funcionar. (Faz?)

Presumivelmente, o motivo pelo qual você não pode inicializá-lo no userdomínio é que ele já está inicializado no guidomínio.

Robin Houston
fonte