def test_non_zero_exit_status_empty_output_but_non_empty_stderr(self): a = Action() a.command = "echo hooo >&2 ; exit 1" a.timeout = 10 a.env = {} # :fixme: this sould be pre-set in Action.__init__() a.execute() self.wait_finished(a) self.assertEqual(a.output, "hooo")
def test_grep_for_environment_variables(self): if os.name == 'nt': return a = Action() a.timeout = 10 a.env = {} # :fixme: this sould be pre-set in Action.__init__() a.command = "/usr/bin/env | grep TITI" self.assertNotIn('TITI', a.get_local_environnement()) a.env = {'TITI': 'est en vacance'} self.assertIn('TITI', a.get_local_environnement()) self.assertEqual(a.get_local_environnement()['TITI'], 'est en vacance' ) a.execute() self.wait_finished(a) self.assertEqual(a.output, 'TITI=est en vacance')
def test_execve_fail_with_utf8(self): if os.name == 'nt': return a = Action() a.timeout = 10 a.env = {} # :fixme: this sould be pre-set in Action.__init__() a.command = u"/bin/echo Wiadomo\u015b\u0107" a.execute() self.wait_finished(a) #print a.output self.assertEqual(a.output.decode('utf8'), u"Wiadomo\u015b\u0107")
def test_got_pipe_shell_characters(self): a = Action() a.timeout = 10 a.command = "libexec/dummy_command_nobang.sh | grep 'Please do not use me directly'" a.env = {} if os.name == 'nt': return self.assertEqual(True, a.got_shell_characters()) a.execute() self.assertEqual('launched', a.status) self.wait_finished(a) print "F**k", a.status, a.output self.assertEqual(0, a.exit_status) self.assertEqual('done', a.status)
def test_noshell_bang_command(self): a = Action() a.timeout = 10 a.command = "libexec/dummy_command_nobang.sh" a.env = {} if os.name == 'nt': return self.assertEqual(False, a.got_shell_characters()) a.execute() self.assertEqual('launched', a.status) self.wait_finished(a) print "F**k", a.status, a.output self.assertEqual(0, a.exit_status) self.assertEqual('done', a.status)
def test_grep_for_environment_variables(self): """ Test grep for environment variables :return: None """ a = Action() a.command = "/usr/bin/env | grep ALIGNAK_TEST_VARIABLE" assert 'ALIGNAK_TEST_VARIABLE' not in a.get_local_environnement() a.env = {'ALIGNAK_TEST_VARIABLE': 'is now existing and defined'} assert 'ALIGNAK_TEST_VARIABLE' in a.get_local_environnement() assert a.get_local_environnement()['ALIGNAK_TEST_VARIABLE'] == 'is now existing and defined' # Execute action a.execute() self.wait_finished(a) assert a.output == 'ALIGNAK_TEST_VARIABLE=is now existing and defined'
def test_grep_for_environment_variables(self): """ Test grep for environment variables :return: None """ a = Action() a.command = "/usr/bin/env | grep ALIGNAK_TEST_VARIABLE" assert 'ALIGNAK_TEST_VARIABLE' not in a.get_local_environnement() a.env = {'ALIGNAK_TEST_VARIABLE': 'is now existing and defined'} assert 'ALIGNAK_TEST_VARIABLE' in a.get_local_environnement() assert a.get_local_environnement( )['ALIGNAK_TEST_VARIABLE'] == 'is now existing and defined' # Execute action a.execute() self.wait_finished(a) assert a.output == 'ALIGNAK_TEST_VARIABLE=is now existing and defined'
def test_action(self): a = Action() a.timeout = 10 a.env = {} if os.name == 'nt': a.command = r'libexec\\dummy_command.cmd' else: a.command = "libexec/dummy_command.sh" self.assertEqual(False, a.got_shell_characters()) a.execute() self.assertEqual('launched', a.status) # Give also the max output we want for the command self.wait_finished(a) self.assertEqual(0, a.exit_status) self.assertEqual('done', a.status) print a.output self.assertEqual("Hi, I'm for testing only. Please do not use me directly, really", a.output) self.assertEqual("Hip=99% Bob=34mm", a.perf_data)
def test_echo_environment_variables(self): """ Test echo environment variables :return: None """ self.print_header() a = Action() a.command = "echo $ALIGNAK_TEST_VARIABLE" assert 'ALIGNAK_TEST_VARIABLE' not in a.get_local_environnement() a.env = {'ALIGNAK_TEST_VARIABLE': 'is now existing and defined'} assert 'ALIGNAK_TEST_VARIABLE' in a.get_local_environnement() assert a.get_local_environnement( )['ALIGNAK_TEST_VARIABLE'] == 'is now existing and defined' # Execute action a.execute() self.wait_finished(a) assert a.output == 'is now existing and defined'
def test_got_unclosed_quote(self): # https://github.com/naparuba/shinken/issues/155 a = Action() a.timeout = 10 a.command = "libexec/dummy_command_nobang.sh -a 'wwwwzzzzeeee" a.env = {} if os.name == 'nt': return a.execute() self.wait_finished(a) self.assertEqual('done', a.status) print "F**k", a.status, a.output if sys.version_info < (2, 7): # cygwin: /bin/sh: -c: line 0: unexpected EOF while looking for matching' # ubuntu: /bin/sh: Syntax error: Unterminated quoted string self.assertTrue(a.output.startswith("/bin/sh")) self.assertEqual(3, a.exit_status) else: self.assertEqual('Not a valid shell command: No closing quotation', a.output) self.assertEqual(3, a.exit_status)
def test_huge_output(self): a = Action() a.timeout = 5 a.env = {} if os.name == 'nt': a.command = r"""python -c 'print "A"*1000000'""" # FROM NOW IT4S FAIL ON WINDOWS :( return else: a.command = r"""python -u -c 'print "A"*100000'""" print "EXECUTE" a.execute() print "EXECUTE FINISE" self.assertEqual('launched', a.status) # Give also the max output we want for the command self.wait_finished(a, 10000000000) print "Status?", a.exit_status self.assertEqual(0, a.exit_status) print "Output", len(a.output) self.assertEqual(0, a.exit_status) self.assertEqual('done', a.status) self.assertEqual("A"*100000, a.output) self.assertEqual("", a.perf_data)