Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release proposal: v3.0.0 #2299

Merged
merged 2 commits into from
Aug 4, 2015
Merged

Release proposal: v3.0.0 #2299

merged 2 commits into from
Aug 4, 2015

Conversation

rvagg
Copy link
Member

@rvagg rvagg commented Aug 4, 2015

Taking over from #2221, the commits there are now in master, the remaining commit is the release commit which is in this PR.

CHANGELOG entry copied here:


2015-08-04, Version 3.0.0, @rvagg

Notable changes

  • buffer:
    • Due to changes in V8, it has been necessary to reimplement Buffer on top of V8's Uint8Array. While every effort has been made to maintain performance, users are likely to experience a different performance profile depending on how Buffer is used. (Trevor Norris) #1825.
    • Buffer can now take ArrayBuffers as a constructor argument (Trevor Norris) #2002.
    • When a single buffer is passed to Buffer.concat(), a new, copied Buffer object will be returned; previous behavior was to return the original Buffer object (Sakthipriyan Vairamani) #1937.
  • build: PPC support has been added to core to allow compiling on pLinux BE and LE (AIX support coming soon) (Michael Dawson) #2124.
  • dgram: If an error occurs within socket.send() and a callback has been provided, the error is only passed as the first argument to the callback and not emitted on the socket object; previous behavior was to do both (Matteo Collina & Chris Dickinson) #1796
  • freelist: Deprecate the undocumented freelist core module (Sakthipriyan Vairamani) #2176.
  • http:
    • Status codes now all use the official IANA names as per RFC7231, e.g. http.STATUS_CODES[414] now returns 'URI Too Long' rather than 'Request-URI Too Large' (jomo) #1470.
    • Calling .getName() on an HTTP agent no longer returns a trailing colon, HTTPS agents will no longer return an extra colon near the middle of the string (Brendan Ashworth) #1617.
  • node:
    • NODE_MODULE_VERSION has been bumped to 45 to reflect the break in ABI (Rod Vagg) #2096.
    • Introduce a new process.release object that contains a name property set to 'io.js' and sourceUrl, headersUrl and libUrl (Windows only) properties containing URLs for the relevant resources; this is intended to be used by node-gyp (Rod Vagg) #2154.
    • The version of node-gyp bundled with io.js now downloads and uses a tarball of header files from iojs.org rather than the full source for compiling native add-ons; it is hoped this is a temporary floating patch and the change will be upstreamed to node-gyp soon (Rod Vagg) #2066.
  • repl: Persistent history is now enabled by default. The history file is located at ~/.node_repl_history, which can be overridden by the new environment variable NODE_REPL_HISTORY. This deprecates the previous NODE_REPL_HISTORY_FILE variable. Additionally, the format of the file has been changed to plain text to better handle file corruption. (Jeremiah Senkpiel) #2224.
  • smalloc: The smalloc module has been removed as it is no longer possible to provide the API due to changes in V8 (Ben Noordhuis) #2022.
  • tls: Add server.getTicketKeys() and server.setTicketKeys() methods for TLS session key rotation (Fedor Indutny) #2227.
  • v8: Upgraded to 4.4.63.26
    • ES6: Enabled computed property names
    • ES6: Array can now be subclassed in strict mode
    • ES6: Implement rest parameters in staging, use the --harmony-rest-parameters command line flag
    • ES6: Implement the spread operator in staging, use the --harmony-spreadcalls command line flag
    • Removed SetIndexedPropertiesToExternalArrayData and related APIs, forcing a shift to Buffer to be reimplemented based on Uint8Array
    • Introduction of Maybe and MaybeLocal C++ API for objects which may or may not have a value.
    • Added support for PPC

Known issues

See https://github.com/nodejs/io.js/labels/confirmed-bug for complete and current list of known issues.

  • Using multiple REPL instances in parallel may cause some REPL history corruption or loss. #1634
  • Some problems with unreferenced timers running during beforeExit are still to be resolved. See #1264.
  • Surrogate pair in REPL can freeze terminal. #690
  • process.send() is not synchronous as the docs suggest, a regression introduced in 1.0.2, see #760.
  • Calling dns.setServers() while a DNS query is in progress can cause the process to crash on a failed assertion. #894
  • url.resolve may transfer the auth portion of the url when resolving between two full hosts, see #1435.

