Commit Graph

21375 Commits

Author SHA1 Message Date
Ben Newman
121eb30c90 Shorten initial README.md description for inter-process-messaging. release/METEOR@1.7.1-beta.19 2018-07-17 21:12:46 -04:00
Ben Newman
fe45f24c8f Bump package versions for 1.7.1-beta.19 release. 2018-07-17 21:02:07 -04:00
Ben Newman
fc1c762ad5 Bump $BUNDLE_VERSION to 8.11.3.6 before rebuilding dev bundle. 2018-07-17 21:00:18 -04:00
Ben Newman
50b44f6465 Update meteor-babel to version 7.0.0-beta.54. 2018-07-17 20:35:37 -04:00
Ben Newman
ff8cee9e4e Update npm to version 6.2.0.
The pacote dependency (a small fork of which we maintain) remains at
version 8.1.6.
2018-07-17 20:13:55 -04:00
Ben Newman
d7e489d5d5 Merge pull request #10077 from meteor/inter-process-messaging
Use listener API for communication between build/server processes.
2018-07-17 15:12:14 -07:00
Ben Newman
7d25b592b6 Use ARSON to encode and decode IPC payloads and results. 2018-07-17 16:44:59 -04:00
Ben Newman
5ea442bb12 Update packages/inter-process-messaging/README.md. 2018-07-17 16:44:58 -04:00
Ben Newman
f4946306c0 Make IPC system more testable, and implement some basic tests. 2018-07-17 16:44:58 -04:00
Ben Newman
eceb3b0f57 Silence UnhandledPromiseRejectionWarning in exit handler. 2018-07-17 16:44:58 -04:00
Ben Newman
9faaddd641 Handle child process 'exit' event in IPC system. 2018-07-17 13:24:02 -04:00
Ben Newman
393196eb93 Remove parent/child terminology from the IPC system.
Every process is potentially the child of some other process and the
parent of zero or more child processes of its own, so it's confusing to
use terminology that always treats the current global.process as a
"parent" process, or to include PARENT and CHILD in the message types.

Instead, this new implementation uses message types MESSAGE, RESPONSE,
PING, and PONG, and refers to `process` and `otherProcess` objects,
with the caveat that sometimes `process === otherProcess`, because
`process.send` can be used to send messages to the parent process.

Instead of relying on the child to send a special CHILD_READY message to
the parent when it's ready to receive messages, the sending process polls
the receiving process with a preflight PING message, and the receiving
process immediately responds with a PONG when ready.
2018-07-17 13:11:48 -04:00
Ben Newman
692b533d49 Extract IPC type strings into a shared module. 2018-07-17 10:27:00 -04:00
Ben Newman
2450ffe84d Remove unreliable modification of Autoupdate versions from self-test. 2018-07-16 18:59:51 -04:00
Ben Newman
77ed148614 Use listener API for communication between build/server processes.
Fixes #10073, per
https://github.com/meteor/meteor/issues/10073#issuecomment-405290391

While thinking about this bug, I realized that sending IPC messages to
specific packages in the server process was much less flexible than
sending messages based on an arbitrary topic string, since the topic
string approach allows both `autoupdate` and `dynamic-import` to listen
for the same message.

The topic string approach calls for a listener interface like
`onMessage(topic, callback)`, which elegantly replaces the previous
approach of requiring packages to export a single `onMessage` function.

However, because the `meteor` package does not have access to the module
system, implementing the `onMessage` listener interface in the `meteor`
package would have required exposing an API like `Meteor.onMessage(topic,
callback)`, which has an unpleasant global smell to it. Instead, the
`onMessage` function should be explicitly imported (using the module
system) from a less-generically-named package.

Since I knew I was going to have to move the message dispatch logic out of
the `meteor` package, I decided to create a new package called
`inter-process-messaging` to implement the parent/child components of the
IPC system.
2018-07-16 18:59:50 -04:00
Ben Newman
547b1675b7 Bump package versions for 1.7.1-beta.18 release. release/METEOR@1.7.1-beta.18 2018-07-13 03:50:39 -04:00
Ben Newman
34bbbcb0f9 Calculate autoupdate versions correctly in cordova/builder.js.
Follow-up to the recent rewrite of autoupdate:
fe9e4035f9

Should fix #10067.
2018-07-12 11:57:09 -04:00
Ben Newman
e2e0f71b14 Bump package versions for 1.7.1-beta.17 release. release/METEOR@1.7.1-beta.17 2018-07-11 20:23:26 -04:00
Ben Newman
244fd2a677 Replace Package._on(name, callback) with Package._promise(name).
https://github.com/meteor/meteor/pull/10055#discussion_r201855997

