예제 #1
0
    def test_superadmin_termination(self):
        """Test the termination of one running resources from superadmin user
        """

        # Create a random test user id that are used for login as admin
        user_id = "horst" + str(randint(0, 10000000))
        user_group = self.user_group
        password = "******"

        # We need to create an HTML basic authorization header
        auth_header = Headers()
        auth = bytes('%s:%s' % (user_id, password), "utf-8")
        auth_header.add('Authorization',
                        'Basic ' + base64.b64encode(auth).decode())

        # Make sure the user database is empty
        user = ActiniaUser(user_id)
        if user.exists():
            user.delete()
        # Create a user in the database and reduce its credentials
        self.user = ActiniaUser.create_user(
            user_id,
            user_group,
            password,
            user_role="superadmin",
            accessible_datasets={
                "nc_spm_08": ["PERMANENT", "user1", "landsat", "test_mapset"],
                "ECAD": ["PERMANENT"]
            },
            process_num_limit=3,
            process_time_limit=100)

        # Start three processes that will be terminated
        rv = self.server.post(URL_PREFIX + '/custom_process/sleep',
                              headers=auth_header,
                              data=json_dumps(["20"]),
                              content_type="application/json")

        # Test guest termination error
        rv = self.server.delete(URL_PREFIX + '/resources/%s' % user_id,
                                headers=self.guest_auth_header)
        print(rv.data.decode())
        self.assertEqual(rv.status_code, 401,
                         "HTML status code is wrong %i" % rv.status_code)
        #self.assertEqual(rv.mimetype, "application/json", "Wrong mimetype %s" % rv.mimetype)

        # Test user termination error
        rv = self.server.delete(URL_PREFIX + '/resources/%s' % user_id,
                                headers=self.user_auth_header)
        print(rv.data.decode())
        self.assertEqual(rv.status_code, 401,
                         "HTML status code is wrong %i" % rv.status_code)
        #self.assertEqual(rv.mimetype, "application/json", "Wrong mimetype %s" % rv.mimetype)

        # Test admin termination error
        rv = self.server.delete(URL_PREFIX + '/resources/%s' % user_id,
                                headers=self.admin_auth_header)
        print(rv.data.decode())
        self.assertEqual(rv.status_code, 401,
                         "HTML status code is wrong %i" % rv.status_code)
        #self.assertEqual(rv.mimetype, "application/json", "Wrong mimetype %s" % rv.mimetype)

        # Test superadmin termination success
        rv = self.server.delete(URL_PREFIX + '/resources/%s' % user_id,
                                headers=self.root_auth_header)
        print(rv.data.decode())
        self.assertEqual(rv.status_code, 200,
                         "HTML status code is wrong %i" % rv.status_code)
        self.assertEqual(rv.mimetype, "application/json",
                         "Wrong mimetype %s" % rv.mimetype)

        # Wait for termination
        time.sleep(5)

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=auth_header)
        print(rv.data.decode())
        self.assertEqual(rv.status_code, 200,
                         "HTML status code is wrong %i" % rv.status_code)
        self.assertEqual(rv.mimetype, "application/json",
                         "Wrong mimetype %s" % rv.mimetype)

        resource_list = json_loads(rv.data)["resource_list"]
        self.assertTrue(len(resource_list) == 1)

        # Count return stats
        terminated = 0
        for resource in resource_list:
            terminated += int(resource["status"] == "terminated")
            print(resource["status"])

        self.assertTrue(terminated == 1)
