def test_destroy_provider_exception(self):
     """Test to destroy a provider with a connection error."""
     client = ProviderBuilder(auth_header=Config.SOURCES_FAKE_HEADER)
     with patch.object(ProviderAccessor,
                       "cost_usage_source_ready",
                       returns=True):
         provider = client.create_provider_from_source(self.mock_source)
         self.assertEqual(provider.name, self.name)
         self.assertEqual(str(provider.uuid), self.source_uuid)
         logging.disable(logging.NOTSET)
         with self.assertLogs(logger="api.provider.provider_builder",
                              level=logging.INFO):
             client.destroy_provider(faker.uuid4())
    def test_destroy_provider(self):
        """Test to destroy a provider."""
        client = ProviderBuilder(auth_header=Config.SOURCES_FAKE_HEADER)

        with patch.object(ProviderAccessor,
                          "cost_usage_source_ready",
                          returns=True):
            provider = client.create_provider_from_source(self.mock_source)
            self.assertEqual(provider.name, self.name)
            self.assertEqual(str(provider.uuid), self.source_uuid)
            client.destroy_provider(self.source_uuid)
            with self.assertRaises(Provider.DoesNotExist):
                Provider.objects.get(uuid=self.source_uuid)
Beispiel #3
0
 def destroy(self, request, *args, **kwargs):
     """Delete a source."""
     source = self.get_object()
     manager = ProviderBuilder(request.user.identity_header.get("encoded"))
     for _ in range(5):
         try:
             manager.destroy_provider(source.koku_uuid)
         except IntegrityError as error:
             LOG.warning(f"Retrying Source delete due to error: {error}")
         except Exception as error:  # catch everything else. return immediately
             msg = f"Source removal resulted in UNKNOWN error: {type(error).__name__}: {error}"
             LOG.error(msg)
             return Response(msg, status=500)
         else:
             return super().destroy(request, *args, **kwargs)
     LOG.error("Failed to remove Source")
     return Response("Failed to remove Source", status=500)
Beispiel #4
0
class SourcesProviderCoordinator:
    """Coordinator to control source and provider operations."""
    def __init__(self, source_id, auth_header):
        """Initialize the client."""
        header = {"x-rh-identity": auth_header, "sources-client": "True"}
        self._source_id = source_id
        self._identity_header = header
        self._provider_builder = ProviderBuilder(self._identity_header)

    def create_account(self,
                       name,
                       provider_type,
                       authentication,
                       billing_source,
                       source_uuid=None):
        """Call to create provider."""
        try:
            provider = self._provider_builder.create_provider(
                name, provider_type, authentication, billing_source,
                source_uuid)
            add_provider_koku_uuid(self._source_id, provider.uuid)
        except ProviderBuilderError as provider_err:
            raise SourcesProviderCoordinatorError(str(provider_err))
        return provider

    def update_account(self, provider_uuid, name, provider_type,
                       authentication, billing_source):
        """Call to update provider."""
        try:
            provider = self._provider_builder.update_provider(
                provider_uuid, name, provider_type, authentication,
                billing_source)
            clear_update_flag(self._source_id)
        except ProviderBuilderError as provider_err:
            raise SourcesProviderCoordinatorError(str(provider_err))
        return provider

    def destroy_account(self, provider_uuid):
        """Call to destroy provider."""
        try:
            self._provider_builder.destroy_provider(provider_uuid)
            destroy_source_event(self._source_id)
        except ProviderBuilderError as provider_err:
            LOG.error(f"Failed to remove provider. Error: {str(provider_err)}")
Beispiel #5
0
class SourcesProviderCoordinator:
    """Coordinator to control source and provider operations."""
    def __init__(self, source_id, auth_header):
        """Initialize the client."""
        header = {"x-rh-identity": auth_header, "sources-client": "True"}
        self._source_id = source_id
        self._identity_header = header
        self._provider_builder = ProviderBuilder(self._identity_header)

    def create_account(self, source):
        """Call to create provider."""
        try:
            LOG.info(
                f"Creating Provider for Source ID: {str(self._source_id)}")
            provider = self._provider_builder.create_provider_from_source(
                source)
            add_provider_koku_uuid(self._source_id, provider.uuid)
        except ProviderBuilderError as provider_err:
            raise SourcesProviderCoordinatorError(str(provider_err))
        return provider

    def update_account(self, source):
        """Call to update provider."""
        try:
            LOG.info(
                f"Updating Provider for Source ID: {str(self._source_id)}")
            provider = self._provider_builder.update_provider_from_source(
                source)
        except ProviderBuilderError as provider_err:
            raise SourcesProviderCoordinatorError(str(provider_err))
        return provider

    def destroy_account(self, koku_uuid):
        """Call to destroy provider."""
        try:
            self._provider_builder.destroy_provider(koku_uuid)
            destroy_source_event(self._source_id)
        except ProviderBuilderError as provider_err:
            LOG.error(f"Failed to remove provider. Error: {str(provider_err)}")
Beispiel #6
0
 def destroy(self, request, *args, **kwargs):
     """Delete a source."""
     source = self.get_object()
     manager = ProviderBuilder(request.user.identity_header.get("encoded"))
     manager.destroy_provider(source.koku_uuid)
     return super().destroy(request, *args, **kwargs)