123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192 |
- '''
- Licensed to the Apache Software Foundation (ASF) under one
- or more contributor license agreements. See the NOTICE file
- distributed with this work for additional information
- regarding copyright ownership. The ASF licenses this file
- to you under the Apache License, Version 2.0 (the
- "License"); you may not use this file except in compliance
- with the License. You may obtain a copy of the License at
- http://www.apache.org/licenses/LICENSE-2.0
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- '''
- from unittest import TestCase
- from mock.mock import patch, MagicMock
- from resource_management.core import Environment, Fail
- from resource_management.core.system import System
- from resource_management.core.resources import User
- import pwd
- import subprocess
- @patch.object(System, "platform", new = 'redhat')
- class TestUserResource(TestCase):
- @patch.object(subprocess, "Popen")
- @patch.object(pwd, "getpwnam")
- def test_action_create_nonexistent(self, getpwnam_mock, popen_mock):
- subproc_mock = MagicMock()
- subproc_mock.returncode = 0
- popen_mock.return_value = subproc_mock
- getpwnam_mock.return_value = None
- with Environment('/') as env:
- user = User("mapred", action = "create")
-
- popen_mock.assert_called_with(['/bin/bash', '--login', '-c', 'useradd -m -s /bin/bash mapred'], shell=False, preexec_fn=None, stderr=-2, stdout=-1, env=None, cwd=None)
- self.assertEqual(popen_mock.call_count, 1)
- @patch.object(subprocess, "Popen")
- @patch.object(pwd, "getpwnam")
- def test_action_create_existent(self, getpwnam_mock, popen_mock):
- subproc_mock = MagicMock()
- subproc_mock.returncode = 0
- popen_mock.return_value = subproc_mock
- getpwnam_mock.return_value = 1
- with Environment('/') as env:
- user = User("mapred", action = "create")
-
- popen_mock.assert_called_with(['/bin/bash', '--login', '-c', 'usermod -s /bin/bash mapred'], shell=False, preexec_fn=None, stderr=-2, stdout=-1, env=None, cwd=None)
- self.assertEqual(popen_mock.call_count, 1)
- @patch.object(subprocess, "Popen")
- @patch.object(pwd, "getpwnam")
- def test_action_delete(self, getpwnam_mock, popen_mock):
- subproc_mock = MagicMock()
- subproc_mock.returncode = 0
- popen_mock.return_value = subproc_mock
- getpwnam_mock.return_value = 1
- with Environment('/') as env:
- user = User("mapred", action = "remove")
-
- popen_mock.assert_called_with(['/bin/bash', '--login', '-c', 'userdel mapred'], shell=False, preexec_fn=None, stderr=-2, stdout=-1, env=None, cwd=None)
- self.assertEqual(popen_mock.call_count, 1)
- @patch.object(subprocess, "Popen")
- @patch.object(pwd, "getpwnam")
- def test_attribute_comment(self, getpwnam_mock, popen_mock):
- subproc_mock = MagicMock()
- subproc_mock.returncode = 0
- popen_mock.return_value = subproc_mock
- getpwnam_mock.return_value = 1
- with Environment('/') as env:
- user = User("mapred",
- action = "create",
- comment = "testComment")
-
- popen_mock.assert_called_with(['/bin/bash', '--login', '-c', 'usermod -c testComment -s /bin/bash mapred'], shell=False, preexec_fn=None, stderr=-2, stdout=-1, env=None, cwd=None)
- self.assertEqual(popen_mock.call_count, 1)
- @patch.object(subprocess, "Popen")
- @patch.object(pwd, "getpwnam")
- def test_attribute_home(self, getpwnam_mock, popen_mock):
- subproc_mock = MagicMock()
- subproc_mock.returncode = 0
- popen_mock.return_value = subproc_mock
- getpwnam_mock.return_value = 1
- with Environment('/') as env:
- user = User("mapred",
- action = "create",
- home = "/test/home")
-
- popen_mock.assert_called_with(['/bin/bash', '--login', '-c', 'usermod -s /bin/bash -d /test/home mapred'], shell=False, preexec_fn=None, stderr=-2, stdout=-1, env=None, cwd=None)
- self.assertEqual(popen_mock.call_count, 1)
- @patch.object(subprocess, "Popen")
- @patch.object(pwd, "getpwnam")
- def test_attribute_password(self, getpwnam_mock, popen_mock):
- subproc_mock = MagicMock()
- subproc_mock.returncode = 0
- popen_mock.return_value = subproc_mock
- getpwnam_mock.return_value = 1
- with Environment('/') as env:
- user = User("mapred",
- action = "create",
- password = "secure")
-
- popen_mock.assert_called_with(['/bin/bash', '--login', '-c', 'usermod -s /bin/bash -p secure mapred'], shell=False, preexec_fn=None, stderr=-2, stdout=-1, env=None, cwd=None)
- self.assertEqual(popen_mock.call_count, 1)
- @patch.object(subprocess, "Popen")
- @patch.object(pwd, "getpwnam")
- def test_attribute_shell(self, getpwnam_mock, popen_mock):
- subproc_mock = MagicMock()
- subproc_mock.returncode = 0
- popen_mock.return_value = subproc_mock
- getpwnam_mock.return_value = 1
- with Environment('/') as env:
- user = User("mapred",
- action = "create",
- shell = "/bin/sh")
-
- popen_mock.assert_called_with(['/bin/bash', '--login', '-c', 'usermod -s /bin/sh mapred'], shell=False, preexec_fn=None, stderr=-2, stdout=-1, env=None, cwd=None)
- self.assertEqual(popen_mock.call_count, 1)
- @patch.object(subprocess, "Popen")
- @patch.object(pwd, "getpwnam")
- def test_attribute_uid(self, getpwnam_mock, popen_mock):
- subproc_mock = MagicMock()
- subproc_mock.returncode = 0
- popen_mock.return_value = subproc_mock
- getpwnam_mock.return_value = 1
- with Environment('/') as env:
- user = User("mapred",
- action = "create",
- uid = "1")
-
- popen_mock.assert_called_with(['/bin/bash', '--login', '-c', 'usermod -s /bin/bash -u 1 mapred'], shell=False, preexec_fn=None, stderr=-2, stdout=-1, env=None, cwd=None)
- self.assertEqual(popen_mock.call_count, 1)
- @patch.object(subprocess, "Popen")
- @patch.object(pwd, "getpwnam")
- def test_attribute_gid(self, getpwnam_mock, popen_mock):
- subproc_mock = MagicMock()
- subproc_mock.returncode = 0
- popen_mock.return_value = subproc_mock
- getpwnam_mock.return_value = 1
- with Environment('/') as env:
- user = User("mapred",
- action = "create",
- gid = "1")
-
- popen_mock.assert_called_with(['/bin/bash', '--login', '-c', 'usermod -s /bin/bash -g 1 mapred'], shell=False, preexec_fn=None, stderr=-2, stdout=-1, env=None, cwd=None)
- self.assertEqual(popen_mock.call_count, 1)
- @patch.object(subprocess, "Popen")
- @patch.object(pwd, "getpwnam")
- def test_attribute_groups(self, getpwnam_mock, popen_mock):
- subproc_mock = MagicMock()
- subproc_mock.returncode = 0
- popen_mock.return_value = subproc_mock
- getpwnam_mock.return_value = 1
- with Environment('/') as env:
- user = User("mapred",
- action = "create",
- groups = ['1','2','3'])
-
- popen_mock.assert_called_with(['/bin/bash', '--login', '-c', 'usermod -G 1,2,3 -s /bin/bash mapred'], shell=False, preexec_fn=None, stderr=-2, stdout=-1, env=None, cwd=None)
- self.assertEqual(popen_mock.call_count, 1)
|