예제 #2
0
    def test_user_status_requests_1(self):
        """Resource list with 3 finished resources
        """

        # Create a random test user id that are used for login as admin
        user_id = "heinz" + str(randint(0, 10000000))
        user_group = self.user_group
        password = "******"

        # We need to create an HTML basic authorization header
        auth_header = Headers()
        auth = bytes('%s:%s' % (user_id, password), "utf-8")
        auth_header.add('Authorization',
                        'Basic ' + base64.b64encode(auth).decode())

        # Make sure the user database is empty
        user = ActiniaUser(user_id)
        if user.exists():
            user.delete()
        # Create a user in the database and reduce its credentials
        self.user = ActiniaUser.create_user(
            user_id,
            user_group,
            password,
            user_role="user",
            accessible_datasets={
                "nc_spm_08": ["PERMANENT", "user1", "landsat", "test_mapset"],
                "ECAD": ["PERMANENT"]
            },
            process_num_limit=3,
            process_time_limit=2)

        # Create three successfully run resources
        rv = self.server.post(URL_PREFIX + '/custom_process/uname',
                              headers=auth_header,
                              data=json_dumps(["-a"]),
                              content_type="application/json")
        self.waitAsyncStatusAssertHTTP(rv, headers=self.admin_auth_header)

        rv = self.server.post(URL_PREFIX + '/custom_process/uname',
                              headers=auth_header,
                              data=json_dumps(["-a"]),
                              content_type="application/json")
        self.waitAsyncStatusAssertHTTP(rv, headers=self.admin_auth_header)

        rv = self.server.post(URL_PREFIX + '/custom_process/uname',
                              headers=auth_header,
                              data=json_dumps(["-a"]),
                              content_type="application/json")
        self.waitAsyncStatusAssertHTTP(rv, headers=self.admin_auth_header)

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=auth_header)
        # print(rv.data.decode())
        self.assertEqual(rv.status_code, 200,
                         "HTML status code is wrong %i" % rv.status_code)
        self.assertEqual(rv.mimetype, "application/json",
                         "Wrong mimetype %s" % rv.mimetype)

        resource_list = json_loads(rv.data)["resource_list"]

        pprint(resource_list)

        self.assertTrue(len(resource_list) == 3)

        # Count return stats
        finished = 0
        for resource in resource_list:
            finished += int(resource["status"] == "finished")
            # print(resource["status"])

        self.assertTrue(finished == 3)

        # Check the different resource list parameters
        rv = self.server.get(URL_PREFIX + '/resources/%s?num=1' % user_id,
                             headers=auth_header)
        self.assertTrue(len(json_loads(rv.data)["resource_list"]) == 1)

        rv = self.server.get(URL_PREFIX + '/resources/%s?num=2' % user_id,
                             headers=auth_header)
        self.assertTrue(len(json_loads(rv.data)["resource_list"]) == 2)

        rv = self.server.get(URL_PREFIX +
                             '/resources/%s?num=2&type=finished' % user_id,
                             headers=auth_header)
        self.assertTrue(len(json_loads(rv.data)["resource_list"]) == 2)

        rv = self.server.get(URL_PREFIX +
                             '/resources/%s?num=2&type=all' % user_id,
                             headers=auth_header)
        self.assertTrue(len(json_loads(rv.data)["resource_list"]) == 2)

        rv = self.server.get(URL_PREFIX + '/resources/%s?type=all' % user_id,
                             headers=auth_header)
        self.assertTrue(len(json_loads(rv.data)["resource_list"]) == 3)

        rv = self.server.get(URL_PREFIX +
                             '/resources/%s?type=finished' % user_id,
                             headers=auth_header)
        self.assertTrue(len(json_loads(rv.data)["resource_list"]) == 3)

        rv = self.server.get(URL_PREFIX +
                             '/resources/%s?type=terminated' % user_id,
                             headers=auth_header)
        self.assertTrue(len(json_loads(rv.data)["resource_list"]) == 0)

        rv = self.server.get(URL_PREFIX +
                             '/resources/%s?type=unknown' % user_id,
                             headers=auth_header)
        self.assertTrue(len(json_loads(rv.data)["resource_list"]) == 0)

        # Check permission access using the default users

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=self.guest_auth_header)
        # print(rv.data.decode())
        self.assertEqual(rv.status_code, 401,
                         "HTML status code is wrong %i" % rv.status_code)
        #self.assertEqual(rv.mimetype, "application/json", "Wrong mimetype %s" % rv.mimetype)

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=self.user_auth_header)
        # print(rv.data.decode())
        self.assertEqual(rv.status_code, 401,
                         "HTML status code is wrong %i" % rv.status_code)
        #self.assertEqual(rv.mimetype, "application/json", "Wrong mimetype %s" % rv.mimetype)

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=self.admin_auth_header)
        # print(rv.data.decode())
        self.assertEqual(rv.status_code, 200,
                         "HTML status code is wrong %i" % rv.status_code)
        #self.assertEqual(rv.mimetype, "application/json", "Wrong mimetype %s" % rv.mimetype)

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=self.root_auth_header)
        # print(rv.data.decode())
        self.assertEqual(rv.status_code, 200,
                         "HTML status code is wrong %i" % rv.status_code)
