Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
H
heroku-buildpack-nodejs
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
JIRA
JIRA
Merge Requests
0
Merge Requests
0
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Python-Dev
heroku-buildpack-nodejs
Commits
34818989
Unverified
Commit
34818989
authored
Mar 28, 2019
by
Jeremy Morrell
Committed by
GitHub
Mar 28, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add metadata logging when the build fails (#630)
* Add metadata logging when the build fails
parent
99ebd7cb
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
79 additions
and
15 deletions
+79
-15
compile
bin/compile
+2
-0
builddata.sh
lib/builddata.sh
+1
-0
failure.sh
lib/failure.sh
+61
-11
run
test/run
+15
-4
No files found.
bin/compile
View file @
34818989
...
@@ -70,6 +70,7 @@ handle_failure() {
...
@@ -70,6 +70,7 @@ handle_failure() {
echo
" Read more: https://devcenter.heroku.com/changelog-items/1573"
echo
" Read more: https://devcenter.heroku.com/changelog-items/1573"
echo
""
echo
""
meta_set
"node-build-success"
"false"
header
"Build failed"
header
"Build failed"
fail_yarn_outdated
"
$LOG_FILE
"
fail_yarn_outdated
"
$LOG_FILE
"
fail_yarn_lockfile_outdated
"
$LOG_FILE
"
fail_yarn_lockfile_outdated
"
$LOG_FILE
"
...
@@ -81,6 +82,7 @@ handle_failure() {
...
@@ -81,6 +82,7 @@ handle_failure() {
warn_angular_resolution
"
$LOG_FILE
"
warn_angular_resolution
"
$LOG_FILE
"
warn_missing_devdeps
"
$LOG_FILE
"
"
$BUILD_DIR
"
warn_missing_devdeps
"
$LOG_FILE
"
"
$BUILD_DIR
"
warn_econnreset
"
$LOG_FILE
"
warn_econnreset
"
$LOG_FILE
"
log_meta_data
>>
"
$BUILDPACK_LOG_FILE
"
failure_message | output
"
$LOG_FILE
"
failure_message | output
"
$LOG_FILE
"
}
}
trap
'handle_failure'
ERR
trap
'handle_failure'
ERR
...
...
lib/builddata.sh
View file @
34818989
#!/usr/bin/env bash
#!/usr/bin/env bash
log_initial_state
()
{
log_initial_state
()
{
meta_set
"buildpack"
"nodejs"
if
"
$YARN
"
;
then
if
"
$YARN
"
;
then
meta_set
"node-package-manager"
"yarn"
meta_set
"node-package-manager"
"yarn"
meta_set
"has-node-lock-file"
"true"
meta_set
"has-node-lock-file"
"true"
...
...
lib/failure.sh
View file @
34818989
...
@@ -9,6 +9,11 @@ detect_package_manager() {
...
@@ -9,6 +9,11 @@ detect_package_manager() {
esac
esac
}
}
fail
()
{
log_meta_data
>>
"
$BUILDPACK_LOG_FILE
"
exit
1
}
failure_message
()
{
failure_message
()
{
local
warn
local
warn
...
@@ -40,13 +45,17 @@ fail_invalid_package_json() {
...
@@ -40,13 +45,17 @@ fail_invalid_package_json() {
if
"
$is_invalid
"
;
then
if
"
$is_invalid
"
;
then
error
"Unable to parse package.json"
error
"Unable to parse package.json"
mcount
'failures.parse.package-json'
mcount
'failures.parse.package-json'
return
1
meta_set
"failure"
"invalid-package-json"
header
"Build failed"
failure_message
fail
fi
fi
}
}
fail_dot_heroku
()
{
fail_dot_heroku
()
{
if
[
-f
"
${
1
:-}
/.heroku"
]
;
then
if
[
-f
"
${
1
:-}
/.heroku"
]
;
then
mcount
"failures.dot-heroku"
mcount
"failures.dot-heroku"
meta_set
"failure"
"dot-heroku"
header
"Build failed"
header
"Build failed"
warn
"The directory .heroku could not be created
warn
"The directory .heroku could not be created
...
@@ -55,13 +64,14 @@ fail_dot_heroku() {
...
@@ -55,13 +64,14 @@ fail_dot_heroku() {
binaries like the node runtime and npm. You should remove the
binaries like the node runtime and npm. You should remove the
.heroku file or ignore it by adding it to .slugignore
.heroku file or ignore it by adding it to .slugignore
"
"
exit
1
fail
fi
fi
}
}
fail_dot_heroku_node
()
{
fail_dot_heroku_node
()
{
if
[
-f
"
${
1
:-}
/.heroku/node"
]
;
then
if
[
-f
"
${
1
:-}
/.heroku/node"
]
;
then
mcount
"failures.dot-heroku-node"
mcount
"failures.dot-heroku-node"
meta_set
"failure"
"dot-heroku-node"
header
"Build failed"
header
"Build failed"
warn
"The directory .heroku/node could not be created
warn
"The directory .heroku/node could not be created
...
@@ -70,7 +80,7 @@ fail_dot_heroku_node() {
...
@@ -70,7 +80,7 @@ fail_dot_heroku_node() {
binaries like the node runtime and npm. You should remove the
binaries like the node runtime and npm. You should remove the
.heroku file or ignore it by adding it to .slugignore
.heroku file or ignore it by adding it to .slugignore
"
"
exit
1
fail
fi
fi
}
}
...
@@ -82,6 +92,7 @@ fail_multiple_lockfiles() {
...
@@ -82,6 +92,7 @@ fail_multiple_lockfiles() {
if
[
-f
"
${
1
:-}
/yarn.lock"
]
&&
[
-f
"
${
1
:-}
/package-lock.json"
]
;
then
if
[
-f
"
${
1
:-}
/yarn.lock"
]
&&
[
-f
"
${
1
:-}
/package-lock.json"
]
;
then
mcount
"failures.two-lock-files"
mcount
"failures.two-lock-files"
meta_set
"failure"
"two-lock-files"
header
"Build failed"
header
"Build failed"
warn
"Two different lockfiles found: package-lock.json and yarn.lock
warn
"Two different lockfiles found: package-lock.json and yarn.lock
...
@@ -100,11 +111,12 @@ fail_multiple_lockfiles() {
...
@@ -100,11 +111,12 @@ fail_multiple_lockfiles() {
$
git rm package-lock.json
$
git rm package-lock.json
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-conflicting-lock-files
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-conflicting-lock-files
exit
1
fail
fi
fi
if
$has_modern_lockfile
&&
[
-f
"
${
1
:-}
/npm-shrinkwrap.json"
]
;
then
if
$has_modern_lockfile
&&
[
-f
"
${
1
:-}
/npm-shrinkwrap.json"
]
;
then
mcount
"failures.shrinkwrap-lock-file-conflict"
mcount
"failures.shrinkwrap-lock-file-conflict"
meta_set
"failure"
"shrinkwrap-lock-file-conflict"
header
"Build failed"
header
"Build failed"
warn
"Two different lockfiles found
warn
"Two different lockfiles found
...
@@ -123,7 +135,7 @@ fail_multiple_lockfiles() {
...
@@ -123,7 +135,7 @@ fail_multiple_lockfiles() {
- package-lock.json
- package-lock.json
- npm-shrinkwrap.json
- npm-shrinkwrap.json
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-conflicting-lock-files
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-conflicting-lock-files
exit
1
fail
fi
fi
}
}
...
@@ -134,6 +146,7 @@ fail_yarn_outdated() {
...
@@ -134,6 +146,7 @@ fail_yarn_outdated() {
if
grep
-qi
'error .install. has been replaced with .add. to add new dependencies'
"
$log_file
"
;
then
if
grep
-qi
'error .install. has been replaced with .add. to add new dependencies'
"
$log_file
"
;
then
yarn_engine
=
$(
yarn
--version
)
yarn_engine
=
$(
yarn
--version
)
mcount
"failures.outdated-yarn"
mcount
"failures.outdated-yarn"
meta_set
"failure"
"outdated-yarn"
echo
""
echo
""
warn
"Outdated Yarn version:
$yarn_engine
warn
"Outdated Yarn version:
$yarn_engine
...
@@ -146,7 +159,7 @@ fail_yarn_outdated() {
...
@@ -146,7 +159,7 @@ fail_yarn_outdated() {
\"
yarn
\"
:
\"
1.3.2
\"
\"
yarn
\"
:
\"
1.3.2
\"
}
}
"
https://devcenter.heroku.com/articles/nodejs-support#specifying-a-yarn-version
"
https://devcenter.heroku.com/articles/nodejs-support#specifying-a-yarn-version
exit
1
fail
fi
fi
}
}
...
@@ -154,6 +167,7 @@ fail_yarn_lockfile_outdated() {
...
@@ -154,6 +167,7 @@ fail_yarn_lockfile_outdated() {
local
log_file
=
"
$1
"
local
log_file
=
"
$1
"
if
grep
-qi
'Your lockfile needs to be updated'
"
$log_file
"
;
then
if
grep
-qi
'Your lockfile needs to be updated'
"
$log_file
"
;
then
mcount
"failures.outdated-yarn-lockfile"
mcount
"failures.outdated-yarn-lockfile"
meta_set
"failure"
"outdated-yarn-lockfile"
echo
""
echo
""
warn
"Outdated Yarn lockfile
warn
"Outdated Yarn lockfile
...
@@ -169,7 +183,7 @@ fail_yarn_lockfile_outdated() {
...
@@ -169,7 +183,7 @@ fail_yarn_lockfile_outdated() {
$
git commit -m
\"
Updated Yarn lockfile
\"
$
git commit -m
\"
Updated Yarn lockfile
\"
$
git push heroku master
$
git push heroku master
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-an-outdated-yarn-lockfile
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-an-outdated-yarn-lockfile
exit
1
fail
fi
fi
}
}
...
@@ -206,6 +220,7 @@ fail_node_install() {
...
@@ -206,6 +220,7 @@ fail_node_install() {
if
grep
-qi
'Could not find Node version corresponding to version requirement'
"
$log_file
"
;
then
if
grep
-qi
'Could not find Node version corresponding to version requirement'
"
$log_file
"
;
then
node_engine
=
$(
read_json
"
$build_dir
/package.json"
".engines.node"
)
node_engine
=
$(
read_json
"
$build_dir
/package.json"
".engines.node"
)
mcount
"failures.invalid-node-version"
mcount
"failures.invalid-node-version"
meta_set
"failure"
"invalid-node-version"
echo
""
echo
""
warn
"No matching version found for Node:
$node_engine
warn
"No matching version found for Node:
$node_engine
...
@@ -227,7 +242,7 @@ fail_node_install() {
...
@@ -227,7 +242,7 @@ fail_node_install() {
\"
node
\"
:
\"
6.11.1
\"
\"
node
\"
:
\"
6.11.1
\"
}
}
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-no-matching-node-versions
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-no-matching-node-versions
exit
1
fail
fi
fi
}
}
...
@@ -239,6 +254,7 @@ fail_yarn_install() {
...
@@ -239,6 +254,7 @@ fail_yarn_install() {
if
grep
-qi
'Could not find Yarn version corresponding to version requirement'
"
$log_file
"
;
then
if
grep
-qi
'Could not find Yarn version corresponding to version requirement'
"
$log_file
"
;
then
yarn_engine
=
$(
read_json
"
$build_dir
/package.json"
".engines.yarn"
)
yarn_engine
=
$(
read_json
"
$build_dir
/package.json"
".engines.yarn"
)
mcount
"failures.invalid-yarn-version"
mcount
"failures.invalid-yarn-version"
meta_set
"failure"
"invalid-yarn-version"
echo
""
echo
""
warn
"No matching version found for Yarn:
$yarn_engine
warn
"No matching version found for Yarn:
$yarn_engine
...
@@ -262,7 +278,7 @@ fail_yarn_install() {
...
@@ -262,7 +278,7 @@ fail_yarn_install() {
\"
yarn
\"
:
\"
0.27.5
\"
\"
yarn
\"
:
\"
0.27.5
\"
}
}
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-no-matching-yarn-versions
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-no-matching-yarn-versions
exit
1
fail
fi
fi
}
}
...
@@ -270,6 +286,7 @@ fail_invalid_semver() {
...
@@ -270,6 +286,7 @@ fail_invalid_semver() {
local
log_file
=
"
$1
"
local
log_file
=
"
$1
"
if
grep
-qi
'Error: Invalid semantic version'
"
$log_file
"
;
then
if
grep
-qi
'Error: Invalid semantic version'
"
$log_file
"
;
then
mcount
"failures.invalid-semver-requirement"
mcount
"failures.invalid-semver-requirement"
meta_set
"invalid-semver-requirement"
echo
""
echo
""
warn
"Invalid semver requirement
warn
"Invalid semver requirement
...
@@ -281,7 +298,7 @@ fail_invalid_semver() {
...
@@ -281,7 +298,7 @@ fail_invalid_semver() {
However you have specified a version requirement that is not a valid
However you have specified a version requirement that is not a valid
semantic version.
semantic version.
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-an-invalid-semver-requirement
"
https://kb.heroku.com/why-is-my-node-js-build-failing-because-of-an-invalid-semver-requirement
exit
1
fail
fi
fi
}
}
...
@@ -289,26 +306,31 @@ log_other_failures() {
...
@@ -289,26 +306,31 @@ log_other_failures() {
local
log_file
=
"
$1
"
local
log_file
=
"
$1
"
if
grep
-qi
"sh: 1: .*: not found"
"
$log_file
"
;
then
if
grep
-qi
"sh: 1: .*: not found"
"
$log_file
"
;
then
mcount
"failures.dev-dependency-tool-not-installed"
mcount
"failures.dev-dependency-tool-not-installed"
meta_set
"failure"
"dev-dependency-tool-not-installed"
return
0
return
0
fi
fi
if
grep
-qi
"Failed at the bcrypt@
\d
.
\d
.
\d
install script"
"
$log_file
"
;
then
if
grep
-qi
"Failed at the bcrypt@
\d
.
\d
.
\d
install script"
"
$log_file
"
;
then
mcount
"failures.bcrypt-permissions-issue"
mcount
"failures.bcrypt-permissions-issue"
meta_set
"failure"
"bcrypt-permissions-issue"
return
0
return
0
fi
fi
if
grep
-qi
"Versions of @angular/compiler-cli and typescript could not be determined"
"
$log_file
"
;
then
if
grep
-qi
"Versions of @angular/compiler-cli and typescript could not be determined"
"
$log_file
"
;
then
mcount
"failures.ng-cli-version-issue"
mcount
"failures.ng-cli-version-issue"
meta_set
"failure"
"ng-cli-version-issue"
return
0
return
0
fi
fi
if
grep
-qi
"Cannot read property '0' of undefined"
"
$log_file
"
;
then
if
grep
-qi
"Cannot read property '0' of undefined"
"
$log_file
"
;
then
mcount
"failures.npm-property-zero-issue"
mcount
"failures.npm-property-zero-issue"
meta_set
"failure"
"npm-property-zero-issue"
return
0
return
0
fi
fi
if
grep
-qi
"npm is known not to run on Node.js v
\d
.
\d
.
\d
"
"
$log_file
"
;
then
if
grep
-qi
"npm is known not to run on Node.js v
\d
.
\d
.
\d
"
"
$log_file
"
;
then
mcount
"failures.npm-known-bad-version"
mcount
"failures.npm-known-bad-version"
meta_set
"failure"
"npm-known-bad-version"
return
0
return
0
fi
fi
...
@@ -316,76 +338,91 @@ log_other_failures() {
...
@@ -316,76 +338,91 @@ log_other_failures() {
# "error Couldn't find any versions for" = yarn
# "error Couldn't find any versions for" = yarn
if
grep
-q
-e
"notarget No matching version found for"
-e
"error Couldn't find any versions for"
"
$log_file
"
;
then
if
grep
-q
-e
"notarget No matching version found for"
-e
"error Couldn't find any versions for"
"
$log_file
"
;
then
mcount
"failures.bad-version-for-dependency"
mcount
"failures.bad-version-for-dependency"
meta_set
"failure"
"bad-version-for-dependency"
return
0
return
0
fi
fi
if
grep
-qi
"You are likely using a version of node-tar or npm that is incompatible with this version of Node.js"
"
$log_file
"
;
then
if
grep
-qi
"You are likely using a version of node-tar or npm that is incompatible with this version of Node.js"
"
$log_file
"
;
then
mcount
"failures.node-9-npm-issue"
mcount
"failures.node-9-npm-issue"
meta_set
"failure"
"node-9-npm-issue"
return
0
return
0
fi
fi
if
grep
-qi
"console.error(
\`
a bug known to break npm"
"
$log_file
"
;
then
if
grep
-qi
"console.error(
\`
a bug known to break npm"
"
$log_file
"
;
then
mcount
"failures.old-node-new-npm"
mcount
"failures.old-node-new-npm"
meta_set
"failure"
"old-node-new-npm"
return
0
return
0
fi
fi
if
grep
-qi
"CALL_AND_RETRY_LAST Allocation failed"
"
$log_file
"
;
then
if
grep
-qi
"CALL_AND_RETRY_LAST Allocation failed"
"
$log_file
"
;
then
mcount
"failures.build-out-of-memory-error"
mcount
"failures.build-out-of-memory-error"
meta_set
"failure"
"build-out-of-memory-error"
return
0
return
0
fi
fi
if
grep
-qi
"enoent ENOENT: no such file or directory"
"
$log_file
"
;
then
if
grep
-qi
"enoent ENOENT: no such file or directory"
"
$log_file
"
;
then
mcount
"failures.npm-enoent"
mcount
"failures.npm-enoent"
meta_set
"failure"
"npm-enoent"
return
0
return
0
fi
fi
if
grep
-qi
"ERROR in [^ ]* from UglifyJs"
"
$log_file
"
;
then
if
grep
-qi
"ERROR in [^ ]* from UglifyJs"
"
$log_file
"
;
then
mcount
"failures.uglifyjs"
mcount
"failures.uglifyjs"
meta_set
"failure"
"uglifyjs"
return
0
return
0
fi
fi
# https://github.com/angular/angular-cli/issues/4551
# https://github.com/angular/angular-cli/issues/4551
if
grep
-qi
"Module not found: Error: Can't resolve '
\.\/\$\$
_gendir
\/
app
\/
app
\.
module
\.
ngfactory'"
"
$log_file
"
;
then
if
grep
-qi
"Module not found: Error: Can't resolve '
\.\/\$\$
_gendir
\/
app
\/
app
\.
module
\.
ngfactory'"
"
$log_file
"
;
then
mcount
"failures.ng-cli-issue-4551"
mcount
"failures.ng-cli-issue-4551"
meta_set
"failure"
"ng-cli-issue-4551"
return
0
return
0
fi
fi
if
grep
-qi
"Host key verification failed"
"
$log_file
"
;
then
if
grep
-qi
"Host key verification failed"
"
$log_file
"
;
then
mcount
"failures.private-git-dependency-without-auth"
mcount
"failures.private-git-dependency-without-auth"
meta_set
"failure"
"private-git-dependency-without-auth"
return
0
return
0
fi
fi
# same as the next test, but isolate bcyrpt specifically
# same as the next test, but isolate bcyrpt specifically
if
grep
-qi
"Failed at the bcrypt@
\d\.\d\.\d
install"
"
$log_file
"
;
then
if
grep
-qi
"Failed at the bcrypt@
\d\.\d\.\d
install"
"
$log_file
"
;
then
mcount
"failures.bcrypt-failed-to-build"
mcount
"failures.bcrypt-failed-to-build"
meta_set
"failure"
"bcrypt-failed-to-build"
return
0
return
0
fi
fi
if
grep
-qi
"Failed at the [^ ]* install script"
"
$log_file
"
;
then
if
grep
-qi
"Failed at the [^ ]* install script"
"
$log_file
"
;
then
mcount
"failures.dependency-failed-to-build"
mcount
"failures.dependency-failed-to-build"
meta_set
"failure"
"dependency-failed-to-build"
return
0
return
0
fi
fi
if
grep
-qi
"Line
\d
*: '.*' is not defined"
"
$log_file
"
;
then
if
grep
-qi
"Line
\d
*: '.*' is not defined"
"
$log_file
"
;
then
mcount
"failures.undefined-variable-lint"
mcount
"failures.undefined-variable-lint"
meta_set
"failure"
"undefined-variable-lint"
return
0
return
0
fi
fi
if
grep
-qi
"npm ERR! code EBADPLATFORM"
"
$log_file
"
;
then
if
grep
-qi
"npm ERR! code EBADPLATFORM"
"
$log_file
"
;
then
mcount
"failures.npm-ebadplatform"
mcount
"failures.npm-ebadplatform"
meta_set
"failure"
"npm-ebadplatform"
return
0
return
0
fi
fi
if
grep
-qi
"npm ERR! code EINVALIDPACKAGENAME"
"
$log_file
"
;
then
if
grep
-qi
"npm ERR! code EINVALIDPACKAGENAME"
"
$log_file
"
;
then
mcount
"failures.npm-package-name-typo"
mcount
"failures.npm-package-name-typo"
meta_set
"failure"
"npm-package-name-typo"
return
0
return
0
fi
fi
if
grep
-qi
-e
"npm ERR! code E404"
-e
"error An unexpected error occurred: .* Request failed
\"
404 Not Found
\"
"
"
$log_file
"
;
then
if
grep
-qi
-e
"npm ERR! code E404"
-e
"error An unexpected error occurred: .* Request failed
\"
404 Not Found
\"
"
"
$log_file
"
;
then
mcount
"failures.module-404"
mcount
"failures.module-404"
meta_set
"failure"
"module-404"
if
grep
-qi
"flatmap-stream"
"
$log_file
"
;
then
if
grep
-qi
"flatmap-stream"
"
$log_file
"
;
then
mcount
"flatmap-stream-404"
mcount
"flatmap-stream-404"
meta_set
"failure"
"flatmap-stream-404"
warn
"The flatmap-stream module has been removed from the npm registry
warn
"The flatmap-stream module has been removed from the npm registry
On November 26th, npm was notified of a malicious package that had made its
On November 26th, npm was notified of a malicious package that had made its
...
@@ -393,7 +430,7 @@ log_other_failures() {
...
@@ -393,7 +430,7 @@ log_other_failures() {
npm responded by removing flatmap-stream and event-stream@3.3.6 from the Registry
npm responded by removing flatmap-stream and event-stream@3.3.6 from the Registry
and taking ownership of the event-stream package to prevent further abuse.
and taking ownership of the event-stream package to prevent further abuse.
"
https://kb.heroku.com/4OM7X18J/why-am-i-seeing-npm-404-errors-for-event-stream-flatmap-stream-in-my-build-logs
"
https://kb.heroku.com/4OM7X18J/why-am-i-seeing-npm-404-errors-for-event-stream-flatmap-stream-in-my-build-logs
exit
1
fail
fi
fi
return
0
return
0
...
@@ -401,6 +438,7 @@ log_other_failures() {
...
@@ -401,6 +438,7 @@ log_other_failures() {
if
grep
-qi
"sh: 1: cd: can't cd to"
"
$log_file
"
;
then
if
grep
-qi
"sh: 1: cd: can't cd to"
"
$log_file
"
;
then
mcount
"failures.cd-command-fail"
mcount
"failures.cd-command-fail"
meta_set
"failure"
"cd-command-fail"
return
0
return
0
fi
fi
...
@@ -408,11 +446,13 @@ log_other_failures() {
...
@@ -408,11 +446,13 @@ log_other_failures() {
if
grep
-qi
"Module not found: Error: Can't resolve"
"
$log_file
"
;
then
if
grep
-qi
"Module not found: Error: Can't resolve"
"
$log_file
"
;
then
mcount
"failures.webpack.module-not-found"
mcount
"failures.webpack.module-not-found"
meta_set
"failure"
"webpack-module-not-found"
return
0
return
0
fi
fi
if
grep
-qi
"sass-loader/lib/loader.js:3:14"
"
$log_file
"
;
then
if
grep
-qi
"sass-loader/lib/loader.js:3:14"
"
$log_file
"
;
then
mcount
"failures.webpack.sass-loader-error"
mcount
"failures.webpack.sass-loader-error"
meta_set
"failure"
"webpack-sass-loader-error"
return
0
return
0
fi
fi
...
@@ -420,21 +460,25 @@ log_other_failures() {
...
@@ -420,21 +460,25 @@ log_other_failures() {
if
grep
-qi
"Property '.*' does not exist on type '.*'"
"
$log_file
"
;
then
if
grep
-qi
"Property '.*' does not exist on type '.*'"
"
$log_file
"
;
then
mcount
"failures.typescript.missing-property"
mcount
"failures.typescript.missing-property"
meta_set
"failure"
"typescript-missing-property"
return
0
return
0
fi
fi
if
grep
-qi
"Property '.*' is private and only accessible within class '.*'"
"
$log_file
"
;
then
if
grep
-qi
"Property '.*' is private and only accessible within class '.*'"
"
$log_file
"
;
then
mcount
"failures.typescript.private-property"
mcount
"failures.typescript.private-property"
meta_set
"failure"
"typescript-private-property"
return
0
return
0
fi
fi
if
grep
-qi
"error TS2307: Cannot find module '.*'"
"
$log_file
"
;
then
if
grep
-qi
"error TS2307: Cannot find module '.*'"
"
$log_file
"
;
then
mcount
"failures.typescript.missing-module"
mcount
"failures.typescript.missing-module"
meta_set
"failure"
"typescript-missing-module"
return
0
return
0
fi
fi
if
grep
-qi
"error TS2688: Cannot find type definition file for '.*'"
"
$log_file
"
;
then
if
grep
-qi
"error TS2688: Cannot find type definition file for '.*'"
"
$log_file
"
;
then
mcount
"failures.typescript.missing-type-definition"
mcount
"failures.typescript.missing-type-definition"
meta_set
"failure"
"typescript-missing-type-definition"
return
0
return
0
fi
fi
...
@@ -442,6 +486,7 @@ log_other_failures() {
...
@@ -442,6 +486,7 @@ log_other_failures() {
# Ex: Error: Cannot find module 'chalk'
# Ex: Error: Cannot find module 'chalk'
if
grep
-q
"Error: Cannot find module '[^/C
\.
]"
"
$log_file
"
;
then
if
grep
-q
"Error: Cannot find module '[^/C
\.
]"
"
$log_file
"
;
then
mcount
"failures.missing-module.npm"
mcount
"failures.missing-module.npm"
meta_set
"failure"
"missing-module-npm"
return
0
return
0
fi
fi
...
@@ -449,6 +494,7 @@ log_other_failures() {
...
@@ -449,6 +494,7 @@ log_other_failures() {
# Ex: Error: Cannot find module '/tmp/build_{hash}/...'
# Ex: Error: Cannot find module '/tmp/build_{hash}/...'
if
grep
-q
"Error: Cannot find module '/"
"
$log_file
"
;
then
if
grep
-q
"Error: Cannot find module '/"
"
$log_file
"
;
then
mcount
"failures.missing-module.local-absolute"
mcount
"failures.missing-module.local-absolute"
meta_set
"failure"
"missing-module-local-absolute"
return
0
return
0
fi
fi
...
@@ -456,6 +502,7 @@ log_other_failures() {
...
@@ -456,6 +502,7 @@ log_other_failures() {
# Ex: Error: Cannot find module './lib/utils'
# Ex: Error: Cannot find module './lib/utils'
if
grep
-q
"Error: Cannot find module '
\.
"
"
$log_file
"
;
then
if
grep
-q
"Error: Cannot find module '
\.
"
"
$log_file
"
;
then
mcount
"failures.missing-module.local-relative"
mcount
"failures.missing-module.local-relative"
meta_set
"failure"
"missing-module-local-relative"
return
0
return
0
fi
fi
...
@@ -463,16 +510,19 @@ log_other_failures() {
...
@@ -463,16 +510,19 @@ log_other_failures() {
# Ex: Error: Cannot find module 'C:\Users...'
# Ex: Error: Cannot find module 'C:\Users...'
if
grep
-q
"Error: Cannot find module 'C:"
"
$log_file
"
;
then
if
grep
-q
"Error: Cannot find module 'C:"
"
$log_file
"
;
then
mcount
"failures.missing-module.local-windows"
mcount
"failures.missing-module.local-windows"
meta_set
"failure"
"missing-module-local-windows"
return
0
return
0
fi
fi
# matches the subsequent lines of a stacktrace
# matches the subsequent lines of a stacktrace
if
grep
-q
'at [^ ]* \([^ ]*:\d*\d*\)'
"
$log_file
"
;
then
if
grep
-q
'at [^ ]* \([^ ]*:\d*\d*\)'
"
$log_file
"
;
then
mcount
"failures.unknown-stacktrace"
mcount
"failures.unknown-stacktrace"
meta_set
"failure"
"unknown-stacktrace"
return
0
return
0
fi
fi
# If we've made it this far it's not an error we've added detection for yet
# If we've made it this far it's not an error we've added detection for yet
meta_set
"failure"
"unknown"
mcount
"failures.unknown"
mcount
"failures.unknown"
}
}
...
...
test/run
View file @
34818989
...
@@ -1043,11 +1043,9 @@ testMemoryMetrics() {
...
@@ -1043,11 +1043,9 @@ testMemoryMetrics() {
}
}
testBuildMetaData
()
{
testBuildMetaData
()
{
env_dir
=
$(
mktmpdir
)
local
log_file
=
$(
mktemp
)
local
log_file
=
$(
mktemp
)
echo
"
$log_file
"
>
$env_dir
/BUILDPACK_LOG_FILE
compile
"pre-post-build-scripts"
"
$(
mktmpdir
)
"
$env_dir
BUILDPACK_LOG_FILE
=
"
$log_file
"
compile
"pre-post-build-scripts"
# build info
# build info
assertFileContains
"node-package-manager=npm"
$log_file
assertFileContains
"node-package-manager=npm"
$log_file
...
@@ -1084,7 +1082,7 @@ testBuildMetaData() {
...
@@ -1084,7 +1082,7 @@ testBuildMetaData() {
# erase the log file
# erase the log file
echo
""
>
$log_file
echo
""
>
$log_file
compile
"yarn"
"
$(
mktmpdir
)
"
$env_dir
BUILDPACK_LOG_FILE
=
"
$log_file
"
compile
"yarn"
assertFileContains
"node-package-manager=yarn"
$log_file
assertFileContains
"node-package-manager=yarn"
$log_file
assertFileContains
"has-node-lock-file=true"
$log_file
assertFileContains
"has-node-lock-file=true"
$log_file
...
@@ -1095,6 +1093,19 @@ testBuildMetaData() {
...
@@ -1095,6 +1093,19 @@ testBuildMetaData() {
assertFileContains
"node-build-success=true"
$log_file
assertFileContains
"node-build-success=true"
$log_file
}
}
testFailingBuildMetaData
()
{
local
log_file
=
$(
mktemp
)
BUILDPACK_LOG_FILE
=
"
$log_file
"
compile
"bad-json"
assertFileContains
"failure=invalid-package-json"
$log_file
assertCapturedError
echo
""
>
$log_file
BUILDPACK_LOG_FILE
=
"
$log_file
"
compile
"yarn-lockfile-out-of-date"
assertFileContains
"failure=outdated-yarn-lockfile"
$log_file
assertCapturedError
}
testPropagateAppUUID
()
{
testPropagateAppUUID
()
{
env_dir
=
$(
mktmpdir
)
env_dir
=
$(
mktmpdir
)
local
log_file
=
$(
mktemp
)
local
log_file
=
$(
mktemp
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment