123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221 |
- # Copyright (c) 2015 Stephen Warren
- # Copyright (c) 2015-2016, NVIDIA CORPORATION. All rights reserved.
- #
- # SPDX-License-Identifier: GPL-2.0
- # Test operation of shell commands relating to environment variables.
- import pytest
- # FIXME: This might be useful for other tests;
- # perhaps refactor it into ConsoleBase or some other state object?
- class StateTestEnv(object):
- '''Container that represents the state of all U-Boot environment variables.
- This enables quick determination of existant/non-existant variable
- names.
- '''
- def __init__(self, u_boot_console):
- '''Initialize a new StateTestEnv object.
- Args:
- u_boot_console: A U-Boot console.
- Returns:
- Nothing.
- '''
- self.u_boot_console = u_boot_console
- self.get_env()
- self.set_var = self.get_non_existent_var()
- def get_env(self):
- '''Read all current environment variables from U-Boot.
- Args:
- None.
- Returns:
- Nothing.
- '''
- response = self.u_boot_console.run_command('printenv')
- self.env = {}
- for l in response.splitlines():
- if not '=' in l:
- continue
- (var, value) = l.strip().split('=', 1)
- self.env[var] = value
- def get_existent_var(self):
- '''Return the name of an environment variable that exists.
- Args:
- None.
- Returns:
- The name of an environment variable.
- '''
- for var in self.env:
- return var
- def get_non_existent_var(self):
- '''Return the name of an environment variable that does not exist.
- Args:
- None.
- Returns:
- The name of an environment variable.
- '''
- n = 0
- while True:
- var = 'test_env_' + str(n)
- if var not in self.env:
- return var
- n += 1
- @pytest.fixture(scope='module')
- def state_test_env(u_boot_console):
- '''pytest fixture to provide a StateTestEnv object to tests.'''
- return StateTestEnv(u_boot_console)
- def unset_var(state_test_env, var):
- '''Unset an environment variable.
- This both executes a U-Boot shell command and updates a StateTestEnv
- object.
- Args:
- state_test_env: The StateTestEnv object to updata.
- var: The variable name to unset.
- Returns:
- Nothing.
- '''
- state_test_env.u_boot_console.run_command('setenv %s' % var)
- if var in state_test_env.env:
- del state_test_env.env[var]
- def set_var(state_test_env, var, value):
- '''Set an environment variable.
- This both executes a U-Boot shell command and updates a StateTestEnv
- object.
- Args:
- state_test_env: The StateTestEnv object to updata.
- var: The variable name to set.
- value: The value to set the variable to.
- Returns:
- Nothing.
- '''
- state_test_env.u_boot_console.run_command('setenv %s "%s"' % (var, value))
- state_test_env.env[var] = value
- def validate_empty(state_test_env, var):
- '''Validate that a variable is not set, using U-Boot shell commands.
- Args:
- var: The variable name to test.
- Returns:
- Nothing.
- '''
- response = state_test_env.u_boot_console.run_command('echo $%s' % var)
- assert response == ''
- def validate_set(state_test_env, var, value):
- '''Validate that a variable is set, using U-Boot shell commands.
- Args:
- var: The variable name to test.
- value: The value the variable is expected to have.
- Returns:
- Nothing.
- '''
- # echo does not preserve leading, internal, or trailing whitespace in the
- # value. printenv does, and hence allows more complete testing.
- response = state_test_env.u_boot_console.run_command('printenv %s' % var)
- assert response == ('%s=%s' % (var, value))
- def test_env_echo_exists(state_test_env):
- '''Test echoing a variable that exists.'''
- var = state_test_env.get_existent_var()
- value = state_test_env.env[var]
- validate_set(state_test_env, var, value)
- def test_env_echo_non_existent(state_test_env):
- '''Test echoing a variable that doesn't exist.'''
- var = state_test_env.set_var
- validate_empty(state_test_env, var)
- def test_env_printenv_non_existent(state_test_env):
- '''Test printenv error message for non-existant variables.'''
- var = state_test_env.set_var
- c = state_test_env.u_boot_console
- with c.disable_check('error_notification'):
- response = c.run_command('printenv %s' % var)
- assert(response == '## Error: "%s" not defined' % var)
- def test_env_unset_non_existent(state_test_env):
- '''Test unsetting a nonexistent variable.'''
- var = state_test_env.get_non_existent_var()
- unset_var(state_test_env, var)
- validate_empty(state_test_env, var)
- def test_env_set_non_existent(state_test_env):
- '''Test set a non-existant variable.'''
- var = state_test_env.set_var
- value = 'foo'
- set_var(state_test_env, var, value)
- validate_set(state_test_env, var, value)
- def test_env_set_existing(state_test_env):
- '''Test setting an existant variable.'''
- var = state_test_env.set_var
- value = 'bar'
- set_var(state_test_env, var, value)
- validate_set(state_test_env, var, value)
- def test_env_unset_existing(state_test_env):
- '''Test unsetting a variable.'''
- var = state_test_env.set_var
- unset_var(state_test_env, var)
- validate_empty(state_test_env, var)
- def test_env_expansion_spaces(state_test_env):
- '''Test expanding a variable that contains a space in its value.'''
- var_space = None
- var_test = None
- try:
- var_space = state_test_env.get_non_existent_var()
- set_var(state_test_env, var_space, ' ')
- var_test = state_test_env.get_non_existent_var()
- value = ' 1${%(var_space)s}${%(var_space)s} 2 ' % locals()
- set_var(state_test_env, var_test, value)
- value = ' 1 2 '
- validate_set(state_test_env, var_test, value)
- finally:
- if var_space:
- unset_var(state_test_env, var_space)
- if var_test:
- unset_var(state_test_env, var_test)
|