예제 #3
0
    def test_create_delete_user(self):

        # Make sure the user database is empty
        user = ActiniaUser(self.user_id)
        if user.exists():
            print("Delete existing user")
            user.delete()

        # Create a new user
        user = ActiniaUser.create_user(
            self.user_id,
            self.user_group,
            self.password,
            user_role="admin",
            accessible_datasets={"nc_spm_08": ["PERMANENT", "user1"]},
            accessible_modules=["g.region", "g.mapset", "r.slope.aspect"],
            cell_limit=1000,
            process_num_limit=3,
            process_time_limit=30)

        print(user)

        self.assertEqual(user.get_role(), "admin")
        self.assertEquals(user.get_id(), self.user_id)
        self.assertEquals(user.get_group(), self.user_group)
        self.assertEquals(user.get_cell_limit(), 1000)
        self.assertEquals(user.get_process_num_limit(), 3)
        self.assertEquals(user.get_process_time_limit(), 30)

        datasets = user.get_accessible_datasets()
        modules = user.get_accessible_modules()

        self.assertTrue("nc_spm_08" in datasets)
        self.assertTrue("PERMANENT" in datasets["nc_spm_08"])
        self.assertTrue("g.region" in modules)

        token = user.generate_auth_token()
        user_2 = ActiniaUser.verify_auth_token(token)

        print(user_2)

        self.assertTrue(user_2.exists())
        self.assertEqual(user_2.get_role(), "admin")
        self.assertEquals(user_2.get_id(), self.user_id)
        self.assertEquals(user.get_group(), self.user_group)
        self.assertEquals(user_2.get_cell_limit(), 1000)
        self.assertEquals(user_2.get_process_num_limit(), 3)
        self.assertEquals(user_2.get_process_time_limit(), 30)

        datasets = user_2.get_accessible_datasets()
        modules = user_2.get_accessible_modules()

        self.assertTrue("nc_spm_08" in datasets)
        self.assertTrue("PERMANENT" in datasets["nc_spm_08"])
        self.assertTrue("g.region" in modules)

        api_key = user.generate_api_key()
        user_3 = ActiniaUser.verify_api_key(api_key)

        print(user_3)

        self.assertTrue(user_3.exists())
        self.assertEqual(user_3.get_role(), "admin")
        self.assertEquals(user_3.get_id(), self.user_id)
        self.assertEquals(user.get_group(), self.user_group)
        self.assertEquals(user_3.get_cell_limit(), 1000)
        self.assertEquals(user_3.get_process_num_limit(), 3)
        self.assertEquals(user_3.get_process_time_limit(), 30)

        datasets = user_3.get_accessible_datasets()
        modules = user_3.get_accessible_modules()

        self.assertTrue("nc_spm_08" in datasets)
        self.assertTrue("PERMANENT" in datasets["nc_spm_08"])
        self.assertTrue("g.region" in modules)

        self.assertTrue(user.delete())
        self.assertFalse(user_2.delete())
        self.assertFalse(user_3.delete())
예제 #4
0
    def test_user_status_requests_3(self):
        """Empty resource list test
        """

        # Create a random test user id that are used for login as admin
        user_id = "heinz" + str(randint(0, 10000000))
        user_group = "test"
        password = "******"

        # We need to create an HTML basic authorization header
        auth_header = Headers()
        auth = bytes('%s:%s' % (user_id, password), "utf-8")
        auth_header.add('Authorization',
                        'Basic ' + base64.b64encode(auth).decode())

        # Make sure the user database is empty
        user = ActiniaUser(user_id)
        if user.exists():
            user.delete()
        # Create a user in the database and reduce its credentials
        self.user = ActiniaUser.create_user(user_id, user_group, password)

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=auth_header)
        print(rv.data.decode())
        self.assertEqual(rv.status_code, 200,
                         "HTML status code is wrong %i" % rv.status_code)
        self.assertEqual(rv.mimetype, "application/json",
                         "Wrong mimetype %s" % rv.mimetype)

        resource_list = json_loads(rv.data)["resource_list"]
        self.assertTrue(len(resource_list) == 0)

        # Check permission access using the default users

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=self.guest_auth_header)
        print(rv.data.decode())
        self.assertEqual(rv.status_code, 401,
                         "HTML status code is wrong %i" % rv.status_code)
        #self.assertEqual(rv.mimetype, "application/json", "Wrong mimetype %s" % rv.mimetype)

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=self.user_auth_header)
        print(rv.data.decode())
        self.assertEqual(rv.status_code, 401,
                         "HTML status code is wrong %i" % rv.status_code)
        #self.assertEqual(rv.mimetype, "application/json", "Wrong mimetype %s" % rv.mimetype)

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=self.admin_auth_header)
        print(rv.data.decode())
        self.assertEqual(rv.status_code, 401,
                         "HTML status code is wrong %i" % rv.status_code)
        #self.assertEqual(rv.mimetype, "application/json", "Wrong mimetype %s" % rv.mimetype)

        rv = self.server.get(URL_PREFIX + '/resources/%s' % user_id,
                             headers=self.root_auth_header)
        print(rv.data.decode())
        self.assertEqual(rv.status_code, 200,
                         "HTML status code is wrong %i" % rv.status_code)
        self.assertEqual(rv.mimetype, "application/json",
                         "Wrong mimetype %s" % rv.mimetype)
예제 #5
0
    def test_create_update_user(self):
        """Test the creation and update of a user in the redis database
        """

        user = ActiniaUser(self.user_id)
        if user.exists():
            print("Delete existing user")
            user.delete()

        # Create a new user
        user = ActiniaUser.create_user(
            self.user_id,
            self.user_group,
            self.password,
            user_role="admin",
            accessible_datasets={"nc_spm_08": ["PERMANENT", "user1"]},
            accessible_modules=["g.region", "g.mapset", "r.slope.aspect"],
            cell_limit=1000,
            process_num_limit=3,
            process_time_limit=30)

        print(user)

        self.assertEqual(user.get_role(), "admin")
        self.assertEquals(user.get_id(), self.user_id)
        self.assertEquals(user.get_group(), self.user_group)
        self.assertEquals(user.get_cell_limit(), 1000)
        self.assertEquals(user.get_process_num_limit(), 3)
        self.assertEquals(user.get_process_time_limit(), 30)

        datasets = user.get_accessible_datasets()

        self.assertTrue("nc_spm_08" in datasets)
        self.assertTrue("PERMANENT" in datasets["nc_spm_08"])

        user = ActiniaUser(user_id=self.user_id)
        user.read_from_db()
        user.set_role("user")
        user.set_cell_limit(1000000)
        user.set_process_num_limit(10)
        user.set_process_time_limit(50)
        user.update()

        print(user)

        self.assertEqual(user.get_role(), "user")
        self.assertEquals(user.get_cell_limit(), 1000000)
        self.assertEquals(user.get_process_num_limit(), 10)
        self.assertEquals(user.get_process_time_limit(), 50)

        user = ActiniaUser(user_id=self.user_id)
        user.read_from_db()
        user.add_accessible_dataset("utm32n", ["PERMANENT"])
        user.add_accessible_modules([
            "i.vi",
        ])
        user.update()

        print(user)

        datasets = user.get_accessible_datasets()
        modules = user.get_accessible_modules()

        self.assertTrue("nc_spm_08" in datasets)
        self.assertTrue("PERMANENT" in datasets["nc_spm_08"])
        self.assertTrue("g.region" in modules)
        self.assertTrue("utm32n" in datasets)
        self.assertTrue("PERMANENT" in datasets["utm32n"])
        self.assertTrue("i.vi" in modules)

        user = ActiniaUser(user_id=self.user_id)
        user.read_from_db()
        user.remove_location("utm32n")
        user.remove_mapsets_from_location("nc_spm_08", [
            "user1",
        ])
        user.remove_accessible_modules([
            "i.vi",
        ])
        user.update()

        print(user)

        datasets = user.get_accessible_datasets()
        modules = user.get_accessible_modules()

        self.assertTrue("nc_spm_08" in datasets)
        self.assertTrue("PERMANENT" in datasets["nc_spm_08"])
        self.assertFalse("user1" in datasets["nc_spm_08"])
        self.assertTrue("g.region" in modules)
        self.assertFalse("utm32n" in datasets)
        self.assertFalse("i.vi" in modules)