Commits

  • [60a974d200] - buffer: fix missing null/undefined check (Trevor Norris) #2195
  • [e6ab2d92bc] - buffer: fix not return on error (Trevor Norris) #2225
  • [1057d1186b] - buffer: rename internal/buffer_new.js to buffer.js (Ben Noordhuis) #2022
  • [4643b8b667] - (SEMVER-MINOR) buffer: allow ArrayBuffer as Buffer argument (Trevor Norris) #2002
  • [e5ada116cd] - buffer: minor cleanup from rebase (Trevor Norris) #2003
  • [b625ab4242] - buffer: fix usage of kMaxLength (Trevor Norris) #2003
  • [eea66e2a7b] - (SEMVER-MAJOR) buffer: fix case of one buffer passed to concat (Sakthipriyan Vairamani) #1937
  • [8664084166] - buffer: make additional changes to native API (Trevor Norris) #1825
  • [36f78f4c1c] - buffer: switch API to return MaybeLocal (Trevor Norris) #1825
  • [571ec13841] - buffer: switch to using Maybe API (Trevor Norris) #1825
  • [d75f5c8d0e] - buffer: finish implementing FreeCallback (Trevor Norris) #1825
  • [63da0dfd3a] - buffer: implement Uint8Array backed Buffer (Trevor Norris) #1825
  • [23be6ca189] - buffer: allow ARGS_THIS to accept a name (Trevor Norris) #1825
  • [971de5e417] - build: prepare Windows installer for i18n support (Frederic Hemberger) #2247
  • [2ba8b23661] - build: add 'x86' option back in to configure (Rod Vagg) #2233
  • [b4226e797a] - build: first set of updates to enable PPC support (Michael Dawson) #2124
  • [24dd016deb] - build: produce symbol map files on windows (Ali Ijaz Sheikh) #2243
  • [423d8944ce] - cluster: do not unconditionally set --debug-port (cjihrig) #1949
  • [fa98b97171] - cluster: add handle ref/unref stubs in rr mode (Ben Noordhuis) #2274
  • [944f68046c] - crypto: remove kMaxLength on randomBytes() (Trevor Norris) #1825
  • [3d3c687012] - deps: update V8 to 4.4.63.26 (Michaël Zasso) #2220
  • [3aad4fa89a] - deps: upgrade v8 to 4.4.63.12 (Ben Noordhuis) #2092
  • [70d1f32f56] - (SEMVER-MAJOR) deps: update v8 to 4.4.63.9 (Ben Noordhuis) #2022
  • [deb7ee93a7] - deps: backport 7b24219346 from v8 upstream (Rod Vagg) #1805
  • [d58e780504] - (SEMVER-MAJOR) deps: update v8 to 4.3.61.21 (Chris Dickinson) iojs/io.js#1632
  • [2a63cf612b] - deps: make node-gyp work with io.js (cjihrig) iojs/io.js#990
  • [bf63266460] - deps: upgrade to npm 2.13.3 (Kat Marchán) #2284
  • [ef2c8cd4ec] - (SEMVER-MAJOR) dgram: make send cb act as "error" event handler (Matteo Collina) #1796
  • [3da057fef6] - (SEMVER-MAJOR) dgram: make send cb act as "error" event handler (Chris Dickinson) #1796
  • [df1994fe53] - _Revert_ "dns: remove AI_V4MAPPED hint flag on FreeBSD" (cjihrig) iojs/io.js#1555
  • [1721968b22] - doc: document repl persistent history changes (Jeremiah Senkpiel) #2224
  • [d12df7f159] - doc: update v8 flags in man page (Michaël Zasso) iojs/io.js#1701
  • [d168d01b04] - doc: properly inheriting from EventEmitter (Sakthipriyan Vairamani) #2168
  • [500f2538cc] - doc: a listener, not "an" listener (Sam Roberts) #1025
  • [54627a919d] - doc: server close event does not have an argument (Sam Roberts) #1025
  • [ed85c95a9c] - doc,test: documents behaviour of non-existent file (Sakthipriyan Vairamani) #2169
  • [2965442308] - (SEMVER-MAJOR) http: fix agent.getName() and add tests (Brendan Ashworth) #1617
  • [2d9456e3e6] - (SEMVER-MAJOR) http: use official IANA Status Codes (jomo) #1470
  • [11e4249227] - (SEMVER-MAJOR) http_server: prefinish vs finish (Fedor Indutny) #1411
  • [9bc2e26720] - net: do not set V4MAPPED on FreeBSD (Julien Gilli) iojs/io.js#1555
  • [ba9ccf227e] - node: remove redundant --use-old-buffer (Rod Vagg) #2275
  • [ef65321083] - (SEMVER-MAJOR) node: do not override message/stack of error (Fedor Indutny) #2108
  • [9f727f5e03] - node-gyp: detect RC build with x.y.z-rc.n format (Rod Vagg) #2171
  • [e52f963632] - node-gyp: download header tarball for compile (Rod Vagg) #2066
  • [902c9ca51d] - node-gyp: make aware of nightly, next-nightly & rc (Rod Vagg) #2066
  • [4cffaa3f55] - (SEMVER-MINOR) readline: allow tabs in input (Rich Trott) #1761
  • [ed6c249104] - (SEMVER-MAJOR) repl: persist history in plain text (Jeremiah Senkpiel) #2224
  • [f7d5e4c618] - (SEMVER-MINOR) repl: default persistence to ~/.node_repl_history (Jeremiah Senkpiel) #2224
  • [ea05e760cd] - repl: don't clobber RegExp.$ properties (Sakthipriyan Vairamani) #2137
  • [d20093246b] - src: disable vector ICs on arm (Michaël Zasso) #2220
  • [04fd4fad46] - (SEMVER-MINOR) src: introduce process.release object (Rod Vagg) #2154
  • [9d34bd1147] - src: increment NODE_MODULE_VERSION to 45 (Rod Vagg) #2096
  • [ceee8d2807] - test: add tests for persistent repl history (Jeremiah Senkpiel) #2224
  • [8e1a8ffe24] - test: remove two obsolete pummel tests (Ben Noordhuis) #2022
  • [ae731ec0fa] - test: don't use arguments.callee (Ben Noordhuis) #2022
  • [21d31c08e7] - test: remove obsolete harmony flags (Chris Dickinson)
  • [64cf71195c] - test: change the hostname to an invalid name (Sakthipriyan Vairamani) #2287
  • [80a1cf7425] - test: fix messages and use return to skip tests (Sakthipriyan Vairamani) #2290
  • [d5ab92bcc1] - test: use common.isWindows consistently (Sakthipriyan Vairamani) #2269
  • [bc733f7065] - test: fix fs.readFile('/dev/stdin') tests (Ben Noordhuis) #2265
  • [3cbb5870e5] - tools: expose skip output to test runner (Johan Bergström) #2130
  • [3b021efe11] - vm: fix symbol access (Domenic Denicola) #1773
  • [7b81e4ba36] - vm: remove unnecessary access checks (Domenic Denicola) #1773
  • [659dadd410] - vm: fix property descriptors of sandbox properties (Domenic Denicola) #1773
  • [9bac1dbae9] - win,node-gyp: enable delay-load hook by default (Bert Belder) iojs/io.js#1433

