Android WorkManager: PeriodicWorkRequest から出力データを取得できません 質問する

Android WorkManager: PeriodicWorkRequest から出力データを取得できません 質問する

何らかの理由で、Android WorkManager の PeriodicWorkRequest から出力データを取得できません。ワーカーは期待どおりに定期的に実行されますが、データを返しません。

私の主な活動:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    schedulePeriodicRequests();
}

public void schedulePeriodicRequests() {
    PeriodicWorkRequest workRequest = new PeriodicWorkRequest.Builder(ServerRequestsWorker.class, 15, TimeUnit.MINUTES)
            .build();

    WorkManager workManager = WorkManager.getInstance(MainActivity.this);
    workManager.enqueue(workRequest);
    workManager.getWorkInfoByIdLiveData(workRequest.getId())
            .observe(this, new Observer<WorkInfo>() {
                @Override
                public void onChanged(@Nullable WorkInfo workInfo) {
                    if (workInfo != null) {
                        Log.d(LOG_TAG, "WorkInfo received: state: " + workInfo.getState());
                        String message = workInfo.getOutputData().getString(ServerRequestsWorker.KEY_MESSAGE);
                        Log.d(LOG_TAG, "message: " + message);
                    }
                }
            });
}

私の ServerRequestsWorker:

public static final String KEY_MESSAGE = "message";

@NonNull
@Override
public Result doWork() {
    Log.d(LOG_TAG, "Worker works");

    Data outputData = new Data.Builder()
            .putString(KEY_MESSAGE, "This is output message")
            .build();

    return Result.success(outputData);
}

workInfo.getOutputData().getString の値は常に null です。ログに表示される内容は次のとおりです。

MainActivity: WorkInfo received: state: ENQUEUED
MainActivity: message: null
ServerRequestsWorker: Worker works
WM-WorkerWrapper: Worker result SUCCESS for Work [ id=5f2beba8-c8bf-4f07-b4ee-e876e95d3cdb, tags={ com.anshmidt.pricemonitor.ServerRequestsWorker } ]
MainActivity: WorkInfo received: state: RUNNING
MainActivity: message: null
MainActivity: WorkInfo received: state: ENQUEUED
MainActivity: message: null

興味深いのはOneTimeWorkRequestからの出力データの取得は正常に動作していますPeriodicWorkRequest から OneTimeWorkRequest に切り替えると、次のようになります。

    OneTimeWorkRequest serverScraperWorkRequest = new OneTimeWorkRequest.Builder(ServerRequestsWorker.class)
            .build();

    WorkManager workManager = WorkManager.getInstance(MainActivity.this);
    workManager.enqueue(serverScraperWorkRequest);
    workManager.getWorkInfoByIdLiveData(serverScraperWorkRequest.getId())
            .observe(this, new Observer<WorkInfo>() {
                @Override
                public void onChanged(@Nullable WorkInfo workInfo) {
                    if (workInfo != null) {
                        Log.d(LOG_TAG, "WorkInfo received: state: " + workInfo.getState());
                        String message = workInfo.getOutputData().getString(ServerRequestsWorker.KEY_MESSAGE);
                        Log.d(LOG_TAG, "message: " + message);
                    }
                }
            });

すると、出力データから値を正常に受け取ることができます。

MainActivity: message: This is output message

一意の作業をキューに登録したり、タグでキューに登録したりしてみましたが、うまくいきませんでした。WorkManager 2.2.0 と 1.x を試しましたが、結果は同じでした。

何か見落としているのでしょうか? PeriodicWorkRequest から出力データを取得することは可能ですか? 何が間違っているのでしょうか?

ベストアンサー1

によるとWorkInfoドキュメンテーション:

出力はターミナル状態(作業情報.状態.成功そして作業情報.状態.失敗)。

定期的な作業の場合、実行ごとに同じ ID が再利用されるため、作業が に到達することはありません。SUCCEEDED代わりに、作業はすぐに に戻りENQUEUED、次の定期的な実行を待機します。したがって、発生している動作は予想される動作であると思われます。

ご覧のとおり、1回限りの作業ではこの動作は発生しません。作業は実際に実行されSUCCEEDED、その後の実行ごとに(1回限りの作業で同じタイプの作業を再スケジュールする場合)、新しいIDが付与されるからです。もう1つの方法は、ない出力データを使用する代わりに、定期的な作業の結果を独自のデータベースに保存します。

おすすめ記事