Commit graph

4304 commits

Author SHA1 Message Date
Michael Grinich
05da3a6c0d Update documentation with GitBook 2017-01-30 02:38:37 -08:00
Juan Tejada
c7037d06a1 bump(k2) 2017-01-28 01:40:18 -08:00
Evan Morikawa
9be018b489 bump(k2) 2017-01-27 17:49:38 -05:00
Evan Morikawa
667f4dd87d bump(k2) 2017-01-27 17:46:39 -05:00
Juan Tejada
82b3033861 fix(tasks) ChangeMailTask should depend on EnsureMessagesInSentFolder
Summary:
See title
Add specs

Test Plan: unit

Reviewers: halla, evan

Reviewed By: halla, evan

Differential Revision: https://phab.nylas.com/D3805
2017-01-27 14:02:50 -08:00
Juan Tejada
bf69357c01 bump(changelog) 2017-01-27 12:54:57 -08:00
Juan Tejada
f6b4cfdacb bump(version) 1.0.17 2017-01-27 12:51:49 -08:00
Juan Tejada
5b11097172 bump(k2) 2017-01-27 12:50:35 -08:00
Evan Morikawa
3441df3a65 bump(k2) 2017-01-27 14:19:48 -05:00
Mark Hahnenberg
0d61af5f03 [search-index] Embiggen Thread and Contact indexes
Summary: See diff title

Test Plan: Run it

Reviewers: juan, mg, evan

Reviewed By: evan

Differential Revision: https://phab.nylas.com/D3794
2017-01-27 10:30:45 -08:00
Juan Tejada
6252f94bb0 bump(changelog) 2017-01-27 09:09:18 -08:00
Juan Tejada
3aaf91ee93 bump(k2) 2017-01-27 08:29:27 -08:00
Evan Morikawa
dfc09254e6 bump(version): 1.0.16 2017-01-27 10:11:27 -05:00
Evan Morikawa
bb560af023 bump(changelog): 1.0.16 2017-01-27 10:11:09 -05:00
Mark Hahnenberg
9acb8b48a8 [spellcheck] Fix spellcheck debouncing
Summary:
Previously we were only debouncing one function in onContentChanged. This would
cause us to do very expensive things on every keypress in the things that
weren't debounced. This diff changes things so that we debounce the entire
process of running the spellchecker.

Test Plan:
Run locally, make sure spellchecker doesn't run on every keypress.
Misspell lots of things, type really quickly, paste large chunks of text
into the composer.

Reviewers: evan, spang, juan

Reviewed By: juan

Differential Revision: https://phab.nylas.com/D3791
2017-01-26 13:40:45 -08:00
Juan Tejada
f6193f9114 bump(k2) 2017-01-26 13:38:40 -08:00
Juan Tejada
6dc9bbf412 fix(tasks) Notify when actions on threads fail
Summary: It is better to notify that a task failed rather than having a thread or group of threads randomly bounce back.

Test Plan: manual

Reviewers: evan, spang, mark, halla

Reviewed By: mark, halla

Subscribers: mark

Differential Revision: https://phab.nylas.com/D3790
2017-01-26 13:30:40 -08:00
Juan Tejada
78cdf32761 bump(k2) 2017-01-26 09:19:42 -08:00
Juan Tejada
c996af3b36 bump(k2) 2017-01-26 09:11:01 -08:00
Juan Tejada
54ca43e48e fix(plugins) Unbreak plugins support in Nylas Mail
Properly use plugins specified in babelrc.json when using the babel
compiler. #3187
2017-01-25 22:41:54 -08:00
Juan Tejada
5a67198226 bump(version) 1.0.15 2017-01-25 16:47:04 -08:00
Juan Tejada
0eaa184a4a bump(k2) 2017-01-25 16:37:54 -08:00
Juan Tejada
7beff5bae4 fix(onboarding) Allow users who only have custom imap to auth
Summary:
Users who only had a custom imap account could not open the window to
add a custom imap account the first time the auth was opened, rendering
the app useless for them.

Github issue #3185 and T7691

Test Plan: manual

Reviewers: halla, spang, evan

Reviewed By: evan

Differential Revision: https://phab.nylas.com/D3783
2017-01-25 15:06:58 -08:00
Mark Hahnenberg
7bf8d18a02 Don't register to receive IPC for hot windows
Summary:
These windows don't need to receive IPC until they're being used for something
(i.e. after transitioning from hot window to composer, popout, etc)

Test Plan:
Run locally w/ hot windows shown, make sure that hot window doesn't
receive IPC

Reviewers: evan, spang, juan

Reviewed By: juan

Differential Revision: https://phab.nylas.com/D3780
2017-01-25 14:54:38 -08:00
Mark Hahnenberg
6946bda2bd Use meaningful names for helper processes
Summary: See diff title

Test Plan: Run locally, check in htop for new titles

Reviewers: evan, juan

Reviewed By: juan

Differential Revision: https://phab.nylas.com/D3778
2017-01-25 14:54:13 -08:00
Evan Morikawa
14514a3413 fix(specs): change spec scheduler back to setTimeout
Summary:
Adds a new `npm run test-window` that will launch specs in a window so you
can use the debugger

The spec window wouldn't close because `onbeforeunload` was unnecessarily
preventing close. This circumvents this in spec mode.

Most significantly I discovered we can't use the synchronous timer for the
promise scheduler anymore. Suppose you do:

```
it('should error', async () => {
  try {
    await doSomething()
    throw new Error("doSomething should have thrown!")
  } catch (err) {
    expect(err.message).toMatch(/my message/)
  }
})
```

The way async/await is transpiled, when `doSomething` throws, the error
will propagate all the way back up to the uncaughtPromiseException handler
before the `catch` gets called and registered. The transpilation method
assumes that when the function gets executed it can synchrously advance
beyond the call before the `then` or `catch` resolve. When the promise
scheduler is synchronous this doesn't happen.

I chose to use `setTimeout` instead of `process.nextTick` or
`setImmediate` as the promise scheduler. `setTimeout` seems to work better
with Chrome's async function call stacks. `nextTick` and `setImmediate`,
being Node methods, skip Chrome's async watchers.

Test Plan:
I talked with Juan about these changes, in an upcoming diff he will be
testing these in the context of our broader test suite.

Reviewers: mark, khamidou, halla, spang, juan

Reviewed By: juan

Differential Revision: https://phab.nylas.com/D3779
2017-01-25 17:43:11 -05:00
Evan Morikawa
2fe1368aa9 bump(k2) 2017-01-25 17:11:45 -05:00
Juan Tejada
85d41839c1 bump(k2) 2017-01-25 13:53:17 -08:00
Juan Tejada
be99845d41 bump(version) 1.0.14 2017-01-25 12:28:47 -08:00
Evan Morikawa
9b21dfb261 bump(k2) 2017-01-25 15:28:09 -05:00
Evan Morikawa
77bc501eb7 bump(spellcheck) upgrade to 1.0.0
Summary: This bumps the spellcheck and restores the specs

Test Plan:
Manually open a composer, type some text and ensure it underlines them as
misspelled. Also restore test coverage

Reviewers: mark, halla, juan

Reviewed By: juan

Differential Revision: https://phab.nylas.com/D3776
2017-01-25 15:26:38 -05:00
Juan Tejada
b2bd4186a2 bump(changelog) 2017-01-25 11:04:58 -08:00
Juan Tejada
a4a71d790f bump(k2) 2017-01-25 10:57:16 -08:00
Mark Hahnenberg
afb49b8b2f Add option to silence query plan debug output for individual queries
Summary:
Sometimes you have to perform a query that needs to do a table scan. For those
times you don't want to silence entire classes of queries (e.g. by table name),
you can now silence individual queries.

Test Plan: Run locally, verify that noisy stuff disappears from logs

Reviewers: evan, juan

Reviewed By: juan

Differential Revision: https://phab.nylas.com/D3763
2017-01-25 09:56:46 -08:00
Evan Morikawa
313bd18913 bump(version): 1.0.13 2017-01-25 10:20:52 -05:00
Evan Morikawa
96f54829b3 bump(changelog): 1.0.13 2017-01-25 10:20:35 -05:00
Evan Morikawa
b5a6739bfb bump(k2) 2017-01-25 10:13:05 -05:00
Evan Morikawa
0be186302a refactor(account): remove unused accont refresh methods
Summary:
This removes `refreshHealthOfAccounts`, which I originally found because I
was trying to refactor it out of the IdentityStore. We need it gone from
the IdentityStore so that store can trigger frequently as things like the
usageLimits constantly update on it.

