diff options
Diffstat (limited to 'mobile/android/tests/browser/chrome/test_home_provider.html')
-rw-r--r-- | mobile/android/tests/browser/chrome/test_home_provider.html | 165 |
1 files changed, 165 insertions, 0 deletions
diff --git a/mobile/android/tests/browser/chrome/test_home_provider.html b/mobile/android/tests/browser/chrome/test_home_provider.html new file mode 100644 index 000000000..542cd82c0 --- /dev/null +++ b/mobile/android/tests/browser/chrome/test_home_provider.html @@ -0,0 +1,165 @@ +<!DOCTYPE HTML> +<html> +<!-- +https://bugzilla.mozilla.org/show_bug.cgi?id=942288 +Migrated from Robocop: https://bugzilla.mozilla.org/show_bug.cgi?id=1184186 +--> +<head> + <meta charset="utf-8"> + <title>Test for Bug 942288</title> + <script type="application/javascript" src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script> + <script type="application/javascript" src="chrome://mochikit/content/tests/SimpleTest/SpawnTask.js"></script> + <link rel="stylesheet" type="text/css" href="chrome://global/skin"/> + <link rel="stylesheet" type="text/css" href="chrome://mochikit/content/tests/SimpleTest/test.css"/> + <script type="application/javascript;version=1.7"> + + const { utils: Cu } = Components; + + Cu.import("resource://gre/modules/HomeProvider.jsm"); + Cu.import("resource://gre/modules/osfile.jsm"); + Cu.import("resource://gre/modules/Services.jsm"); + Cu.import("resource://gre/modules/Sqlite.jsm"); + Cu.import("resource://gre/modules/Task.jsm"); + + const TEST_DATASET_ID = "test-dataset-id"; + const TEST_URL = "http://test.com"; + const TEST_TITLE = "Test"; + const TEST_BACKGROUND_URL = "http://example.com/background"; + const TEST_BACKGROUND_COLOR = "#FF9500"; + + const PREF_SYNC_CHECK_INTERVAL_SECS = "home.sync.checkIntervalSecs"; + const TEST_INTERVAL_SECS = 1; + + const DB_PATH = OS.Path.join(OS.Constants.Path.profileDir, "home.sqlite"); + + test_request_sync(); + test_periodic_sync(); + + function test_request_sync() { + // The current implementation of requestSync is synchronous. + let success = HomeProvider.requestSync(TEST_DATASET_ID, function callback(datasetId) { + is(datasetId, TEST_DATASET_ID, "expected dataset ID"); + }); + + ok(success, "requestSync success"); + } + + function test_periodic_sync() { + SimpleTest.registerCleanupFunction(function() { + Services.prefs.clearUserPref(PREF_SYNC_CHECK_INTERVAL_SECS); + HomeProvider.removePeriodicSync(TEST_DATASET_ID); + }); + + // Lower the check interval for testing purposes. + Services.prefs.setIntPref(PREF_SYNC_CHECK_INTERVAL_SECS, TEST_INTERVAL_SECS); + + HomeProvider.addPeriodicSync(TEST_DATASET_ID, TEST_INTERVAL_SECS, function callback(datasetId) { + is(datasetId, TEST_DATASET_ID, "expected dataset ID"); + }); + } + + add_task(function* test_save_and_delete() { + // Use the HomeProvider API to save some data. + let storage = HomeProvider.getStorage(TEST_DATASET_ID); + yield storage.save([{ + title: TEST_TITLE, + url: TEST_URL, + background_url: TEST_BACKGROUND_URL, + background_color: TEST_BACKGROUND_COLOR + }]); + + // Peek in the DB to make sure we have the right data. + let db = yield Sqlite.openConnection({ path: DB_PATH }); + + // Make sure the items table was created. + ok((yield db.tableExists("items")), "items table exists"); + + // Make sure the correct values for the item ended up in there. + let result = yield db.execute("SELECT * FROM items", null, function onRow(row){ + is(row.getResultByName("dataset_id"), TEST_DATASET_ID, "expected dataset ID"); + is(row.getResultByName("url"), TEST_URL, "expected test url"); + is(row.getResultByName("background_url"), TEST_BACKGROUND_URL, "expected background url"); + is(row.getResultByName("background_color"), TEST_BACKGROUND_COLOR, "expected background color"); + }); + + // Use the HomeProvider API to delete the data. + yield storage.deleteAll(); + + // Make sure the data was deleted. + result = yield db.execute("SELECT * FROM items"); + is(result.length, 0, "length is 0"); + + db.close(); + }); + + add_task(function* test_row_validation() { + // Use the HomeProvider API to save some data. + let storage = HomeProvider.getStorage(TEST_DATASET_ID); + + let invalidRows = [ + { url: "url" }, + { title: "title" }, + { description: "description" }, + { image_url: "image_url" } + ]; + + // None of these save calls should save anything + for (let row of invalidRows) { + try { + yield storage.save([row]); + } catch (e if e instanceof HomeProvider.ValidationError) { + // Just catch and ignore validation errors + } + } + + // Peek in the DB to make sure we have the right data. + let db = yield Sqlite.openConnection({ path: DB_PATH }); + + // Make sure no data has been saved. + let result = yield db.execute("SELECT * FROM items"); + is(result.length, 0, "length is 0"); + + db.close(); + }); + + add_task(function* test_save_transaction() { + // Use the HomeProvider API to save some data. + let storage = HomeProvider.getStorage(TEST_DATASET_ID); + + // One valid, one invalid + let rows = [ + { title: TEST_TITLE, url: TEST_URL }, + { image_url: "image_url" } + ]; + + // Try to save all the rows at once + try { + yield storage.save(rows); + } catch (e if e instanceof HomeProvider.ValidationError) { + // Just catch and ignore validation errors + } + + // Peek in the DB to make sure we have the right data. + let db = yield Sqlite.openConnection({ path: DB_PATH }); + + // Make sure no data has been saved. + let result = yield db.execute("SELECT * FROM items"); + is(result.length, 0, "length is 0"); + + db.close(); + }); + + </script> +</head> +<body> +<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=942288">Mozilla Bug 942288</a> +<br> +<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1184186">Migrated from Robocop testHomeProvider</a> +<p id="display"></p> +<div id="content" style="display: none"> + +</div> +<pre id="test"> +</pre> +</body> +</html> |