From e62f3dc49abdd61e8f5423db77a988d36601653e Mon Sep 17 00:00:00 2001 From: Cyberboss Date: Wed, 17 Oct 2018 11:02:23 -0400 Subject: [PATCH 1/8] Add DeploymentStatusesPreview accept header --- Octokit/Helpers/AcceptHeaders.cs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Octokit/Helpers/AcceptHeaders.cs b/Octokit/Helpers/AcceptHeaders.cs index 3a857cca3f..45cbbd63a9 100644 --- a/Octokit/Helpers/AcceptHeaders.cs +++ b/Octokit/Helpers/AcceptHeaders.cs @@ -71,6 +71,8 @@ public static class AcceptHeaders public const string IssueEventsApiPreview = "application/vnd.github.starfox-preview"; + public const string DeploymentStatusesPreview = "application/vnd.github.flash-preview+json"; + /// /// Combines multiple preview headers. GitHub API supports Accept header with multiple /// values separated by comma. From 77238152bd6d6416513b09a7fee850c3d586eb5b Mon Sep 17 00:00:00 2001 From: Cyberboss Date: Wed, 17 Oct 2018 11:02:58 -0400 Subject: [PATCH 2/8] Add the `in_progress` and `queued` deployment states --- Octokit/Models/Response/DeploymentStatus.cs | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/Octokit/Models/Response/DeploymentStatus.cs b/Octokit/Models/Response/DeploymentStatus.cs index a7bef3ca05..cd46e7339e 100644 --- a/Octokit/Models/Response/DeploymentStatus.cs +++ b/Octokit/Models/Response/DeploymentStatus.cs @@ -115,6 +115,12 @@ public enum DeploymentState Failure, [Parameter(Value = "inactive")] - Inactive + Inactive, + + [Parameter(Value = "in_progress")] + InProgress, + + [Parameter(Value = "queued")] + Queued } } \ No newline at end of file From a71ffc34014a2a99e59a72877ce5aa99418246a5 Mon Sep 17 00:00:00 2001 From: Cyberboss Date: Wed, 17 Oct 2018 11:04:59 -0400 Subject: [PATCH 3/8] Add DeploymentStatusesPreview to DeploymentStatusClient.Create Also fix the lack of preview headers in the repositoryId version --- Octokit/Clients/DeploymentStatusClient.cs | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/Octokit/Clients/DeploymentStatusClient.cs b/Octokit/Clients/DeploymentStatusClient.cs index c1f874eacc..5d880a10b6 100644 --- a/Octokit/Clients/DeploymentStatusClient.cs +++ b/Octokit/Clients/DeploymentStatusClient.cs @@ -108,7 +108,7 @@ public Task Create(string owner, string name, int deploymentId return ApiConnection.Post(ApiUrls.DeploymentStatuses(owner, name, deploymentId), newDeploymentStatus, - AcceptHeaders.DeploymentApiPreview); + AcceptHeaders.Concat(AcceptHeaders.DeploymentApiPreview, AcceptHeaders.DeploymentStatusesPreview)); } /// @@ -126,7 +126,8 @@ public Task Create(long repositoryId, int deploymentId, NewDep Ensure.ArgumentNotNull(newDeploymentStatus, nameof(newDeploymentStatus)); return ApiConnection.Post(ApiUrls.DeploymentStatuses(repositoryId, deploymentId), - newDeploymentStatus); + newDeploymentStatus, + AcceptHeaders.Concat(AcceptHeaders.DeploymentApiPreview, AcceptHeaders.DeploymentStatusesPreview)); } } } From 20fafc85183c1ded389c8c9093cd0d1e32037305 Mon Sep 17 00:00:00 2001 From: Cyberboss Date: Wed, 17 Oct 2018 11:08:20 -0400 Subject: [PATCH 4/8] Adds the Environment field to NewDeploymentStatus --- Octokit/Models/Request/NewDeploymentStatus.cs | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Octokit/Models/Request/NewDeploymentStatus.cs b/Octokit/Models/Request/NewDeploymentStatus.cs index 5a4da78973..7bbec67dbc 100644 --- a/Octokit/Models/Request/NewDeploymentStatus.cs +++ b/Octokit/Models/Request/NewDeploymentStatus.cs @@ -41,6 +41,11 @@ public NewDeploymentStatus(DeploymentState deploymentState) /// public string EnvironmentUrl { get; set; } + /// + /// Name for the target deployment environment. + /// + public string Environment { get; set; } + /// /// Indicates if a new inactive status should be added to all non-transient, /// non-production environment deployments with the same repository and environment From da4711cf320f471b738d8b02f4956d4b8939f7cb Mon Sep 17 00:00:00 2001 From: Cyberboss Date: Wed, 17 Oct 2018 11:11:46 -0400 Subject: [PATCH 5/8] Further cleanup in the DeploymentStatusClient --- Octokit/Clients/DeploymentStatusClient.cs | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/Octokit/Clients/DeploymentStatusClient.cs b/Octokit/Clients/DeploymentStatusClient.cs index 5d880a10b6..61735e8d2a 100644 --- a/Octokit/Clients/DeploymentStatusClient.cs +++ b/Octokit/Clients/DeploymentStatusClient.cs @@ -68,7 +68,7 @@ public Task> GetAll(string owner, string name, i return ApiConnection.GetAll(ApiUrls.DeploymentStatuses(owner, name, deploymentId), null, - AcceptHeaders.DeploymentApiPreview, + AcceptHeaders.Concat(AcceptHeaders.DeploymentApiPreview, AcceptHeaders.DeploymentStatusesPreview), options); } @@ -86,7 +86,10 @@ public Task> GetAll(long repositoryId, int deplo { Ensure.ArgumentNotNull(options, nameof(options)); - return ApiConnection.GetAll(ApiUrls.DeploymentStatuses(repositoryId, deploymentId), options); + return ApiConnection.GetAll(ApiUrls.DeploymentStatuses(repositoryId, deploymentId), + null, + AcceptHeaders.Concat(AcceptHeaders.DeploymentApiPreview, AcceptHeaders.DeploymentStatusesPreview), + options); } /// From b6ad71e198d895a3b7f6091442588ec788d1d96b Mon Sep 17 00:00:00 2001 From: Cyberboss Date: Wed, 17 Oct 2018 11:50:31 -0400 Subject: [PATCH 6/8] Update DeploymentStatusClientTests --- .../Clients/DeploymentStatusClientTests.cs | 21 ++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/Octokit.Tests/Clients/DeploymentStatusClientTests.cs b/Octokit.Tests/Clients/DeploymentStatusClientTests.cs index fc1e7e65f4..8d3d5de616 100644 --- a/Octokit.Tests/Clients/DeploymentStatusClientTests.cs +++ b/Octokit.Tests/Clients/DeploymentStatusClientTests.cs @@ -21,7 +21,7 @@ public async Task RequestsCorrectUrl() connection.Received().GetAll< DeploymentStatus>(Arg.Is(u => u.ToString() == expectedUrl), null, - "application/vnd.github.ant-man-preview+json", + "application/vnd.github.ant-man-preview+json,application/vnd.github.flash-preview+json", Args.ApiOptions); } @@ -34,7 +34,10 @@ public async Task RequestsCorrectUrlWithRepositoryId() await client.GetAll(1, 1); - connection.Received().GetAll(Arg.Is(u => u.ToString() == expectedUrl), Args.ApiOptions); + connection.Received().GetAll(Arg.Is(u => u.ToString() == expectedUrl), + null, + "application/vnd.github.ant-man-preview+json,application/vnd.github.flash-preview+json", + Args.ApiOptions); } [Fact] @@ -56,7 +59,7 @@ public async Task RequestsCorrectUrlWithApiOptions() connection.Received().GetAll( Arg.Is(u => u.ToString() == expectedUrl), null, - "application/vnd.github.ant-man-preview+json", + "application/vnd.github.ant-man-preview+json,application/vnd.github.flash-preview+json", options); } @@ -76,7 +79,10 @@ public async Task RequestsCorrectUrlWithRepositoryIdWithApiOptions() await client.GetAll(1, 1, options); - connection.Received().GetAll(Arg.Is(u => u.ToString() == expectedUrl), options); + connection.Received().GetAll(Arg.Is(u => u.ToString() == expectedUrl), + null, + "application/vnd.github.ant-man-preview+json,application/vnd.github.flash-preview+json", + options); } [Fact] @@ -132,7 +138,7 @@ public void PostsToCorrectUrl() connection.Received().Post(Arg.Is(u => u.ToString() == expectedUrl), newDeploymentStatus, - "application/vnd.github.ant-man-preview+json"); + "application/vnd.github.ant-man-preview+json,application/vnd.github.flash-preview+json"); } [Fact] @@ -145,7 +151,8 @@ public void PostsToCorrectUrlWithRepositoryId() client.Create(1, 1, newDeploymentStatus); connection.Received().Post(Arg.Is(u => u.ToString() == expectedUrl), - Arg.Any()); + Arg.Any(), + "application/vnd.github.ant-man-preview+json,application/vnd.github.flash-preview+json"); } [Fact] @@ -202,7 +209,7 @@ public void SendsPreviewAcceptHeaders() connection.Received(1).Post(Arg.Is(u => u.ToString() == expectedUrl), Arg.Any(), - Arg.Is(s => s == AcceptHeaders.DeploymentApiPreview)); + Arg.Is(s => s == AcceptHeaders.Concat(AcceptHeaders.DeploymentApiPreview, AcceptHeaders.DeploymentStatusesPreview))); } } From e5928c0799a2296ec9391cccd6a2582ccd6e03ac Mon Sep 17 00:00:00 2001 From: Brendan Forster Date: Tue, 25 Feb 2020 19:30:47 -0400 Subject: [PATCH 7/8] inline preview headers --- Octokit.Tests/Clients/DeploymentStatusClientTests.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Octokit.Tests/Clients/DeploymentStatusClientTests.cs b/Octokit.Tests/Clients/DeploymentStatusClientTests.cs index 8d3d5de616..9cf4c083ef 100644 --- a/Octokit.Tests/Clients/DeploymentStatusClientTests.cs +++ b/Octokit.Tests/Clients/DeploymentStatusClientTests.cs @@ -209,7 +209,7 @@ public void SendsPreviewAcceptHeaders() connection.Received(1).Post(Arg.Is(u => u.ToString() == expectedUrl), Arg.Any(), - Arg.Is(s => s == AcceptHeaders.Concat(AcceptHeaders.DeploymentApiPreview, AcceptHeaders.DeploymentStatusesPreview))); + Arg.Is(s => s == "application/vnd.github.ant-man-preview+json,application/vnd.github.flash-preview+json")); } } From 1619e24b4d94ff2e4cca05009bef2c19bf3719f4 Mon Sep 17 00:00:00 2001 From: Brendan Forster Date: Tue, 25 Feb 2020 19:48:30 -0400 Subject: [PATCH 8/8] add test that uses preview features --- .../Clients/DeploymentStatusClientTests.cs | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/Octokit.Tests.Integration/Clients/DeploymentStatusClientTests.cs b/Octokit.Tests.Integration/Clients/DeploymentStatusClientTests.cs index bb6ce3aaee..5d8ad0ccf5 100644 --- a/Octokit.Tests.Integration/Clients/DeploymentStatusClientTests.cs +++ b/Octokit.Tests.Integration/Clients/DeploymentStatusClientTests.cs @@ -40,7 +40,10 @@ public DeploymentStatusClientTests() var commit = github.Git.Commit.Create(_context.RepositoryOwner, _context.RepositoryName, newCommit).Result; - var newDeployment = new NewDeployment(commit.Sha) { AutoMerge = false }; + var newDeployment = new NewDeployment(commit.Sha) { + Environment = "production", + AutoMerge = false + }; _deployment = _deploymentsClient.Create(_context.RepositoryOwner, _context.RepositoryName, newDeployment).Result; } @@ -55,6 +58,17 @@ public async Task CanCreateDeploymentStatus() Assert.Equal(DeploymentState.Success, status.State); } + [IntegrationTest] + public async Task CanCreateDeploymentStatusWithNewState() + { + var newStatus = new NewDeploymentStatus(DeploymentState.InProgress); + + var status = await _deploymentsClient.Status.Create(_context.RepositoryOwner, _context.RepositoryName, _deployment.Id, newStatus); + + Assert.NotNull(status); + Assert.Equal(DeploymentState.InProgress, status.State); + } + [IntegrationTest] public async Task CanCreateDeploymentStatusWithRepositoryId() { @@ -243,4 +257,3 @@ public void Dispose() _context.Dispose(); } } -