Skip to content

Conversation

@Octalbyte
Copy link

@Octalbyte Octalbyte commented Dec 25, 2021

This PR adds handling for fatal crashes of any type. Just so you don't have to see a giant error stack on your console.
The feature is turned on by the --no-panic option or by the environment variable NODE_HTTP_SERVER_NO_PANIC.
The output is something like:
image

Relevant issues

Refers partly to #665

What needs to be done:
  • Add switch.
  • Better log file (JSON formatting)
Contributor checklist
  • Provide tests for the changes (unless documentation-only)
  • Documented any new features, CLI switches, etc. (if applicable)
    • Server --help output
    • README.md
    • doc/http-server.1 (use the same format as other entries)
  • The pull request is being made against the master branch
Maintainer checklist
  • Assign a version triage tag
  • Approve tests if applicable

@Octalbyte Octalbyte marked this pull request as draft December 26, 2021 16:40
@Octalbyte
Copy link
Author

Ready for review.

@Octalbyte Octalbyte marked this pull request as ready for review December 27, 2021 15:10
bin/http-server Outdated
' -h --help Print this list and exit.',
' -v --version Print the version and exit.'
' -v --version Print the version and exit.',
' -n --no-panic If error occurs, gracefully shut down and create log file',
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure -n is an easy mnemonic here, would only having the long version available be sufficient?

bin/http-server Outdated
let etime = new Date().toISOString().replace(/T/, ' ').replace(/\..+/, '')
console.log(colors.green(etime))
console.log(colors.red("Fatal error: ")+ e.code + ": "+e.message)
let fname = ".httpserver-"+etime.split(" ")[0]+"-"+etime.split(" ")[1]
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For the log file, could we end it with .log to make it clear what the file is?

@Octalbyte Octalbyte requested a review from thornjad June 11, 2022 14:14
Suppress log messages from output.

.TP
.BI \-n ", " \-\-no-panic
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

here the -n needs removing

tls: 'ssl'
}
});

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

blank lines not needed

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants