base_gloda_content.js |
Tests the operation of the GlodaContent (in GlodaContent.sys.mjs) and its exposure
via Gloda.getMessageContent. This may also be implicitly tested by indexing
and fulltext query tests (on messages), but the buck stops here for the
content stuff.
Currently, we just test quoting removal and that the content turns out right.
We do not actually verify that the quoted blocks are correct (aka we might
screw up eating the greater-than signs). (We have no known consumers who
care about the quoted blocks.)
|
6377 |
base_index_junk.js |
Test indexing in the face of junk classification and junk folders. It is
gloda policy not to index junk mail.
A similar test that moving things to the trash folder is deletion happens in
base_index_messages.js.
|
7492 |
base_index_messages.js |
This file tests our indexing prowess. This includes both our ability to
properly be triggered by events taking place in thunderbird as well as our
ability to correctly extract/index the right data.
In general, if these tests pass, things are probably working quite well.
This test has local, IMAP online, IMAP offline, and IMAP online-become-offline
variants. See the text_index_messages_*.js files.
Things we don't test that you think we might test:
- Full-text search. Happens in query testing.
|
50693 |
base_query_messages.js |
This file tests our querying support. We build up a deterministic little
'world' of messages spread across multiple conversations, multiple folders
and multiple authors. To verify expected negative results, in addition to
the 'peoples' in our world clique, we also have 'outlier' contacts that do
not communicate with the others (but are also spread across folders).
This is broadly intended to test all of our query features and mechanisms
(apart from our specialized search implementation, which is tested by
test_search_messages.js), but is probably not the place to test specific
edge-cases if they do not easily fit into the 'world' data set.
I feel like having the 'world' mishmash as a data source may muddle things
more than it should, but it is hard to deny the benefit of not having to
define a bunch of message corpuses entirely specialized for each test.
|
24059 |
head_gloda.js |
|
623 |
resources |
|
|
test_corrupt_database.js |
This test does not use glodaTestHelper because:
1) We need to do things as part of the test without gloda having remotely
thought about opening the database.
2) We expect and desire that the logger produce a warning and glodaTestHelper
takes the view that warnings = death.
We do use the rest of the test infrastructure though.
|
3379 |
test_folder_logic.js |
Tests the gloda folder logic.
|
2247 |
test_fts3_tokenizer.js |
This test file recycles part of test_intl.js. What we do is insert into the
fulltext index two messages:
- one has tokens 'aa' and 'bbb',
- one is from a previous test and has CJK characters in it.
We want to test that the behavior of the tokenizer is as expected (namely,
that it drops two-letter tokens unless they're CJK bigrams), and that
GlodaMsgSearcher.sys.mjs properly drops two-letter tokens (unless CJK) from the search
terms to avoid issuing a query that will definitely return no results.
|
9526 |
test_gloda_content_imap_offline.js |
Tests the operation of the GlodaContent (in GlodaContent.sys.mjs) and its exposure
via Gloda.getMessageContent for IMAP messages that are offline.
|
1092 |
test_gloda_content_local.js |
Tests the operation of the GlodaContent (in GlodaContent.sys.mjs) and its exposure
via Gloda.getMessageContent for local messages.
|
1050 |
test_index_addressbook.js |
Check that events update identity._hasAddressBookCard correctly.
|
4427 |
test_index_bad_messages.js |
Test that we fail on bad messages by marking the messages as bad rather than
exploding or something bad like that.
|
6291 |
test_index_compaction.js |
Test that gloda does the right things in terms of compaction. Major cases:
- Compaction occurs while we are in the process of indexing a folder. We
want to make sure we stop indexing cleanly
- A folder that we have already indexed gets compacted. We want to make sure
that we update the message keys for all involved. This means verifying
that both the on-disk representations and in-memory representations are
correct.
- Make sure that an indexing sweep performs a compaction pass if we kill the
compaction job automatically scheduled by the conclusion of the
compaction. (Simulating the user quitting before all compactions have
been processed.)
- Moves/deletes that happen after a compaction but before we process the
compaction generate a special type of edge case that we need to check.
There is also a less interesting case:
- Make sure that the indexer does not try and start indexing a folder that is
in the process of being compacted.
|
13268 |
test_index_junk_imap_offline.js |
Test indexing support for offline IMAP junk.
|
1465 |
test_index_junk_imap_online.js |
Test indexing support for online IMAP junk.
|
1013 |
test_index_junk_local.js |
Test indexing support for local junk.
|
980 |
test_index_messages_imap_offline.js |
Tests how well gloda indexes IMAP messages that are offline from the start.
|
1145 |
test_index_messages_imap_online.js |
Tests how well gloda indexes IMAP messages that aren't offline.
|
1116 |
test_index_messages_imap_online_to_offline.js |
Tests how well gloda indexes IMAP messages that are not offline at first, but
are made offline later.
|
1271 |
test_index_messages_local.js |
Test indexing support for local messages.
|
4494 |
test_index_sweep_folder.js |
This file tests the folder indexing logic of Gloda._worker_folderIndex in
the greater context of the sweep indexing mechanism in a whitebox fashion.
Automated indexing is suppressed for the duration of this file.
In order to test the phases of the logic we inject failures into
GlodaIndexer._indexerGetEnumerator with a wrapper to control how far
indexing gets. We also clobber or wrap other functions as needed.
|
8340 |
test_intl.js |
Sanity check our encoding transforms and make sure the mozporter tokenizer
is resulting in the expected fulltext search results. Specifically:
- Check that subject, body, and attachment names are properly indexed;
previously we screwed up at least one of these in terms of handling
encodings properly.
- Check that we can fulltext search on those things afterwards.
|
12835 |
test_migration.js |
Test migration logic by artificially inducing or simulating the problem, then
trigger the migration logic, then verify things ended up correct, including
the schema version so a second pass of the logic doesn't happen. (As
opposed to checking in an example of a broken database and running against
that.)
|
5936 |
test_mime_attachments_size.js |
General testing of the byte-counting libmime facility, to make sure that what
is streamed to us is actually labeled with the right size.
|
13650 |
test_mime_emitter.js |
General testing of the JS Mime Emitter to make sure it doesn't choke on any
scenarios.
We do not test, but should consider testing:
- MimeEncryptedPKCS7, whatever that translates to.
- apple double
- sun attachment
|
22222 |
test_msg_search.js |
Test GlodaMsgSearcher.sys.mjs our heuristic-based fulltext search mechanism. Things we
generally want to verify:
- fulltext weighting by where the match happened works.
- static interestingness impacts things appropriately.
Our general strategy is to create two messages each with a unique string
placed in controlled places and whatever intentional message manipulation
is required to set things up. Then we query using a GlodaMsgSearcher with
the limit set to 1. Only the message we expect should come back.
Keep in mind in all tests that our underlying ranking mechanism is based on
time so the date of each message is relevant but should not be significant
because our score boost factor should always be well in excess of the one
hour increment between messages.
Previously, we relied on the general equivalence of the logic in
test_query_core to our message search logic.
|
5913 |
test_noun_mimetype.js |
Test noun_mimetype. Exists because I just changed its implementation and I'm
afraid I may have damaged it and it's hard to tell, so ironically a unit test
is the easiest solution. (Don't you hate it when the right thing to do is
also the easy thing to do?)
|
4484 |
test_nuke_migration.js |
Atypical gloda unit test that tests nuke migration. Gloda is not designed
to be shutdown and started up again in the same process lifetime. It tries
to be clever with caching accessors that clobber themselves out of existence
which are hard to make come back to life, and probably other things.
So what we do is create a global-messages-db.sqlite with an unacceptably
old schema version before tickling gloda to startup. If gloda comes up
with a database connection and it has the right schema version, we declare
that gloda has successfully loaded. Our only historical screw-up here was
very blatant (and was actually a result of trying to avoid complexity in
the nuke path! oh the irony!) so we don't need to get all hardcore.
|
2452 |
test_nuke_migration_from_future.js |
There are actually two ways the nuke migration can be invoked. From
a database too far from the future, and too far from the past. This
one is the future one. We must keep ourselves safe from time-traveling
grandchildren!
|
420 |
test_query_core.js |
Test the mechanics our query functionality. Tests in this file are intended
to cover extreme boundary cases and things that are just unlikely to happen
in reasonable message use-cases. (Which is to say, it could be hard to
formulate a set of synthetic messages that result in the situation we want
to test for.)
|
19572 |
test_query_messages_imap_offline.js |
Test query support for IMAP messages that were offline before they were
indexed.
|
1064 |
test_query_messages_imap_online.js |
Test query support for IMAP messages that aren't offline.
|
1077 |
test_query_messages_imap_online_to_offline.js |
Test query support for IMAP messages that were indexed, then made available
offline.
|
1165 |
test_query_messages_local.js |
Test query support for local messages.
|
999 |
test_smime_mimemsg_representation.js |
Test that S/MIME messages are properly displayed and that the MimeMessage
representation is correct.
|
66484 |
test_startup_offline.js |
Test gloda starts up with indexing suppressed when offline at startup.
|
1796 |
xpcshell.ini |
|
1063 |