This also fixes T7520 where we'd get `ECONNREFUSED 127.0.0.1:2578` on
launch unnecessarily.

The concept of refreshing the health of accounts by occassionally polling
the /accounts endpoint is obsolete. This depends on
D3769 which entirely removes the /accounts endpoint
from K2.

Account health is pushed to us by `Actions.updateAccount` which is fired
directly from the main local-sync sync loop.

This also removes `refreshAccounts` and `Actions.refreshAllDeltaConnections`. These were fired by the Identity Store whenever it updated. We no longer need the Identity Store to tell us to reset the delta connections with our local-sync accounts. The delta connections will either be reset by our offline notification button, or when adding or removing an account. The Identity Store was a redundant mechanisms

Test Plan:
Manually verify things work with an existing account. Add a new account
and ensure sync starts. Remove an account and ensure it gets cleaned up.

Reviewers: halla, khamidou, mark, juan

Reviewed By: juan

Maniphest Tasks: T7520

Differential Revision: https://phab.nylas.com/D3770
2017-01-25 10:12:09 -05:00
Evan Morikawa
f2517ea7d7 refactor(name): rename worker-sync package to deltas
Summary:
This diff is a rename. No logical changes.

We used to have a set of files called `nylas-sync-worker`. In Old N1 these
used to have a lot of logic to slowly sync mail from our API. Since we
exclusively use local-sync via a soon-to-be-obsolesced delta stream, these
files really just manage the delta streaming connection.

It's incredibly confusing to have a set of files called worker-sync when
there's a sync-worker already in the codebase. This renames everything to
refer to them as account sync workers.

The reason I wanted this rename is because the IdentityStore on initial
launch triggers and fires a fairly scary-sounding
`Actions.refreshAllSyncWorkers()`. In reality all it does is
`Actions.refreshAllDeltaConnections()`. I'm also tired of staring at files
for a full minute before realizing that this is not the sync worker I was
  looking for.

Test Plan:
After rename, booted the app and ensured that deltas were coming through
for new mail and no errors were being thrown

Reviewers: halla, juan

Reviewed By: juan

Differential Revision: https://phab.nylas.com/D3767
2017-01-25 10:08:23 -05:00
Juan Tejada
d644fe6396 bump(k2) 2017-01-24 17:43:34 -08:00
Juan Tejada
d8c8dd809c fix(auth) Dont allow invalid form submission with Enter key 2017-01-24 17:43:34 -08:00
Halla Moore
d3a0d60f0d fix(unpersistModel) Add default value for opts param
Just an empty object, so looking up a property on it doesn't error.
(Also some whitespace changes that automatically changed on save.)
2017-01-24 16:45:49 -08:00
Juan Tejada
5ed1f4da9e 🎨 Fix to using imap-provider-settings package
Summary: see title

Test Plan: manual

Reviewers: spang, evan

Reviewed By: evan

Differential Revision: https://phab.nylas.com/D3772
2017-01-24 16:25:03 -08:00
Juan Tejada
899538d642 fix(auth) fix timeouts 2017-01-24 12:06:56 -08:00
Juan Tejada
ae584a8367 fix(auth) Increment IMAP auth timeout
Given that imap connections can take up to 90 seconds (see `auth-helpers` in k2),
we don't want to hang up our local connection too soon
2017-01-24 12:02:58 -08:00
Christine Spang
7082ddeabf fix(updater): s/N1/Nylas Mail/ 2017-01-24 11:57:08 -08:00
Evan Morikawa
51d17ce937 bump(changelog) 2017-01-24 14:51:51 -05:00
Juan Tejada
eecf19717a bump(k2) 2017-01-24 11:46:53 -08:00
Juan Tejada
8b36e2ec90 bump(changelog) 2017-01-24 11:46:46 -08:00
Evan Morikawa
2e7e8c2d01 fix(build): add output log interval to prevent travis from dying 2017-01-24 14:27:32 -05:00