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)
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)
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())
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)
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)