summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMax Wittig <max.wittig.ch@gmail.com>2021-04-18 16:42:58 +0200
committerGitHub <noreply@github.com>2021-04-18 16:42:58 +0200
commit916a7fe4661b3822a0a93fc75fb72d80f550582d (patch)
tree3dd32ddb5818dfcd9d67d59e6d4a971151bfd3a1
parentaf781c10db3829163f977e494e4008acf2096d64 (diff)
parentc5e6fb3bc74c509f35f973e291a7551b2b64dba5 (diff)
downloadgitlab-916a7fe4661b3822a0a93fc75fb72d80f550582d.tar.gz
Merge pull request #1364 from python-gitlab/feat/resource-state-events
feat: add support for resource state events API
-rw-r--r--docs/gl_objects/events.rst42
-rw-r--r--gitlab/tests/conftest.py10
-rw-r--r--gitlab/tests/objects/test_resource_state_events.py105
-rw-r--r--gitlab/v4/objects/events.py24
-rw-r--r--gitlab/v4/objects/issues.py2
-rw-r--r--gitlab/v4/objects/merge_requests.py2
6 files changed, 185 insertions, 0 deletions
diff --git a/docs/gl_objects/events.rst b/docs/gl_objects/events.rst
index 8071b00..5dc03c7 100644
--- a/docs/gl_objects/events.rst
+++ b/docs/gl_objects/events.rst
@@ -2,6 +2,9 @@
Events
######
+Events
+======
+
Reference
---------
@@ -39,3 +42,42 @@ List the issue events on a project::
List the user events::
events = project.events.list()
+
+Resource state events
+=====================
+
+Reference
+---------
+
+* v4 API:
+
+ + :class:`gitlab.v4.objects.ProjectIssueResourceStateEvent`
+ + :class:`gitlab.v4.objects.ProjectIssueResourceStateEventManager`
+ + :attr:`gitlab.v4.objects.ProjectIssue.resourcestateevents`
+ + :class:`gitlab.v4.objects.ProjectMergeRequestResourceStateEvent`
+ + :class:`gitlab.v4.objects.ProjectMergeRequestResourceStateEventManager`
+ + :attr:`gitlab.v4.objects.ProjectMergeRequest.resourcestateevents`
+
+* GitLab API: https://docs.gitlab.com/ee/api/resource_state_events.html
+
+Examples
+--------
+
+You can list and get specific resource state events (via their id) for project issues
+and project merge requests.
+
+List the state events of a project issue (paginated)::
+
+ state_events = issue.resourcestateevents.list()
+
+Get a specific state event of a project issue by its id::
+
+ state_event = issue.resourcestateevents.get(1)
+
+List the state events of a project merge request (paginated)::
+
+ state_events = mr.resourcestateevents.list()
+
+Get a specific state event of a project merge request by its id::
+
+ state_event = mr.resourcestateevents.get(1)
diff --git a/gitlab/tests/conftest.py b/gitlab/tests/conftest.py
index fc8312f..74fb858 100644
--- a/gitlab/tests/conftest.py
+++ b/gitlab/tests/conftest.py
@@ -53,6 +53,16 @@ def project(gl):
@pytest.fixture
+def project_issue(project):
+ return project.issues.get(1, lazy=True)
+
+
+@pytest.fixture
+def project_merge_request(project):
+ return project.mergerequests.get(1, lazy=True)
+
+
+@pytest.fixture
def release(project, tag_name):
return project.releases.get(tag_name, lazy=True)
diff --git a/gitlab/tests/objects/test_resource_state_events.py b/gitlab/tests/objects/test_resource_state_events.py
new file mode 100644
index 0000000..01c1887
--- /dev/null
+++ b/gitlab/tests/objects/test_resource_state_events.py
@@ -0,0 +1,105 @@
+"""
+GitLab API: https://docs.gitlab.com/ee/api/resource_state_events.html
+"""
+
+import pytest
+import responses
+
+from gitlab.v4.objects import (
+ ProjectIssueResourceStateEvent,
+ ProjectMergeRequestResourceStateEvent,
+)
+
+
+issue_event_content = {"id": 1, "resource_type": "Issue"}
+mr_event_content = {"id": 1, "resource_type": "MergeRequest"}
+
+
+@pytest.fixture()
+def resp_list_project_issue_state_events():
+ with responses.RequestsMock() as rsps:
+ rsps.add(
+ method=responses.GET,
+ url="http://localhost/api/v4/projects/1/issues/1/resource_state_events",
+ json=[issue_event_content],
+ content_type="application/json",
+ status=200,
+ )
+ yield rsps
+
+
+@pytest.fixture()
+def resp_get_project_issue_state_event():
+ with responses.RequestsMock() as rsps:
+ rsps.add(
+ method=responses.GET,
+ url="http://localhost/api/v4/projects/1/issues/1/resource_state_events/1",
+ json=issue_event_content,
+ content_type="application/json",
+ status=200,
+ )
+ yield rsps
+
+
+@pytest.fixture()
+def resp_list_merge_request_state_events():
+ with responses.RequestsMock() as rsps:
+ rsps.add(
+ method=responses.GET,
+ url="http://localhost/api/v4/projects/1/merge_requests/1/resource_state_events",
+ json=[mr_event_content],
+ content_type="application/json",
+ status=200,
+ )
+ yield rsps
+
+
+@pytest.fixture()
+def resp_get_merge_request_state_event():
+ with responses.RequestsMock() as rsps:
+ rsps.add(
+ method=responses.GET,
+ url="http://localhost/api/v4/projects/1/merge_requests/1/resource_state_events/1",
+ json=mr_event_content,
+ content_type="application/json",
+ status=200,
+ )
+ yield rsps
+
+
+def test_list_project_issue_state_events(
+ project_issue, resp_list_project_issue_state_events
+):
+ state_events = project_issue.resourcestateevents.list()
+ assert isinstance(state_events, list)
+
+ state_event = state_events[0]
+ assert isinstance(state_event, ProjectIssueResourceStateEvent)
+ assert state_event.resource_type == "Issue"
+
+
+def test_get_project_issue_state_event(
+ project_issue, resp_get_project_issue_state_event
+):
+ state_event = project_issue.resourcestateevents.get(1)
+ assert isinstance(state_event, ProjectIssueResourceStateEvent)
+ assert state_event.resource_type == "Issue"
+
+
+def test_list_merge_request_state_events(
+ project_merge_request, resp_list_merge_request_state_events
+):
+ state_events = project_merge_request.resourcestateevents.list()
+ assert isinstance(state_events, list)
+
+ state_event = state_events[0]
+ assert isinstance(state_event, ProjectMergeRequestResourceStateEvent)
+ assert state_event.resource_type == "MergeRequest"
+
+
+def test_get_merge_request_state_event(
+ project_merge_request, resp_get_merge_request_state_event
+):
+ state_event = project_merge_request.resourcestateevents.get(1)
+ assert isinstance(state_event, ProjectMergeRequestResourceStateEvent)
+ assert state_event.resource_type == "MergeRequest"
diff --git a/gitlab/v4/objects/events.py b/gitlab/v4/objects/events.py
index d1c3cb4..bb76b81 100644
--- a/gitlab/v4/objects/events.py
+++ b/gitlab/v4/objects/events.py
@@ -14,10 +14,14 @@ __all__ = [
"ProjectIssueResourceLabelEventManager",
"ProjectIssueResourceMilestoneEvent",
"ProjectIssueResourceMilestoneEventManager",
+ "ProjectIssueResourceStateEvent",
+ "ProjectIssueResourceStateEventManager",
"ProjectMergeRequestResourceLabelEvent",
"ProjectMergeRequestResourceLabelEventManager",
"ProjectMergeRequestResourceMilestoneEvent",
"ProjectMergeRequestResourceMilestoneEventManager",
+ "ProjectMergeRequestResourceStateEvent",
+ "ProjectMergeRequestResourceStateEventManager",
"UserEvent",
"UserEventManager",
]
@@ -74,6 +78,16 @@ class ProjectIssueResourceMilestoneEventManager(RetrieveMixin, RESTManager):
_from_parent_attrs = {"project_id": "project_id", "issue_iid": "iid"}
+class ProjectIssueResourceStateEvent(RESTObject):
+ pass
+
+
+class ProjectIssueResourceStateEventManager(RetrieveMixin, RESTManager):
+ _path = "/projects/%(project_id)s/issues/%(issue_iid)s/resource_state_events"
+ _obj_cls = ProjectIssueResourceStateEvent
+ _from_parent_attrs = {"project_id": "project_id", "issue_iid": "iid"}
+
+
class ProjectMergeRequestResourceLabelEvent(RESTObject):
pass
@@ -98,6 +112,16 @@ class ProjectMergeRequestResourceMilestoneEventManager(RetrieveMixin, RESTManage
_from_parent_attrs = {"project_id": "project_id", "mr_iid": "iid"}
+class ProjectMergeRequestResourceStateEvent(RESTObject):
+ pass
+
+
+class ProjectMergeRequestResourceStateEventManager(RetrieveMixin, RESTManager):
+ _path = "/projects/%(project_id)s/merge_requests/%(mr_iid)s/resource_state_events"
+ _obj_cls = ProjectMergeRequestResourceStateEvent
+ _from_parent_attrs = {"project_id": "project_id", "mr_iid": "iid"}
+
+
class UserEvent(Event):
pass
diff --git a/gitlab/v4/objects/issues.py b/gitlab/v4/objects/issues.py
index 4da7f91..9d38d72 100644
--- a/gitlab/v4/objects/issues.py
+++ b/gitlab/v4/objects/issues.py
@@ -20,6 +20,7 @@ from .discussions import ProjectIssueDiscussionManager
from .events import (
ProjectIssueResourceLabelEventManager,
ProjectIssueResourceMilestoneEventManager,
+ ProjectIssueResourceStateEventManager,
)
from .notes import ProjectIssueNoteManager
@@ -110,6 +111,7 @@ class ProjectIssue(
("notes", "ProjectIssueNoteManager"),
("resourcelabelevents", "ProjectIssueResourceLabelEventManager"),
("resourcemilestoneevents", "ProjectIssueResourceMilestoneEventManager"),
+ ("resourcestateevents", "ProjectIssueResourceStateEventManager"),
)
@cli.register_custom_action("ProjectIssue", ("to_project_id",))
diff --git a/gitlab/v4/objects/merge_requests.py b/gitlab/v4/objects/merge_requests.py
index f9b305a..938cb5a 100644
--- a/gitlab/v4/objects/merge_requests.py
+++ b/gitlab/v4/objects/merge_requests.py
@@ -24,6 +24,7 @@ from .notes import ProjectMergeRequestNoteManager
from .events import (
ProjectMergeRequestResourceLabelEventManager,
ProjectMergeRequestResourceMilestoneEventManager,
+ ProjectMergeRequestResourceStateEventManager,
)
@@ -121,6 +122,7 @@ class ProjectMergeRequest(
("notes", "ProjectMergeRequestNoteManager"),
("resourcelabelevents", "ProjectMergeRequestResourceLabelEventManager"),
("resourcemilestoneevents", "ProjectMergeRequestResourceMilestoneEventManager"),
+ ("resourcestateevents", "ProjectMergeRequestResourceStateEventManager"),
)
@cli.register_custom_action("ProjectMergeRequest")