@rvagg rvagg force-pushed the v3.0.0-proposal branch from aff74d0 to 9a78059 Compare August 4, 2015 19:19
@rvagg
Copy link
Member Author

rvagg commented Aug 4, 2015

Updated known issues to include:

  • Using multiple REPL instances in parallel may cause some REPL history corruption or loss. #1634

@rvagg
Copy link
Member Author

rvagg commented Aug 4, 2015

From v3.0.0-alpha, essentially identical to this branch:
https://jenkins-iojs.nodesource.com/job/node-test-commit/102/
https://jenkins-iojs.nodesource.com/job/node-test-commit/103/

From this branch:
https://jenkins-iojs.nodesource.com/job/node-test-commit/104/

Moving forward with release if that comes out green sans known flaky tests

@rvagg
Copy link
Member Author

rvagg commented Aug 4, 2015

I have this for Buffer now:

  • Due to changes in V8, it has been necessary to reimplement Buffer on top of V8's Uint8Array. While every effort has been made to minimize the performance impact, users are likely to experience a different performance profile depending on how Buffer is used. (Trevor Norris) #1825.

But it feels a bit too hand-wavy. @trevnorris' current measurements suggests there may be up to a 70% degradation in Buffer instantiation but the actual impact beyond that is uncertain mainly because the uses of Buffer vary so much within core and across applications and instantiation is only one (small) part of this.

