Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions cloudfoundry_client/client.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
from cloudfoundry_client.v2.spaces import SpaceManager as SpaceManagerV2

from cloudfoundry_client.v3.apps import AppManager
from cloudfoundry_client.v3.audit_events import AuditEventManager
from cloudfoundry_client.v3.buildpacks import BuildpackManager
from cloudfoundry_client.v3.domains import DomainManager
from cloudfoundry_client.v3.droplets import DropletManager
Expand Down Expand Up @@ -119,6 +120,7 @@ class V3(object):
def __init__(self, cloud_controller_v3_url: str, credential_manager: "CloudFoundryClient"):
target_endpoint = cloud_controller_v3_url.removesuffix("/v3")
self.apps = AppManager(target_endpoint, credential_manager)
self.audit_events = AuditEventManager(target_endpoint, credential_manager)
self.buildpacks = BuildpackManager(target_endpoint, credential_manager)
self.domains = DomainManager(target_endpoint, credential_manager)
self.droplets = DropletManager(target_endpoint, credential_manager)
Expand Down
11 changes: 11 additions & 0 deletions cloudfoundry_client/v3/audit_events.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
from typing import TYPE_CHECKING

from cloudfoundry_client.v3.entities import EntityManager, Entity

if TYPE_CHECKING:
from cloudfoundry_client.client import CloudFoundryClient


class AuditEventManager(EntityManager[Entity]):
def __init__(self, target_endpoint: str, client: "CloudFoundryClient"):
super().__init__(target_endpoint, client, "/v3/audit_events")
48 changes: 48 additions & 0 deletions tests/fixtures/v3/audit_events/GET_response.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
{
"pagination": {
"total_results": 1,
"total_pages": 1,
"first": {
"href": "https://api.example.org/v3/audit_events?page=1&per_page=2"
},
"last": {
"href": "https://api.example.org/v3/audit_events?page=1&per_page=2"
},
"next": null,
"previous": null
},
"resources": [
{
"guid": "a595fe2f-01ff-4965-a50c-290258ab8582",
"created_at": "2016-06-08T16:41:23Z",
"updated_at": "2016-06-08T16:41:26Z",
"type": "audit.app.update",
"actor": {
"guid": "d144abe3-3d7b-40d4-b63f-2584798d3ee5",
"type": "user",
"name": "admin"
},
"target": {
"guid": "2e3151ba-9a63-4345-9c5b-6d8c238f4e55",
"type": "app",
"name": "my-app"
},
"data": {
"request": {
"recursive": true
}
},
"space": {
"guid": "cb97dd25-d4f7-4185-9e6f-ad6e585c207c"
},
"organization": {
"guid": "d9be96f5-ea8f-4549-923f-bec882e32e3c"
},
"links": {
"self": {
"href": "https://api.example.org//v3/audit_events/a595fe2f-01ff-4965-a50c-290258ab8582"
}
}
}
]
}
32 changes: 32 additions & 0 deletions tests/fixtures/v3/audit_events/GET_{id}_response.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
{
"guid": "a595fe2f-01ff-4965-a50c-290258ab8582",
"created_at": "2016-06-08T16:41:23Z",
"updated_at": "2016-06-08T16:41:26Z",
"type": "audit.app.update",
"actor": {
"guid": "d144abe3-3d7b-40d4-b63f-2584798d3ee5",
"type": "user",
"name": "admin"
},
"target": {
"guid": "2e3151ba-9a63-4345-9c5b-6d8c238f4e55",
"type": "app",
"name": "my-app"
},
"data": {
"request": {
"recursive": true
}
},
"space": {
"guid": "cb97dd25-d4f7-4185-9e6f-ad6e585c207c"
},
"organization": {
"guid": "d9be96f5-ea8f-4549-923f-bec882e32e3c"
},
"links": {
"self": {
"href": "https://api.example.org/v3/audit_events/a595fe2f-01ff-4965-a50c-290258ab8582"
}
}
}
39 changes: 39 additions & 0 deletions tests/v3/test_audit_events.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
import unittest
from http import HTTPStatus

from abstract_test_case import AbstractTestCase
from cloudfoundry_client.v3.entities import Entity


class TestAuditEvents(unittest.TestCase, AbstractTestCase):
@classmethod
def setUpClass(cls):
cls.mock_client_class()

def setUp(self):
self.build_client()

def test_list(self):
self.client.get.return_value = self.mock_response(
"/v3/audit_events",
HTTPStatus.OK,
None,
"v3", "audit_events", "GET_response.json"
)
all_audit_events = [audit_event for audit_event in self.client.v3.audit_events.list()]
self.client.get.assert_called_with(self.client.get.return_value.url)
self.assertEqual(1, len(all_audit_events))
self.assertEqual(all_audit_events[0]["type"], "audit.app.update")
self.assertIsInstance(all_audit_events[0], Entity)

def test_get(self):
self.client.get.return_value = self.mock_response(
"/v3/audit_events/audit-event-id",
HTTPStatus.OK,
None,
"v3", "audit_events", "GET_{id}_response.json"
)
result = self.client.v3.audit_events.get("audit-event-id")
self.client.get.assert_called_with(self.client.get.return_value.url)
self.assertIsNotNone(result)
self.assertIsInstance(result, Entity)
Loading