Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(40)

Unified Diff: tools/telemetry/telemetry/core/backends/chrome/cros_interface_unittest.py

Issue 541693004: Move remote platform creation logic from cros_browser_finders to platform. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address achuith's comments Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: tools/telemetry/telemetry/core/backends/chrome/cros_interface_unittest.py
diff --git a/tools/telemetry/telemetry/core/backends/chrome/cros_interface_unittest.py b/tools/telemetry/telemetry/core/backends/chrome/cros_interface_unittest.py
deleted file mode 100644
index 304c5647225843ee564d680a3037a83c04d754cc..0000000000000000000000000000000000000000
--- a/tools/telemetry/telemetry/core/backends/chrome/cros_interface_unittest.py
+++ /dev/null
@@ -1,184 +0,0 @@
-# Copyright 2013 The Chromium Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style license that can be
-# found in the LICENSE file.
-
-# TODO(nduca): Rewrite what some of these tests to use mocks instead of
-# actually talking to the device. This would improve our coverage quite
-# a bit.
-
-import socket
-import tempfile
-import unittest
-
-from telemetry import benchmark
-from telemetry.core import forwarders
-from telemetry.core.backends.chrome import cros_interface
-from telemetry.core.forwarders import cros_forwarder
-from telemetry.unittest import options_for_unittests
-
-
-class CrOSInterfaceTest(unittest.TestCase):
- @benchmark.Enabled('cros-chrome')
- def testPushContents(self):
- remote = options_for_unittests.GetCopy().cros_remote
- with cros_interface.CrOSInterface(
- remote,
- options_for_unittests.GetCopy().cros_ssh_identity) as cri:
- cri.RunCmdOnDevice(['rm', '-rf', '/tmp/testPushContents'])
- cri.PushContents('hello world', '/tmp/testPushContents')
- contents = cri.GetFileContents('/tmp/testPushContents')
- self.assertEquals(contents, 'hello world')
-
- @benchmark.Enabled('cros-chrome')
- def testExists(self):
- remote = options_for_unittests.GetCopy().cros_remote
- with cros_interface.CrOSInterface(
- remote,
- options_for_unittests.GetCopy().cros_ssh_identity) as cri:
- self.assertTrue(cri.FileExistsOnDevice('/proc/cpuinfo'))
- self.assertTrue(cri.FileExistsOnDevice('/etc/passwd'))
- self.assertFalse(cri.FileExistsOnDevice('/etc/sdlfsdjflskfjsflj'))
-
- @benchmark.Enabled('linux')
- def testExistsLocal(self):
- with cros_interface.CrOSInterface() as cri:
- self.assertTrue(cri.FileExistsOnDevice('/proc/cpuinfo'))
- self.assertTrue(cri.FileExistsOnDevice('/etc/passwd'))
- self.assertFalse(cri.FileExistsOnDevice('/etc/sdlfsdjflskfjsflj'))
-
- @benchmark.Enabled('cros-chrome')
- def testGetFileContents(self): # pylint: disable=R0201
- remote = options_for_unittests.GetCopy().cros_remote
- with cros_interface.CrOSInterface(
- remote,
- options_for_unittests.GetCopy().cros_ssh_identity) as cri:
- hosts = cri.GetFileContents('/etc/lsb-release')
- self.assertTrue('CHROMEOS' in hosts)
-
- @benchmark.Enabled('cros-chrome')
- def testGetFileContentsNonExistent(self):
- remote = options_for_unittests.GetCopy().cros_remote
- with cros_interface.CrOSInterface(
- remote,
- options_for_unittests.GetCopy().cros_ssh_identity) as cri:
- f = tempfile.NamedTemporaryFile()
- cri.PushContents('testGetFileNonExistent', f.name)
- cri.RmRF(f.name)
- self.assertRaises(
- OSError,
- lambda: cri.GetFileContents(f.name))
-
- @benchmark.Enabled('cros-chrome')
- def testGetFile(self): # pylint: disable=R0201
- remote = options_for_unittests.GetCopy().cros_remote
- with cros_interface.CrOSInterface(
- remote,
- options_for_unittests.GetCopy().cros_ssh_identity) as cri:
- f = tempfile.NamedTemporaryFile()
- cri.GetFile('/etc/lsb-release', f.name)
- with open(f.name, 'r') as f2:
- res = f2.read()
- self.assertTrue('CHROMEOS' in res)
-
- @benchmark.Enabled('cros-chrome')
- def testGetFileNonExistent(self):
- remote = options_for_unittests.GetCopy().cros_remote
- with cros_interface.CrOSInterface(
- remote,
- options_for_unittests.GetCopy().cros_ssh_identity) as cri:
- f = tempfile.NamedTemporaryFile()
- cri.PushContents('testGetFileNonExistent', f.name)
- cri.RmRF(f.name)
- self.assertRaises(
- OSError,
- lambda: cri.GetFile(f.name))
-
- @benchmark.Enabled('cros-chrome')
- def testIsServiceRunning(self):
- remote = options_for_unittests.GetCopy().cros_remote
- with cros_interface.CrOSInterface(
- remote,
- options_for_unittests.GetCopy().cros_ssh_identity) as cri:
- self.assertTrue(cri.IsServiceRunning('openssh-server'))
-
- @benchmark.Enabled('linux')
- def testIsServiceRunningLocal(self):
- with cros_interface.CrOSInterface() as cri:
- self.assertTrue(cri.IsServiceRunning('dbus'))
-
- @benchmark.Enabled('cros-chrome')
- def testGetRemotePortAndIsHTTPServerRunningOnPort(self):
- remote = options_for_unittests.GetCopy().cros_remote
- with cros_interface.CrOSInterface(
- remote,
- options_for_unittests.GetCopy().cros_ssh_identity) as cri:
-
- # Create local server.
- sock = socket.socket()
- sock.bind(('', 0))
- port = sock.getsockname()[1]
- sock.listen(0)
-
- # Get remote port and ensure that it was unused.
- remote_port = cri.GetRemotePort()
- self.assertFalse(cri.IsHTTPServerRunningOnPort(remote_port))
-
- # Forward local server's port to remote device's remote_port.
- forwarder = cros_forwarder.CrOsForwarderFactory(cri).Create(
- forwarders.PortPairs(http=forwarders.PortPair(port, remote_port),
- https=None, dns=None))
-
- # At this point, remote device should be able to connect to local server.
- self.assertTrue(cri.IsHTTPServerRunningOnPort(remote_port))
-
- # Next remote port shouldn't be the same as remote_port, since remote_port
- # is now in use.
- self.assertTrue(cri.GetRemotePort() != remote_port)
-
-
- # Close forwarder and local server ports.
- forwarder.Close()
- sock.close()
-
- # Device should no longer be able to connect to remote_port since it is no
- # longer in use.
- self.assertFalse(cri.IsHTTPServerRunningOnPort(remote_port))
-
- @benchmark.Enabled('cros-chrome')
- def testGetRemotePortReservedPorts(self):
- remote = options_for_unittests.GetCopy().cros_remote
- with cros_interface.CrOSInterface(
- remote,
- options_for_unittests.GetCopy().cros_ssh_identity) as cri:
-
- # Should return 2 separate ports even though the first one isn't
- # technically being used yet.
- remote_port_1 = cri.GetRemotePort()
- remote_port_2 = cri.GetRemotePort()
-
- self.assertTrue(remote_port_1 != remote_port_2)
-
- # TODO(tengs): It would be best if we can filter this test and other tests
- # that need to be run locally based on the platform of the system browser.
- @benchmark.Enabled('linux')
- def testEscapeCmdArguments(self):
- ''' Commands and their arguments that are executed through the cros
- interface should follow bash syntax. This test needs to run on remotely
- and locally on the device to check for consistency.
- '''
- with cros_interface.CrOSInterface(
- options_for_unittests.GetCopy().cros_remote,
- options_for_unittests.GetCopy().cros_ssh_identity) as cri:
-
- # Check arguments with no special characters
- stdout, _ = cri.RunCmdOnDevice(['echo', '--arg1=value1', '--arg2=value2',
- '--arg3="value3"'])
- assert(stdout.strip() == '--arg1=value1 --arg2=value2 --arg3=value3')
-
- # Check argument with special characters escaped
- stdout, _ = cri.RunCmdOnDevice(['echo', '--arg=A\\; echo \\"B\\"'])
- assert(stdout.strip() == '--arg=A; echo "B"')
-
- # Check argument with special characters in quotes
- stdout, _ = cri.RunCmdOnDevice(['echo', "--arg='$HOME;;$PATH'"])
- assert(stdout.strip() == "--arg=$HOME;;$PATH")

Powered by Google App Engine
This is Rietveld 408576698