If anyone has suggestions for how to convey useful information without making it sound too scary or providing negative-tweet-fodder then I'd love to hear it!

@rvagg
Copy link
Member Author

rvagg commented Aug 4, 2015

Sorry, "70% degradation" is wrong, more meaningful to say that instantiation is now taking between 150% and 170% in v3 over what it takes with v2.

@rvagg rvagg force-pushed the v3.0.0-proposal branch from 9a78059 to 2f68ba9 Compare August 4, 2015 20:01
@domenic
Copy link
Contributor

domenic commented Aug 4, 2015

IMO the current text seems good. Instantiation takes longer (usually? sometimes? always?), but access and use is faster for certain sizes IIUC. "Different performance profile" sounds about right. @trevnorris seems like the one you really want to answer though.

@trevnorris
Copy link
Contributor

@domenic re Buffer performance difference. I remember it being comparable in v4.3, and even faster as buffers grew larger (less impact on GC), but in v4.4 the performance has drastically decreased. You can even see that using any normal typed array. Not just in Buffer.

@rvagg
Copy link
Member Author

rvagg commented Aug 4, 2015

  • Due to changes in V8, it has been necessary to reimplement Buffer on top of V8's Uint8Array. Every effort has been made to minimize the performance impact, however Buffer instantiation is measurably slower. The exact performance profile and difference over previous versions will depend on how Buffer is used within applications.

@rvagg
Copy link
Member Author

rvagg commented Aug 4, 2015

  • Due to changes in V8, it has been necessary to reimplement Buffer on top of V8's Uint8Array. Every effort has been made to minimize the performance impact, however Buffer instantiation is measurably slower. Access operations may be faster in some circumstances but the exact performance profile and difference over previous versions will depend on how Buffer is used within applications.

@rvagg rvagg force-pushed the v3.0.0-proposal branch 2 times, most recently from 945e34e to f066fe3 Compare August 4, 2015 20:36
@rvagg
Copy link
Member Author

rvagg commented Aug 4, 2015

@YurySolovyov
Copy link

It would be great to see how it performs in io.js's own benchmarks suite, compared to 2.5.0

@rvagg
Copy link
Member Author

rvagg commented Aug 4, 2015

Error in docs for repl stuff, I'll fix in a PR

/Users/iojs/build/workspace/iojs+release/nodes/osx1010-release-pkg/tools/doc/generate.js:54
        if (er) throw er;
                ^

Error: Inappropriate heading level
{"type":"heading","depth":3,"text":"Persistent History"}
    at /Users/iojs/build/workspace/iojs+release/nodes/osx1010-release-pkg/tools/doc/html.js:192:17
    at Array.forEach (native)
    at buildToc (/Users/iojs/build/workspace/iojs+release/nodes/osx1010-release-pkg/tools/doc/html.js:189:9)
    at render (/Users/iojs/build/workspace/iojs+release/nodes/osx1010-release-pkg/tools/doc/html.js:71:3)
    at /Users/iojs/build/workspace/iojs+release/nodes/osx1010-release-pkg/tools/doc/html.js:37:7
    at FSReqWrap.readFileAfterClose [as oncomplete] (fs.js:380:3)
make: *** [out/doc/api/all.html] Error 1
make: *** Waiting for unfinished jobs....

@rvagg rvagg force-pushed the v3.0.0-proposal branch from f066fe3 to ff46333 Compare August 4, 2015 21:00
@rvagg
Copy link
Member Author

rvagg commented Aug 4, 2015

Can I get an LGTM for this commit changing the heading levels for the new REPL docs? rvagg@02a2e5e

@Fishrock123 if you're around it'd be good to have you comment too

@rvagg rvagg force-pushed the v3.0.0-proposal branch from ff46333 to ecb9b08 Compare August 4, 2015 21:05
@Qard
Copy link
Member

Qard commented Aug 4, 2015

docs commit LGTM.

@Fishrock123
Copy link
Contributor

Docs fixes LGTM

