summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorBrian Gix <brian.gix@intel.com>2019-05-15 09:34:15 -0700
committerBrian Gix <brian.gix@intel.com>2019-05-15 09:36:42 -0700
commit895ba2cdf9405c23993f051562924148e1693736 (patch)
tree24f77f00b7f09489ad31566115b8fa9f65e710a9 /test
parentf66e29d5662dabfa8f361cce5a453514f30a27fd (diff)
downloadbluez-895ba2cdf9405c23993f051562924148e1693736.tar.gz
mesh: Add "create" command to test app
Like "join" this command generates a UUID and calls CreateNetwork() and displays the UUID and token.
Diffstat (limited to 'test')
-rwxr-xr-xtest/test-mesh49
1 files changed, 47 insertions, 2 deletions
diff --git a/test/test-mesh b/test/test-mesh
index 7201669a8..c075a642b 100755
--- a/test/test-mesh
+++ b/test/test-mesh
@@ -23,6 +23,7 @@
#
# The main menu:
# token
+# create
# join
# attach
# remove
@@ -37,6 +38,18 @@
# The token can be set from command line arguments as
# well.
#
+# create
+# Creates a new mesh network, with its first local
+# node. The test generates device UUID to store for
+# the initial node, and the daemon will create all
+# the other parameters including Unicast address 0x0001
+# for the new nodes primary element.
+# In case of successful creation, the application
+# automatically attaches as a node to the daemon. A node
+# 'token' is returned to the application and is used
+# for the runtime of the test, and may be used in future
+# attach requests.
+#
# join
# Request provisioning of a device to become a node
# on a mesh network. The test generates device UUID
@@ -57,8 +70,8 @@
# For the call to be successful, the valid node token must
# be already set, either from command arguments or by
# executing "set token" operation or automatically after
-# successfully executing "join" operation in the same test
-# run.
+# successfully executing "join" or "create" operation in
+# the same test run.
#
# remove
# Permanently removes any node configuration from daemon
@@ -241,6 +254,22 @@ def join_cb():
def join_error_cb(reason):
print('Join procedure failed: ', reason)
+def create_cb(value):
+ global token
+ global have_token
+ global attach
+
+ print(set_yellow('Created mesh network with token ') +
+ set_green(format(value, '16x')))
+
+ token = value
+ have_token = True
+ if attached == False:
+ attach(token)
+
+def create_error_cb(reason):
+ print('Create procedure failed: ', reason)
+
def remove_node_cb():
global attached
global have_token
@@ -737,6 +766,8 @@ class MainMenu(Menu):
menu_items = {
'token': MenuItem(' - set node ID (token)',
self.__cmd_set_token),
+ 'create': MenuItem(' - create mesh network',
+ self.__cmd_create),
'join': MenuItem(' - join mesh network',
self.__cmd_join),
'attach': MenuItem(' - attach mesh node',
@@ -790,6 +821,20 @@ class MainMenu(Menu):
user_input = INPUT_MESSAGE_PAYLOAD;
print(set_cyan('Enter message payload (hex):'))
+ def __cmd_create(self):
+ if agent == None:
+ print(set_error('Provisioning agent not found'))
+ return
+
+ uuid = bytearray.fromhex("0a0102030405060708090A0B0C0D0E0F")
+ random.shuffle(uuid)
+ uuid_str = array_to_string(uuid)
+
+ print(set_yellow('Creating with UUID ') + set_green(uuid_str))
+ mesh_net.CreateNetwork(app.get_path(), uuid,
+ reply_handler=create_cb,
+ error_handler=create_error_cb)
+
def __cmd_join(self):
if agent == None:
print(set_error('Provisioning agent not found'))