mirror of
				https://github.com/ARM-software/devlib.git
				synced 2025-10-25 20:13:20 +01:00 
			
		
		
		
	devlib: don't use sudo/su if you are root
Most invocations of target.execute() pass as_root=self.is_rooted . However, is_rooted is not what you want to do here. as_root tells the connection to wrap the command around sudo/su to execute the command as root. is_rooted returns True if the device can run commands as root (for example, if we are connected as root). If you are already connected as root, there is no need to wrap the command around sudo, you are already root. In that case, as_root should always be false. Define a new property for the target called needs_su that returns true if the target needs to run a command to get superuser privileges.
This commit is contained in:
		| @@ -79,6 +79,11 @@ class Target(object): | |||||||
|         except (TargetError, TimeoutError): |         except (TargetError, TimeoutError): | ||||||
|             return False |             return False | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     @memoized | ||||||
|  |     def needs_su(self): | ||||||
|  |         return not self.connected_as_root and self.is_rooted | ||||||
|  |  | ||||||
|     @property |     @property | ||||||
|     @memoized |     @memoized | ||||||
|     def kernel_version(self): |     def kernel_version(self): | ||||||
| @@ -302,7 +307,7 @@ class Target(object): | |||||||
|     # sysfs interaction |     # sysfs interaction | ||||||
|  |  | ||||||
|     def read_value(self, path, kind=None): |     def read_value(self, path, kind=None): | ||||||
|         output = self.execute('cat \'{}\''.format(path), as_root=self.is_rooted).strip()  # pylint: disable=E1103 |         output = self.execute('cat \'{}\''.format(path), as_root=self.needs_su).strip()  # pylint: disable=E1103 | ||||||
|         if kind: |         if kind: | ||||||
|             return kind(output) |             return kind(output) | ||||||
|         else: |         else: | ||||||
| @@ -325,7 +330,7 @@ class Target(object): | |||||||
|  |  | ||||||
|     def reset(self): |     def reset(self): | ||||||
|         try: |         try: | ||||||
|             self.execute('reboot', as_root=self.is_rooted, timeout=2) |             self.execute('reboot', as_root=self.needs_su, timeout=2) | ||||||
|         except (TargetError, TimeoutError, subprocess.CalledProcessError): |         except (TargetError, TimeoutError, subprocess.CalledProcessError): | ||||||
|             # on some targets "reboot" doesn't return gracefully |             # on some targets "reboot" doesn't return gracefully | ||||||
|             pass |             pass | ||||||
| @@ -723,7 +728,7 @@ class AndroidTarget(Target): | |||||||
|     def reset(self, fastboot=False):  # pylint: disable=arguments-differ |     def reset(self, fastboot=False):  # pylint: disable=arguments-differ | ||||||
|         try: |         try: | ||||||
|             self.execute('reboot {}'.format(fastboot and 'fastboot' or ''), |             self.execute('reboot {}'.format(fastboot and 'fastboot' or ''), | ||||||
|                          as_root=self.is_rooted, timeout=2) |                          as_root=self.needs_su, timeout=2) | ||||||
|         except (TargetError, TimeoutError, subprocess.CalledProcessError): |         except (TargetError, TimeoutError, subprocess.CalledProcessError): | ||||||
|             # on some targets "reboot" doesn't return gracefully |             # on some targets "reboot" doesn't return gracefully | ||||||
|             pass |             pass | ||||||
| @@ -759,7 +764,7 @@ class AndroidTarget(Target): | |||||||
|         a subprocess object). |         a subprocess object). | ||||||
|         """ |         """ | ||||||
|         if as_root is None: |         if as_root is None: | ||||||
|             as_root = self.is_rooted |             as_root = self.needs_su | ||||||
|         try: |         try: | ||||||
|             command = 'cd {} && {} nohup {}'.format(self.working_directory, self.busybox, command) |             command = 'cd {} && {} nohup {}'.format(self.working_directory, self.busybox, command) | ||||||
|             output = self.execute(command, timeout=1, as_root=as_root) |             output = self.execute(command, timeout=1, as_root=as_root) | ||||||
| @@ -888,9 +893,9 @@ class AndroidTarget(Target): | |||||||
|         on_device_executable = self.path.join(self.executables_directory, executable_name) |         on_device_executable = self.path.join(self.executables_directory, executable_name) | ||||||
|         self.push(filepath, on_device_file) |         self.push(filepath, on_device_file) | ||||||
|         if on_device_file != on_device_executable: |         if on_device_file != on_device_executable: | ||||||
|             self.execute('cp {} {}'.format(on_device_file, on_device_executable), as_root=self.is_rooted) |             self.execute('cp {} {}'.format(on_device_file, on_device_executable), as_root=self.needs_su) | ||||||
|             self.remove(on_device_file, as_root=self.is_rooted) |             self.remove(on_device_file, as_root=self.needs_su) | ||||||
|         self.execute("chmod 0777 '{}'".format(on_device_executable), as_root=self.is_rooted) |         self.execute("chmod 0777 '{}'".format(on_device_executable), as_root=self.needs_su) | ||||||
|         self._installed_binaries[executable_name] = on_device_executable |         self._installed_binaries[executable_name] = on_device_executable | ||||||
|         return on_device_executable |         return on_device_executable | ||||||
|  |  | ||||||
| @@ -900,7 +905,7 @@ class AndroidTarget(Target): | |||||||
|     def uninstall_executable(self, executable_name): |     def uninstall_executable(self, executable_name): | ||||||
|         on_device_executable = self.path.join(self.executables_directory, executable_name) |         on_device_executable = self.path.join(self.executables_directory, executable_name) | ||||||
|         self._ensure_executables_directory_is_writable() |         self._ensure_executables_directory_is_writable() | ||||||
|         self.remove(on_device_executable, as_root=self.is_rooted) |         self.remove(on_device_executable, as_root=self.needs_su) | ||||||
|  |  | ||||||
|     def dump_logcat(self, filepath, filter=None, append=False, timeout=30):  # pylint: disable=redefined-builtin |     def dump_logcat(self, filepath, filter=None, append=False, timeout=30):  # pylint: disable=redefined-builtin | ||||||
|         op = '>>' if append else '>' |         op = '>>' if append else '>' | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user