rvagg added 2 commits August 4, 2015 14:07
PR-URL: nodejs#2299
Reviewed-by: Stephen Belanger <admin@stephenbelanger.com>
Reviewed-By: Jeremiah Senkpiel <fishrock123@rocketmail.com>
Notable changes:

* buffer:
  - Due to changes in V8, it has been necessary to reimplement Buffer
    on top of V8's Uint8Array. While every effort has been made to
    maintain performance, users are likely to experience a different
    performance profile depending on how Buffer is used.
    (Trevor Norris) nodejs#1825.
  - Buffer can now take ArrayBuffers as a constructor argument
    (Trevor Norris) nodejs#2002.
  - When a single buffer is passed to Buffer.concat(), a new, copied
    Buffer object will be returned; previous behavior was to return
    the original Buffer object (Sakthipriyan Vairamani) nodejs#1937.
* build: PPC support has been added to core to allow compiling on
  pLinux BE and LE (AIX support coming soon) (Michael Dawson) nodejs#2124.
* dgram: If an error occurs within socket.send() and a callback has
  been provided, the error is only passed as the first argument to the
  callback and not emitted on the socket object; previous behavior was
  to do both (Matteo Collina & Chris Dickinson) nodejs#1796
* freelist: Deprecate the undocumented freelist core module
  (Sakthipriyan Vairamani) nodejs#2176.
* http:
  - Status codes now all use the official IANA names as per RFC7231,
    e.g. http.STATUS_CODES[414] now returns 'URI Too Long' rather than
    'Request-URI Too Large' (jomo) nodejs#1470.
  - Calling .getName() on an HTTP agent no longer returns a trailing
    colon, HTTPS agents will no longer return an extra colon near the
    middle of the string (Brendan Ashworth) nodejs#1617.
* node:
  - NODE_MODULE_VERSION has been bumped to 45 to reflect the break in
    ABI (Rod Vagg) nodejs#2096.
  - Introduce a new process.release object that contains a name
    property set to 'io.js' and sourceUrl, headersUrl and libUrl
    (Windows only) properties containing URLs for the relevant
    resources; this is intended to be used by node-gyp
    (Rod Vagg) nodejs#2154.
  - The version of node-gyp bundled with io.js now downloads and uses
    a tarball of header files from iojs.org rather than the full
    source for compiling native add-ons; it is hoped this is a
    temporary floating patch and the change will be upstreamed to
    node-gyp soon (Rod Vagg) nodejs#2066.
* repl: Persistent history is now enabled by default. The history file
  is located at ~/.node_repl_history, which can be overridden by the
  new environment variable NODE_REPL_HISTORY. This deprecates the
  previous NODE_REPL_HISTORY_FILE variable. Additionally, the format
  of the file has been changed to plain text to better handle file
  corruption. (Jeremiah Senkpiel) nodejs#2224.
* smalloc: The smalloc module has been removed as it is no longer
  possible to provide the API due to changes in V8
  (Ben Noordhuis) nodejs#2022.
* tls: Add server.getTicketKeys() and server.setTicketKeys() methods
  for TLS session key rotation (Fedor Indutny) nodejs#2227.
* v8: Upgraded to 4.4.63.26
  - ES6: Enabled computed property names
  - ES6: Array can now be subclassed in strict mode
  - ES6: Implement rest parameters in staging, use the
    --harmony-rest-parameters command line flag
  - ES6: Implement the spread operator in staging, use the
    --harmony-spreadcalls command line flag
  - Removed SetIndexedPropertiesToExternalArrayData and related APIs,
    forcing a shift to Buffer to be reimplemented based on Uint8Array
  - Introduction of Maybe and MaybeLocal C++ API for objects which may
    or may not have a value.
  - Added support for PPC

PR-URL: nodejs#2299
@rvagg rvagg force-pushed the v3.0.0-proposal branch from ecb9b08 to 6faf17c Compare August 4, 2015 21:07
@rvagg
Copy link
Member Author

rvagg commented Aug 4, 2015

thanks both, new build @ https://jenkins-iojs.nodesource.com/job/iojs+release/69/

@thefourtheye
Copy link
Contributor

Heading looks fine. LGTM

@rvagg rvagg merged commit 6faf17c into nodejs:master Aug 4, 2015
@rvagg rvagg mentioned this pull request Aug 17, 2015
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.

7 participants