Fixed
Status Update
Comments
ra...@google.com <ra...@google.com> #2
ap...@google.com <ap...@google.com> #3
Project: platform/frameworks/support
Branch: androidx-master-dev
commit 383ea4ed58fb94f6ac52a76607542359a3ec41c5
Author: Rahul Ravikumar <rahulrav@google.com>
Date: Fri Oct 05 12:50:24 2018
Relax the restriction on WorkContinuation#combine.
* We allow the combine to happen even though we only have a single
continuation being combined.
Test: Existing tests pass
Change-Id: I84ffe3ecd6fea2b4d99459b4e5ed599ceaf4d768
Fixes: b/117266752
M work/workmanager/src/main/java/androidx/work/WorkContinuation.java
https://android-review.googlesource.com/780040
https://goto.google.com/android-sha1/383ea4ed58fb94f6ac52a76607542359a3ec41c5
Branch: androidx-master-dev
commit 383ea4ed58fb94f6ac52a76607542359a3ec41c5
Author: Rahul Ravikumar <rahulrav@google.com>
Date: Fri Oct 05 12:50:24 2018
Relax the restriction on WorkContinuation#combine.
* We allow the combine to happen even though we only have a single
continuation being combined.
Test: Existing tests pass
Change-Id: I84ffe3ecd6fea2b4d99459b4e5ed599ceaf4d768
Fixes:
M work/workmanager/src/main/java/androidx/work/WorkContinuation.java
[Deleted User] <[Deleted User]> #4
Marvelous!
Description
Version used: alpha09
Devices/Android versions reproduced on:
When using WorkContinuation.combine to join multiple works before continuing, it has a check in it to make sure it's acutally combining multiple WorkContinuations. I think this check is uneccessary and annoying, and adds a hard to find bug in implementations. The combine() method could easily just do nothing if there's only a single WorkContinuation passed to it.
Current use case:
I'm uploading a number of photos, which I'm splitting into a number of WorkContinuation lists so that several happen in parallel. If I only have one photo to upload then obviously I can only split this into one list of work, and the app crashes because WorkContinuation.combine() 'cannot' combine a single item. To fix this I have to have this code:
```
val allCombined = if (workLists.size == 1) workLists[0] else WorkContinuation.combine(workLists)
allCombined.then(....
```
which is much less nice than the original code which I think should work:
```
WorkContinuation.combine(workLists)
.then(....
```