0
0
mirror of https://github.com/nodejs/node.git synced 2024-12-01 16:10:02 +01:00
nodejs/test
Robert Nagy eeccd52b4e net: make readable/writable start as true
`net.Socket` is slightly breaking stream invariants by
having readable/writable going from `false` to `true`.
Streams assume that readable/writable starts out `true`
and then goes to `false` through `push(null)`/`end()`
after which it never goes back to `true`, e.g. once a
stream is `writable == false` it is assumed it will
never become `true`.

This PR changes 2 things:

Unless explicitly set to `false` through options:

- starts as `readable`/`writable` `true` by default.
- uses `push(null)`/`end()` to set `readable`/`writable`
  to `false`. Note that this would cause the socket to
  emit the `'end'`/`'finish'` events, which it did not
  do previously.

In the case it is explicitly set to `false` through
options` it is assumed to never become `true`.

PR-URL: https://github.com/nodejs/node/pull/32272
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
2020-03-24 09:45:25 +01:00
..
abort
addons doc,lib,src,test: make --experimental-report a nop 2020-03-15 13:29:34 -04:00
async-hooks async_hooks: avoid resource reuse by FileHandle 2020-03-11 19:26:10 +01:00
benchmark test: refactor all benchmark tests to use the new test option 2020-03-09 22:35:54 +01:00
cctest test: use InitializeNodeWithArgs in cctest 2020-03-23 10:59:49 -07:00
common src,cli: support compact (one-line) JSON reports 2020-03-17 08:42:41 -07:00
doctool
embedding test: add extended embedder cctest 2020-03-21 10:58:28 +01:00
es-module module: add hook for global preload code 2020-03-23 08:39:37 -05:00
fixtures module: add hook for global preload code 2020-03-23 08:39:37 -05:00
internet test: fix flaky test-dns-any.js 2020-03-02 07:02:51 -08:00
js-native-api src: remove calls to deprecated ArrayBuffer methods 2020-03-21 12:00:57 +01:00
known_issues test: always skip vm-timeout-escape-queuemicrotask 2020-03-10 11:49:09 -07:00
message esm: port loader code to JS 2020-03-13 17:34:43 +01:00
node-api n-api: define release 6 2020-03-09 11:58:51 -07:00
parallel net: make readable/writable start as true 2020-03-24 09:45:25 +01:00
pseudo-tty
pummel test: use Promise.all() in test-hash-seed 2020-03-17 18:29:56 -07:00
report src,cli: support compact (one-line) JSON reports 2020-03-17 08:42:41 -07:00
sequential test: discard data received by client 2020-03-23 07:37:35 -07:00
testpy
tick-processor
tools
v8-updates deps: update V8 dtrace & postmortem metadata 2020-03-18 16:23:32 -07:00
wasi test: verify that WASI errors are rethrown 2020-03-13 18:18:15 -04:00
wpt
.eslintrc.yaml
README.md
root.status

Node.js Core Tests

This directory contains code and data used to test the Node.js implementation.

For a detailed guide on how to write tests in this directory, see the guide on writing tests.

On how to run tests in this directory, see the contributing guide.

For the tests to run on Windows, be sure to clone Node.js source code with the autocrlf git config flag set to true.

Test Directories

Directory Runs on CI Purpose
abort Yes Tests for when the --abort-on-uncaught-exception flag is used.
addons Yes Tests for addon functionality along with some tests that require an addon.
async-hooks Yes Tests for async_hooks functionality.
benchmark No Test minimal functionality of benchmarks.
cctest Yes C++ tests that are run as part of the build process.
code-cache No Tests for a Node.js binary compiled with V8 code cache.
common Common modules shared among many tests. Documentation
doctool Yes Tests for the documentation generator.
es-module Yes Test ESM module loading.
fixtures Test fixtures used in various tests throughout the test suite.
internet No Tests that make real outbound network connections. Tests for networking related modules may also be present in other directories, but those tests do not make outbound connections.
js-native-api Yes Tests for Node.js-agnostic n-api functionality.
known_issues Yes Tests reproducing known issues within the system. All tests inside of this directory are expected to fail. If a test doesn't fail on certain platforms, those should be skipped via known_issues.status.
message Yes Tests for messages that are output for various conditions (console.log, error messages etc.)
node-api Yes Tests for Node.js-specific n-api functionality.
parallel Yes Various tests that are able to be run in parallel.
pseudo-tty Yes Tests that require stdin/stdout/stderr to be a TTY.
pummel No Various tests for various modules / system functionality operating under load.
sequential Yes Various tests that must not run in parallel.
testpy Test configuration utility used by various test suites.
tick-processor No Tests for the V8 tick processor integration. The tests are for the logic in lib/internal/v8_prof_processor.js and lib/internal/v8_prof_polyfill.js. The tests confirm that the profile processor packages the correct set of scripts from V8 and introduces the correct platform specific logic.
v8-updates No Tests for V8 performance integration.