Bug 1030536 - Write a marionette test for verifying the setters of adapter based on bluetooth API v2. r=btian

This commit is contained in:
Jamin Liu 2014-07-09 09:52:11 +08:00
parent fcd6950430
commit 0dc9176f60
3 changed files with 170 additions and 0 deletions

View File

@ -503,6 +503,64 @@ function waitForAdapterStateChanged(aAdapter, aStateChangesInOrder) {
return deferred.promise; return deferred.promise;
} }
/**
* Wait for an 'onattributechanged' event for a specified attribute and compare
* the new value with the expected value.
*
* Resolve if the specified event occurs. Never reject.
*
* Fulfill params: a BluetoothAttributeEvent with property attrs that contains
* changed BluetoothAdapterAttributes.
*
* @param aAdapter
* The BluetoothAdapter you want to use.
* @param aAttrName
* The name of the attribute of adapter.
* @param aExpectedValue
* The expected new value of the attribute.
*
* @return A deferred promise.
*/
function waitForAdapterAttributeChanged(aAdapter, aAttrName, aExpectedValue) {
let deferred = Promise.defer();
aAdapter.onattributechanged = function(aEvent) {
let i = aEvent.attrs.indexOf(aAttrName);
if (i >= 0) {
switch (aEvent.attrs[i]) {
case "state":
log(" 'state' changed to " + aAdapter.state);
is(aAdapter.state, aExpectedValue, "adapter.state");
break;
case "name":
log(" 'name' changed to " + aAdapter.name);
is(aAdapter.name, aExpectedValue, "adapter.name");
break;
case "address":
log(" 'address' changed to " + aAdapter.address);
is(aAdapter.address, aExpectedValue, "adapter.address");
break;
case "discoverable":
log(" 'discoverable' changed to " + aAdapter.discoverable);
is(aAdapter.discoverable, aExpectedValue, "adapter.discoverable");
break;
case "discovering":
log(" 'discovering' changed to " + aAdapter.discovering);
is(aAdapter.discovering, aExpectedValue, "adapter.discovering");
break;
case "unknown":
default:
ok(false, "Unknown attribute '" + aAttrName + "' changed." );
break;
}
aAdapter.onattributechanged = null;
deferred.resolve(aEvent);
}
};
return deferred.promise;
}
/** /**
* Flush permission settings and call |finish()|. * Flush permission settings and call |finish()|.
*/ */

View File

@ -5,3 +5,4 @@ qemu = false
[test_dom_BluetoothManager_API2.js] [test_dom_BluetoothManager_API2.js]
[test_dom_BluetoothAdapter_enable_API2.js] [test_dom_BluetoothAdapter_enable_API2.js]
[test_dom_BluetoothAdapter_setters_API2.js]

View File

@ -0,0 +1,111 @@
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/. */
///////////////////////////////////////////////////////////////////////////////
// Test Purpose:
// To verify that all setters of BluetoothAdapter (except for pairing related
// APIs) can change properties correctly.
//
// Test Procedure:
// [0] Set Bluetooth permission and enable default adapter.
// [1] Verify the functionality of 'setName'.
// [2] Verify the functionality of 'setDiscoverable'.
// [3] Disable Bluetooth and collect changed attributes.
// [4] Verify the changes of attributes when BT is disabled.
// [5] Set properties when Bluetooth is disabled.
// [6] Enable Bluetooth and collect changed attributes.
// [7] Verify the changes of attributes when BT is enabled.
// [8] Restore the original 'adapter.name'.
// [9] Check the validity of setting properties to their present value.
//
// Test Coverage:
// - BluetoothAdapter.setName()
// - BluetoothAdapter.setDiscoverable()
// - BluetoothAdapter.onattributechanged()
// - BluetoothAdapter.state
// - BluetoothAdapter.name
// - BluetoothAdapter.discoverable
//
///////////////////////////////////////////////////////////////////////////////
MARIONETTE_TIMEOUT = 60000;
MARIONETTE_HEAD_JS = 'head.js';
startBluetoothTest(true, function testCaseMain(aAdapter) {
log("Checking adapter attributes ...");
is(aAdapter.state, "enabled", "adapter.state");
isnot(aAdapter.address, "", "adapter.address");
// Since adapter has just been re-enabled, these properties should be 'false'.
is(aAdapter.discovering, false, "adapter.discovering");
is(aAdapter.discoverable, false, "adapter.discoverable at step [0]");
log("adapter.address: " + aAdapter.address);
log("adapter.name: " + aAdapter.name);
let originalName = aAdapter.name;
return Promise.resolve()
.then(function() {
log("[1] Set 'name' ... ");
let promises = [];
promises.push(waitForAdapterAttributeChanged(aAdapter, "name", originalName + "_modified"));
promises.push(aAdapter.setName(originalName + "_modified"));
return Promise.all(promises);
})
.then(function() {
log("[2] Set 'discoverable' ... ");
let promises = [];
promises.push(waitForAdapterAttributeChanged(aAdapter, "discoverable", !aAdapter.discoverable));
promises.push(aAdapter.setDiscoverable(!aAdapter.discoverable));
return Promise.all(promises);
})
.then(function() {
log("[3] Disable Bluetooth ...");
let promises = [];
promises.push(waitForAdapterStateChanged(aAdapter, ["disabling", "disabled"]));
promises.push(aAdapter.disable());
return Promise.all(promises);
})
.then(function(aResults) {
log("[4] Verify the changes of attributes ...");
isnot(aResults[0].indexOf("name"), -1, "Indicator of 'name' changed event");
isnot(aResults[0].indexOf("discoverable"), -1, "Indicator of 'discoverable' changed event");
is(aAdapter.name, "", "adapter.name");
is(aAdapter.discoverable, false, "adapter.discoverable at step [4]");
})
.then(() => log("[5] Set properties when Bluetooth is disabled ..."))
.then(() => aAdapter.setName(originalName))
.then(() => ok(false, "Failed to handle 'setName' when BT is disabled."),
() => aAdapter.setDiscoverable(true))
.then(() => ok(false, "Failed to handle 'setDiscoverable' when BT is disabled."),
() => null)
.then(function() {
log("[6] Enable Bluetooth ...");
let promises = [];
promises.push(waitForAdapterStateChanged(aAdapter, ["enabling", "enabled"]));
promises.push(aAdapter.enable());
return Promise.all(promises);
})
.then(function(aResults) {
log("[7] Verify the changes of attributes ...");
isnot(aResults[0].indexOf("name"), -1, "Indicator of 'name' changed event");
is(aAdapter.name, originalName + "_modified", "adapter.name");
is(aAdapter.discoverable, false, "adapter.discoverable at step [7]");
})
.then(function() {
log("[8] Restore the original 'name' ...");
let promises = [];
promises.push(waitForAdapterAttributeChanged(aAdapter, "name", originalName));
promises.push(aAdapter.setName(originalName));
return Promise.all(promises);
})
.then(function() {
log("[9] Check the validity of setting properties to their present value ...");
let promises = [];
promises.push(aAdapter.setName(aAdapter.name));
promises.push(aAdapter.setDiscoverable(aAdapter.discoverable));
return Promise.all(promises);
});
});