mirror of
https://github.com/zoriya/octokit.net.git
synced 2026-06-03 11:05:56 +00:00
Implement Issue Timeline preview API (#1435)
* Implement Issue Timeline preview API * Add DebuggerDisplay to response models * Rename method * Add Observable Issue Timeline client * Add that missing property thing * Add teh comments * Added unit tests * Fix method names * Add missing event type enum and API preview accept header * Add integration tests for async client * Pass in API preview header * Add observable integration tests * Unbreak the broken tests... * Remove unnecessary usings * Add missing events * Fix API URLs * Add overloads for using repository Id instead of owner/repo and paging * Add tests for repository id overloads * Add paging tests * I'm clearly a bit rusty about this test thing here... * Missed a check for null argument * Added missing XMLDocs
This commit is contained in:
committed by
Ryan Gribble
parent
40a60d75b1
commit
23d9310133
@@ -0,0 +1,144 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Reactive.Linq;
|
||||
using System.Threading.Tasks;
|
||||
using NSubstitute;
|
||||
using Octokit.Internal;
|
||||
using Octokit.Reactive;
|
||||
using Xunit;
|
||||
|
||||
namespace Octokit.Tests.Reactive
|
||||
{
|
||||
public class ObservableIssueTimelineClientTests
|
||||
{
|
||||
public class TheCtor
|
||||
{
|
||||
[Fact]
|
||||
public void EnsuresNonNullArguments()
|
||||
{
|
||||
Assert.Throws<ArgumentNullException>(
|
||||
() => new ObservableIssueTimelineClient(null));
|
||||
}
|
||||
}
|
||||
|
||||
public class TheGetAllForIssueMethod
|
||||
{
|
||||
[Fact]
|
||||
public async Task RequestsCorrectUrl()
|
||||
{
|
||||
var result = new List<TimelineEventInfo> { new TimelineEventInfo() };
|
||||
|
||||
var connection = Substitute.For<IConnection>();
|
||||
var gitHubClient = new GitHubClient(connection);
|
||||
var client = new ObservableIssueTimelineClient(gitHubClient);
|
||||
|
||||
IApiResponse<List<TimelineEventInfo>> response = new ApiResponse<List<TimelineEventInfo>>(
|
||||
new Response
|
||||
{
|
||||
ApiInfo = new ApiInfo(new Dictionary<string, Uri>(), new List<string>(), new List<string>(), "etag", new RateLimit()),
|
||||
}, result);
|
||||
gitHubClient.Connection.Get<List<TimelineEventInfo>>(Args.Uri, Args.EmptyDictionary, "application/vnd.github.mockingbird-preview")
|
||||
.Returns(Task.FromResult(response));
|
||||
|
||||
var timelineEvents = await client.GetAllForIssue("fake", "repo", 42).ToList();
|
||||
|
||||
connection.Received().Get<List<TimelineEventInfo>>(
|
||||
Arg.Is<Uri>(u => u.ToString() == "repos/fake/repo/issues/42/timeline"),
|
||||
Arg.Any<Dictionary<string, string>>(),
|
||||
"application/vnd.github.mockingbird-preview");
|
||||
Assert.Equal(1, timelineEvents.Count);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task RequestsCorrectUrlWithApiOptions()
|
||||
{
|
||||
var result = new List<TimelineEventInfo> { new TimelineEventInfo() };
|
||||
|
||||
var connection = Substitute.For<IConnection>();
|
||||
var gitHubClient = new GitHubClient(connection);
|
||||
var client = new ObservableIssueTimelineClient(gitHubClient);
|
||||
|
||||
IApiResponse<List<TimelineEventInfo>> response = new ApiResponse<List<TimelineEventInfo>>(
|
||||
new Response
|
||||
{
|
||||
ApiInfo = new ApiInfo(new Dictionary<string, Uri>(), new List<string>(), new List<string>(), "etag", new RateLimit()),
|
||||
}, result);
|
||||
gitHubClient.Connection.Get<List<TimelineEventInfo>>(Args.Uri, Arg.Is<Dictionary<string, string>>(d => d.Count == 1), "application/vnd.github.mockingbird-preview")
|
||||
.Returns(Task.FromResult(response));
|
||||
|
||||
var timelineEvents = await client.GetAllForIssue("fake", "repo", 42, new ApiOptions {PageSize = 30}).ToList();
|
||||
|
||||
connection.Received().Get<List<TimelineEventInfo>>(
|
||||
Arg.Is<Uri>(u => u.ToString() == "repos/fake/repo/issues/42/timeline"),
|
||||
Arg.Is<Dictionary<string, string>>(d => d.Count == 1 && d["per_page"] == "30"),
|
||||
"application/vnd.github.mockingbird-preview");
|
||||
Assert.Equal(1, timelineEvents.Count);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task RequestCorrectUrlWithRepositoryId()
|
||||
{
|
||||
var result = new List<TimelineEventInfo> { new TimelineEventInfo() };
|
||||
var connection = Substitute.For<IConnection>();
|
||||
var githubClient = new GitHubClient(connection);
|
||||
var client = new ObservableIssueTimelineClient(githubClient);
|
||||
|
||||
IApiResponse<List<TimelineEventInfo>> response = new ApiResponse<List<TimelineEventInfo>>(
|
||||
new Response
|
||||
{
|
||||
ApiInfo = new ApiInfo(new Dictionary<string, Uri>(), new List<string>(), new List<string>(), "etag", new RateLimit()),
|
||||
}, result);
|
||||
githubClient.Connection.Get<List<TimelineEventInfo>>(Args.Uri, Args.EmptyDictionary, "application/vnd.github.mockingbird-preview")
|
||||
.Returns(Task.FromResult(response));
|
||||
|
||||
var timelineEvents = await client.GetAllForIssue(1, 42).ToList();
|
||||
|
||||
connection.Received().Get<List<TimelineEventInfo>>(
|
||||
Arg.Is<Uri>(u => u.ToString() == "repositories/1/issues/42/timeline"),
|
||||
Arg.Any<Dictionary<string, string>>(),
|
||||
"application/vnd.github.mockingbird-preview");
|
||||
Assert.Equal(1, timelineEvents.Count);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task RequestCorrectUrlWithRepositoryIdAndApiOptions()
|
||||
{
|
||||
var result = new List<TimelineEventInfo> { new TimelineEventInfo() };
|
||||
var connection = Substitute.For<IConnection>();
|
||||
var githubClient = new GitHubClient(connection);
|
||||
var client = new ObservableIssueTimelineClient(githubClient);
|
||||
|
||||
IApiResponse<List<TimelineEventInfo>> response = new ApiResponse<List<TimelineEventInfo>>(
|
||||
new Response
|
||||
{
|
||||
ApiInfo = new ApiInfo(new Dictionary<string, Uri>(), new List<string>(), new List<string>(), "etag", new RateLimit()),
|
||||
}, result);
|
||||
githubClient.Connection.Get<List<TimelineEventInfo>>(Args.Uri, Arg.Is<Dictionary<string, string>>(d => d.Count == 1), "application/vnd.github.mockingbird-preview")
|
||||
.Returns(Task.FromResult(response));
|
||||
|
||||
var timelineEvents = await client.GetAllForIssue(1, 42, new ApiOptions {PageSize = 30}).ToList();
|
||||
|
||||
connection.Received().Get<List<TimelineEventInfo>>(
|
||||
Arg.Is<Uri>(u => u.ToString() == "repositories/1/issues/42/timeline"),
|
||||
Arg.Is<Dictionary<string, string>>(d => d.Count == 1 && d["per_page"] == "30"),
|
||||
"application/vnd.github.mockingbird-preview");
|
||||
Assert.Equal(1, timelineEvents.Count);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task EnsuresNonNullArguments()
|
||||
{
|
||||
var client = new ObservableIssueTimelineClient(Substitute.For<IGitHubClient>());
|
||||
|
||||
Assert.Throws<ArgumentNullException>(() => client.GetAllForIssue(null, "repo", 42));
|
||||
Assert.Throws<ArgumentNullException>(() => client.GetAllForIssue("owner", null, 42));
|
||||
Assert.Throws<ArgumentNullException>(() => client.GetAllForIssue("owner", "repo", 42, null));
|
||||
Assert.Throws<ArgumentNullException>(() => client.GetAllForIssue(1, 42, null));
|
||||
|
||||
Assert.Throws<ArgumentException>(() => client.GetAllForIssue("", "repo", 42));
|
||||
Assert.Throws<ArgumentException>(() => client.GetAllForIssue("owner", "", 42));
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user