Optimize get_tag_image query
No caller uses the image placements or locations, so no need to load them.
This commit is contained in:
		
							parent
							
								
									338f93c3c8
								
							
						
					
					
						commit
						53538f9001
					
				
					 4 changed files with 45 additions and 25 deletions
				
			
		|  | @ -147,7 +147,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_get_layer_success(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     with HTTMock(get_layer_success_mock, response_content): | ||||
|       result = self.api.get_layer_data(layer, include_vulnerabilities=True) | ||||
|       self.assertIsNotNone(result) | ||||
|  | @ -155,7 +155,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_get_layer_failure(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     with HTTMock(get_layer_failure_mock, response_content): | ||||
|       result = self.api.get_layer_data(layer, include_vulnerabilities=True) | ||||
|       self.assertIsNone(result) | ||||
|  | @ -171,7 +171,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
|       # Already registered. | ||||
|       pass | ||||
| 
 | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     self.assertFalse(layer.security_indexed) | ||||
|     self.assertEquals(-1, layer.security_indexed_engine) | ||||
| 
 | ||||
|  | @ -199,7 +199,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_analyze_layer_success(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     self.assertFalse(layer.security_indexed) | ||||
|     self.assertEquals(-1, layer.security_indexed_engine) | ||||
| 
 | ||||
|  | @ -212,7 +212,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_analyze_layer_failure(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     self.assertFalse(layer.security_indexed) | ||||
|     self.assertEquals(-1, layer.security_indexed_engine) | ||||
| 
 | ||||
|  | @ -225,7 +225,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_analyze_layer_internal_error(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     self.assertFalse(layer.security_indexed) | ||||
|     self.assertEquals(-1, layer.security_indexed_engine) | ||||
| 
 | ||||
|  | @ -238,7 +238,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_analyze_layer_bad_request(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     self.assertFalse(layer.security_indexed) | ||||
|     self.assertEquals(-1, layer.security_indexed_engine) | ||||
| 
 | ||||
|  | @ -253,7 +253,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_analyze_layer_missing_storage(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     self.assertFalse(layer.security_indexed) | ||||
|     self.assertEquals(-1, layer.security_indexed_engine) | ||||
| 
 | ||||
|  | @ -273,7 +273,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_analyze_layer_success_events(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     self.assertFalse(layer.security_indexed) | ||||
|     self.assertEquals(-1, layer.security_indexed_engine) | ||||
| 
 | ||||
|  | @ -356,7 +356,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
|     } | ||||
| 
 | ||||
|   def test_notification_new_layers_not_vulnerable(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     layer_id = '%s.%s' % (layer.docker_image_id, layer.storage.uuid) | ||||
| 
 | ||||
|     # Add a repo event for the layer. | ||||
|  | @ -394,7 +394,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_notification_delete(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     layer_id = '%s.%s' % (layer.docker_image_id, layer.storage.uuid) | ||||
| 
 | ||||
|     # Add a repo event for the layer. | ||||
|  | @ -413,7 +413,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_notification_new_layers(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     layer_id = '%s.%s' % (layer.docker_image_id, layer.storage.uuid) | ||||
| 
 | ||||
|     # Add a repo event for the layer. | ||||
|  | @ -464,7 +464,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_notification_no_new_layers(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     layer_id = '%s.%s' % (layer.docker_image_id, layer.storage.uuid) | ||||
| 
 | ||||
|     # Add a repo event for the layer. | ||||
|  | @ -484,7 +484,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
| 
 | ||||
| 
 | ||||
|   def test_notification_no_new_layers_increased_severity(self): | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|     layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|     layer_id = '%s.%s' % (layer.docker_image_id, layer.storage.uuid) | ||||
| 
 | ||||
|     # Add a repo event for the layer. | ||||
|  | @ -558,7 +558,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
|     def get_notification(url, request): | ||||
|       if url.query.find('page=nextpage') >= 0: | ||||
|         pages_called.append('GET-2') | ||||
|         layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, COMPLEX_REPO, 'prod') | ||||
|         layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, COMPLEX_REPO, 'prod', include_storage=True) | ||||
|         layer_id = '%s.%s' % (layer.docker_image_id, layer.storage.uuid) | ||||
| 
 | ||||
|         data = { | ||||
|  | @ -568,7 +568,7 @@ class TestSecurityScanner(unittest.TestCase): | |||
|         return json.dumps(data) | ||||
|       else: | ||||
|         pages_called.append('GET-1') | ||||
|         layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest') | ||||
|         layer = model.tag.get_tag_image(ADMIN_ACCESS_USER, SIMPLE_REPO, 'latest', include_storage=True) | ||||
|         layer_id = '%s.%s' % (layer.docker_image_id, layer.storage.uuid) | ||||
| 
 | ||||
|         notification_data = self._get_notification_data([layer_id], [layer_id]) | ||||
|  |  | |||
		Reference in a new issue