Files
octokit.net/Octokit.Tests.Integration/Clients/IssuesLabelsClientTests.cs
Haacked a94051d6b0 Repository name is required when creating a repo
I was trying to create a repository and I wasn't sure which parameters
were required. Following our philosophy of exposing required parameters
in the constructor, I change the `NewRepository` object to take in a
repository name and to make that property readonly.
2015-03-19 16:25:03 -07:00

85 lines
3.1 KiB
C#

using System;
using System.Threading.Tasks;
using Octokit;
using Octokit.Tests.Integration;
using Xunit;
public class IssuesLabelsClientTests : IDisposable
{
readonly IGitHubClient _gitHubClient;
readonly IIssuesLabelsClient _issuesLabelsClient;
readonly IIssuesClient _issuesClient;
readonly Repository _repository;
readonly string _repositoryOwner;
readonly string _repositoryName;
public IssuesLabelsClientTests()
{
_gitHubClient = Helper.GetAuthenticatedClient();
_issuesLabelsClient= _gitHubClient.Issue.Labels;
_issuesClient = _gitHubClient.Issue;
var repoName = Helper.MakeNameWithTimestamp("public-repo");
_repository = _gitHubClient.Repository.Create(new NewRepository(repoName)).Result;
_repositoryOwner = _repository.Owner.Login;
_repositoryName = _repository.Name;
}
[IntegrationTest]
public async Task CanListLabelsForAnIssue()
{
var newIssue = new NewIssue("A test issue") { Body = "A new unassigned issue" };
var newLabel = new NewLabel("test label", "FFFFFF");
var label = await _issuesLabelsClient.Create(_repositoryOwner, _repository.Name, newLabel);
var issue = await _issuesClient.Create(_repositoryOwner, _repositoryName, newIssue);
var issueLabelsInfo = await _issuesLabelsClient.GetForIssue(_repositoryOwner, _repositoryName, issue.Number);
Assert.Empty(issueLabelsInfo);
var issueUpdate = new IssueUpdate();
issueUpdate.AddLabel(label.Name);
var updated = await _issuesClient.Update(_repositoryOwner, _repository.Name, issue.Number, issueUpdate);
Assert.NotNull(updated);
issueLabelsInfo = await _issuesLabelsClient.GetForIssue(_repositoryOwner, _repositoryName, issue.Number);
Assert.Equal(1, issueLabelsInfo.Count);
Assert.Equal(newLabel.Color, issueLabelsInfo[0].Color);
}
[IntegrationTest]
public async Task CanListIssueLabelsForARepository()
{
var newLabel1 = new NewLabel("test label 1", "FFFFFF");
var newLabel2 = new NewLabel("test label 2", "FFFFFF");
var originalIssueLabels = await _issuesLabelsClient.GetForRepository(_repositoryOwner, _repositoryName);
await _issuesLabelsClient.Create(_repositoryOwner, _repository.Name, newLabel1);
await _issuesLabelsClient.Create(_repositoryOwner, _repository.Name, newLabel2);
var issueLabels = await _issuesLabelsClient.GetForRepository(_repositoryOwner, _repositoryName);
Assert.Equal(originalIssueLabels.Count + 2, issueLabels.Count);
}
[IntegrationTest]
public async Task CanRetrieveIssueLabelByName()
{
var newLabel = new NewLabel("test label 1b", "FFFFFF");
var label = await _issuesLabelsClient.Create(_repositoryOwner, _repository.Name, newLabel);
Assert.NotNull(label);
var issueLabelLookupByName = await _issuesLabelsClient.Get(_repositoryOwner, _repositoryName, label.Name);
Assert.Equal(label.Name, issueLabelLookupByName.Name);
Assert.Equal(label.Color, issueLabelLookupByName.Color);
}
public void Dispose()
{
Helper.DeleteRepo(_repository);
}
}