As I explained in this comment, Package._on(packageName, callback) was a
bad API because it never called the callback if the package was not
installed, which caused any app not using the autoupdate package to get
stuck trying to communicate with the autoupdate package.
2018-07-11 19:37:44 -04:00
Ben Newman
52eb3590b7 Bump package versions for 1.7.1-beta.16 release. release/METEOR@1.7.1-beta.16 2018-07-11 16:31:19 -04:00
Ben Newman
92f6835d2d Bump $BUNDLE_VERSION to 8.11.3.5 before rebuilding dev bundle. 2018-07-11 16:10:33 -04:00
Ben Newman
75443b6995 Merge branch 'devel' into release-1.7.1 2018-07-11 16:10:06 -04:00
Ben Newman
1818150ad6 Bump dev_bundle/lib/node_modules/@babel/runtime to v7.0.0-beta.53. 2018-07-11 16:09:12 -04:00
Ben Newman
60e29707d4 Bump $BUNDLE_VERSION to 8.11.3.4 before rebuilding dev bundle. 2018-07-11 16:07:11 -04:00
Ben Newman
05e7aebef7 Merge branch 'devel' into release-1.7.1 2018-07-11 15:52:05 -04:00
Ben Newman
4b905ed51e Update reify npm package to version 0.16.4. 2018-07-11 15:46:51 -04:00
Ben Newman
098ce3f5db Update reify npm package to version 0.16.3.
This already landed on release-1.7.1, but I've cherry-picked it back onto
devel to avoid confusion.
2018-07-11 15:44:29 -04:00
Ben Newman
2765238a29 Update meteor-babel to version 7.0.0-beta.53. 2018-07-11 15:29:45 -04:00
Ben Newman
c82141cbaa Merge pull request #10055 from meteor/wip-delay-building-legacy-bundle
Delay building web.browser.legacy bundle until after development server restarts.
2018-07-11 14:34:04 -04:00
Ben Newman
05ffaa504b Force older autoupdate clients to reload. 2018-07-11 13:08:33 -04:00
Ben Newman
41e2615424 Fix tests by awaiting newly-async WebApp.staticFilesMiddleware. 2018-07-11 10:32:29 -04:00
Ben Newman
cacace3bcb Avoid nested Profile.run calls in watch.sha{1,512} functions. 2018-07-11 10:08:57 -04:00
Ben Newman
1387473cf5 Pause requests for the legacy bundle while rewriting it.
This is the solution I came up with for the problems I described here:
https://github.com/meteor/meteor/pull/10055#issuecomment-403219805
2018-07-10 21:17:14 -04:00
Ben Newman
4b17a0b760 Allow sending IPC messages from build process to server process.
Instead of having every message consumer listen to every message and act
on the ones that seem relevant to its interests, we now have a single
process.on("message", callback) hook that can dispatch messages to
different Meteor packages running in the server process.

Receiving packages should export an onMessage function. The onMessage
function may be async, and its result will be delivered back to the build
process as the result of the sendMessage Promise.
2018-07-10 21:17:14 -04:00
Ben Newman
2c567091c8 Explicitly add uuid package to dev_bundle/lib/node_modules.
This package is already importable because it's a dependency of request,
npm, and http-signature, but it's a good idea to depend on it explicitly
just in case those packages stop depending on it in the future.
2018-07-10 21:17:14 -04:00
Ben Newman
213d4389c2 Implement Package._on(name, callback) to intercept Package._define. 2018-07-10 21:17:14 -04:00
Ben Newman
99b79dc00f Include hash of minimum modern versions in autoupdate versions. 2018-07-10 17:43:28 -04:00
Ben Newman
6335d68c0a Use api.mainModule in autoupdate package. 2018-07-09 18:05:14 -04:00
Ben Newman
ff3dbf2f1b Send another client refresh message after legacy build completes.
Also removed the AppRunner#_refreshing boolean hack, since reporting
errors during IPC communication seems desirable.
2018-07-06 20:07:45 -04:00
Ben Newman
fe9e4035f9 Rewrite autoupdate to distinguish versions by client architecture.
Now that we're postponing the legacy build until after the first client
refresh message is sent, there's a risk that changes to the legacy build
will not be picked up until after the next rebuild.

If we attempted to fix that problem by sending the refresh message after
the legacy bundle is rebuilt, then we would lose most of the benefit of
delaying the legacy build, because the client would not refresh until
after the legacy build completed.

The right way to fix the problem is by sending a second client refresh
message after the legacy build finishes, but doing so with the current
autoupdate implementation would very likely cause modern clients to reload
a second time.

The solution implemented by this commit is simple in theory: the
autoupdate package should keep track of distinct versions for each client
architecture, so that modern clients will refresh only when the modern
versions change, and legacy clients will refresh only when the legacy
versions change, which allows us to send two refresh messages without
causing any clients to refresh more than once.

In reality, this was a fairly major rewrite, since the ClientVersions
collection has a totally different schema now. I've tested it as well as I
can, though I'm not entirely sure what will happen if clients using the
previous version of the autoupdate package begin receiving DDP messages
from this version of the autoupdate server code.
2018-07-06 19:58:57 -04:00
Ben Newman
e3082a43f6 Precompute WebApp.* client hashes in generateClientProgram.
This means the autoupdate package is no longer responsible for recomputing
client hashes, and we can recompute the hashes whenever there's a new (or
updated) client program, which enables delayed builds of architectures
like web.browser.legacy (#10055).
2018-07-06 13:32:49 -04:00
Ben Newman
ae2ebda6af Start webapp server after WebAppInternals.* fully populated. 2018-07-06 13:32:48 -04:00
Ben Newman
265d9e30d4 Reload legacy bundle using a syncQueue.runTask callback. 2018-07-05 11:20:50 -04:00
Ben Newman
b8074a809d Update packages/non-core/blaze submodule to latest master revision. 2018-07-04 14:05:45 -04:00
Ben Newman
f8c47a775f Merge pull request #10051 from jamesmillerburgess/oauth-underscore-usage
Use underscore on both client and server in github-oauth and meetup-oauth
2018-07-04 14:04:39 -04:00
Ben Newman
b9a05d85f6 Permit delayed bundling only if !Console.isHeadless(). 2018-07-04 13:44:12 -04:00
Ben Newman
7f88d26a60 Pass { childProcess, runLog } into post-startup callback function. 2018-07-04 13:44:12 -04:00
Ben Newman
3c5566f532 Avoid nested Profile.run calls in watch.sha{1,512} functions. 2018-07-04 13:44:11 -04:00
Ben Newman
aade180d46 Build web.browser.legacy bundle after startup on rebuilds. 2018-07-04 12:26:23 -04:00
Ben Newman
3d1db19e79 Remove unused NODE_PATH logic from bundler.js and run-app.js. 2018-07-04 10:51:06 -04:00