Welcome to mirror list, hosted at ThFree Co, Russian Federation.

README.md « promise-all-reject-late « node_modules - github.com/npm/cli.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: eda7c70627f6324740037cce321c893df83270a2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# promise-all-reject-late

Like Promise.all, but save rejections until all promises are resolved.

This is handy when you want to do a bunch of things in parallel, and
rollback on failure, without clobbering or conflicting with those parallel
actions that may be in flight.  For example, creating a bunch of files,
and deleting any if they don't all succeed.

Example:

```js
const lateReject = require('promise-all-reject-late')

const { promisify } = require('util')
const fs = require('fs')
const writeFile = promisify(fs.writeFile)

const createFilesOrRollback = (files) => {
  return lateReject(files.map(file => writeFile(file, 'some data')))
    .catch(er => {
      // try to clean up, then fail with the initial error
      // we know that all write attempts are finished at this point
      return lateReject(files.map(file => rimraf(file)))
        .catch(er => {
          console.error('failed to clean up, youre on your own i guess', er)
        })
        .then(() => {
          // fail with the original error
          throw er
        })
    })
}
```

## API

* `lateReject([array, of, promises])` - Resolve all the promises,
  returning a promise that rejects with the first error, or resolves with
  the array of results, but only after all promises are settled.