예제 #1
0
  def test_check_user_in_group(self):
    vc = ValidateConfigs()

    self.assertTrue(vc.check_user_in_group('root', 'root'))
    self.assertFalse(vc.check_user_in_group('root', 'wrong_group'))
    self.assertFalse(vc.check_user_in_group('wrong_user', 'root'))
    self.assertFalse(vc.check_user_in_group('wrong_user', 'wrong_group'))
예제 #2
0
  def test_check_users(self, geteuid_mock):
    # if excecuting not by root
    geteuid_mock.return_value = 1

    vc = ValidateConfigs()
    params = {
      "component_configurations/NAMENODE/hadoop-env/hdfs_user" : "root",
      "component_configurations/NAMENODE/hadoop-env/user_group" : "root"
    }
    self.assertEquals(vc.check_users(params), True)
    params = {
      "component_configurations/NAMENODE/hadoop-env/hdfs_user" : "root",
      "component_configurations/NAMENODE/hadoop-env/user_group" : "wrong_group"
    }
    self.assertEquals(vc.check_users(params), False)
    params = {
      "component_configurations/NAMENODE/hadoop-env/hdfs_user" : "wrong_user",
      "component_configurations/NAMENODE/hadoop-env/user_group" : "root"
    }
    self.assertEquals(vc.check_users(params), False)
    params = {
      "component_configurations/NAMENODE/hadoop-env/hdfs_user" : "wrong_user",
      "component_configurations/NAMENODE/hadoop-env/user_group" : "wrong_group"
    }
    self.assertEquals(vc.check_users(params), False)
예제 #3
0
    def test_flatten_dict(self):
        init_dict = {"a": "a", "b": {"b": "b"}, "c": {"c": {"c": "c"}}}

        result_list = ['prefix/a/a', 'prefix/c/c/c/c', 'prefix/b/b/b']

        vc = ValidateConfigs()

        self.assertEquals(vc.flatten_dict(init_dict, prefix="prefix"),
                          result_list)
예제 #4
0
  def test_get_value(self):

    params = {
      "component_configurations/NAMENODE/hadoop-env/hdfs_user" : "root",
      "component_configurations/NAMENODE/hadoop-env/user_group" : "${hdfs_user}"
    }

    vc = ValidateConfigs()

    self.assertEquals(vc.get_value("component_configurations/NAMENODE/hadoop-env/hdfs_user", params), 'root')
    self.assertEquals(vc.get_value("component_configurations/NAMENODE/hadoop-env/user_group", params), 'root')
예제 #5
0
  def test_flatten_dict(self):
    init_dict = {
      "a" : "a",
      "b" : {
        "b": "b"
      },
      "c": {
        "c": {
          "c": "c"
        }
      }
    }

    result_list = ['prefix/a/a', 'prefix/c/c/c/c', 'prefix/b/b/b']

    vc = ValidateConfigs()

    self.assertEquals(vc.flatten_dict(init_dict, prefix="prefix"), result_list)
예제 #6
0
    def test_get_value(self):

        params = {
            "component_configurations/NAMENODE/hadoop-env/hdfs_user":
            "******",
            "component_configurations/NAMENODE/hadoop-env/user_group":
            "${hdfs_user}"
        }

        vc = ValidateConfigs()

        self.assertEquals(
            vc.get_value(
                "component_configurations/NAMENODE/hadoop-env/hdfs_user",
                params), 'root')
        self.assertEquals(
            vc.get_value(
                "component_configurations/NAMENODE/hadoop-env/user_group",
                params), 'root')
예제 #7
0
  def test_check_directories(self):
    temp_dir = tempfile.mkdtemp()
    vc = ValidateConfigs()

    params = {
      "component_configurations/NAMENODE/hadoop-env/hdfs_log_dir_prefix" : "/"
    }

    self.assertFalse(vc.check_directories(params))

    params = {
      "component_configurations/NAMENODE/hadoop-env/hdfs_log_dir_prefix" : temp_dir
    }

    self.assertTrue(vc.check_directories(params))

    params = {
      "component_configurations/NAMENODE/hadoop-env/hdfs_log_dir_prefix" : temp_dir + '/some_new_dir'
    }

    self.assertTrue(vc.check_directories(params))
예제 #8
0
    def test_check_user_in_group(self):
        vc = ValidateConfigs()

        self.assertTrue(vc.check_user_in_group('root', 'root'))
        self.assertFalse(vc.check_user_in_group('root', 'wrong_group'))
        self.assertFalse(vc.check_user_in_group('wrong_user', 'root'))
        self.assertFalse(vc.check_user_in_group('wrong_user', 'wrong_group'))
예제 #9
0
    def test_check_users(self, geteuid_mock):
        # if excecuting not by root
        geteuid_mock.return_value = 1

        vc = ValidateConfigs()
        params = {
            "component_configurations/NAMENODE/hadoop-env/hdfs_user": "******",
            "component_configurations/NAMENODE/hadoop-env/user_group": "root"
        }
        self.assertEquals(vc.check_users(params), True)
        params = {
            "component_configurations/NAMENODE/hadoop-env/hdfs_user":
            "******",
            "component_configurations/NAMENODE/hadoop-env/user_group":
            "wrong_group"
        }
        self.assertEquals(vc.check_users(params), False)
        params = {
            "component_configurations/NAMENODE/hadoop-env/hdfs_user":
            "******",
            "component_configurations/NAMENODE/hadoop-env/user_group": "root"
        }
        self.assertEquals(vc.check_users(params), False)
        params = {
            "component_configurations/NAMENODE/hadoop-env/hdfs_user":
            "******",
            "component_configurations/NAMENODE/hadoop-env/user_group":
            "wrong_group"
        }
        self.assertEquals(vc.check_users(params), False)
예제 #10
0
    def test_check_directories(self):
        temp_dir = tempfile.mkdtemp()
        vc = ValidateConfigs()

        params = {
            "component_configurations/NAMENODE/hadoop-env/hdfs_log_dir_prefix":
            "/"
        }

        self.assertFalse(vc.check_directories(params))

        params = {
            "component_configurations/NAMENODE/hadoop-env/hdfs_log_dir_prefix":
            temp_dir
        }

        self.assertTrue(vc.check_directories(params))

        params = {
            "component_configurations/NAMENODE/hadoop-env/hdfs_log_dir_prefix":
            temp_dir + '/some_new_dir'
        }

        self.assertTrue(vc.check_directories(params))