You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
checkout/src
Johannes Schindelin 5a4ac9002d
Add missing `await`s (#379)
* auth-helper: properly await replacement of the token value in the config

After writing the `.extraheader` config, we manually replace the token
with the actual value. This is done in an `async` function, but we were
not `await`ing the result.

In our tests, this commit fixes a flakiness we observed where
`remote.origin.url` sometimes (very rarely, actually) is not set for
submodules. Our interpretation is that the configs are in the process of
being rewritten with the correct token value _while_ another `git
config` that wants to set the `insteadOf` value is reading the config,
which is currently empty.

A more idiomatic way to fix this in Typescript would use
`Promise.all()`, like this:

      await Promise.all(
        configPaths.map(async configPath => {
          core.debug(`Replacing token placeholder in '${configPath}'`)
          await this.replaceTokenPlaceholder(configPath)
        })
      )

However, during review of https://github.com/actions/checkout/pull/379
it was decided to keep the `for` loop in the interest of simplicity.

Reported by Ian Lynagh.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>

* downloadRepository(): await the result of recursive deletions

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>

* Ask ESLint to report floating Promises

This rule is quite helpful in avoiding hard-to-debug missing `await`s.

Note: there are two locations in `src/main.ts` that trigger warnings:
the `run()` and the `cleanup()` function are called without `await` and
without any `.catch()` clause.

In the initial version of https://github.com/actions/checkout/pull/379,
this was addressed by adding `.catch()` clauses. However, it was
determined that this is boilerplate code that will need to be fixed in a
broader way.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>

* Rebuild

This trick was brought to you by `npm ci && npm run build`. Needed to
get the PR build to pass.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
5 years ago
..
misc add ssh support (#163) 6 years ago
fs-helper.ts Convert checkout to a regular action (#70) 6 years ago
git-auth-helper.ts Add missing `await`s (#379) 5 years ago
git-command-manager.ts Remove unneeded commit information from build logs (#345) 5 years ago
git-directory-helper.ts Fetch all history for all tags and branches when fetch-depth=0 (#258) 5 years ago
git-source-provider.ts Remove unneeded commit information from build logs (#345) 5 years ago
git-source-settings.ts group output (#191) 6 years ago
git-version.ts Convert checkout to a regular action (#70) 6 years ago
github-api-helper.ts Add missing `await`s (#379) 5 years ago
input-helper.ts update default branch (#305) 5 years ago
main.ts fallback to REST API to download repo (#104) 6 years ago
ref-helper.ts Fetch all history for all tags and branches when fetch-depth=0 (#258) 5 years ago
regexp-helper.ts add support for submodules (#173) 6 years ago
retry-helper.ts fallback to REST API to download repo (#104) 6 years ago
state-helper.ts add ssh support (#163) 6 years ago
url-helper.ts switch GITHUB_URL to GITHUB_SERVER_URL (#248) 6 years ago