/// <summary> /// Gets a reference for a given repository by reference name /// </summary> /// <remarks> /// http://developer.github.com/v3/git/refs/#get-a-reference /// </remarks> /// <param name="owner">The owner of the repository</param> /// <param name="name">The name of the repository</param> /// <param name="reference">The canonical name of the reference without the 'refs/' prefix. e.g. "heads/master" or "tags/release-1"</param> /// <returns></returns> public IObservable <Reference> Get(string owner, string name, string reference) { Ensure.ArgumentNotNullOrEmptyString(owner, nameof(owner)); Ensure.ArgumentNotNullOrEmptyString(name, nameof(name)); Ensure.ArgumentNotNullOrEmptyString(reference, nameof(reference)); return(_reference.Get(owner, name, reference).ToObservable()); }
public async Task CanGetAReference() { var @ref = await _fixture.Get("octokit", "octokit.net", "heads/master"); // validate the top-level properties Assert.Equal("refs/heads/master", @ref.Ref); Assert.Equal("https://api.github.com/repos/octokit/octokit.net/git/refs/heads/master", @ref.Url); // validate the git reference Assert.Equal(TaggedType.Commit, @ref.Object.Type); Assert.False(String.IsNullOrWhiteSpace(@ref.Object.Sha)); }
/// <summary> /// Creates a branch, based off the master branch. /// </summary> /// <param name="referencesClient">The <see cref="IReferencesClient" /> this method extends</param> /// <param name="owner">The owner of the repository.</param> /// <param name="name">The name of the repository.</param> /// <param name="branchName">The new branch name</param> public static async Task <Reference> CreateBranch(this IReferencesClient referencesClient, string owner, string name, string branchName) { Ensure.ArgumentNotNullOrEmptyString(owner, "owner"); Ensure.ArgumentNotNullOrEmptyString(name, "name"); Ensure.ArgumentNotNullOrEmptyString(branchName, "branchName"); if (branchName.StartsWith("refs/heads")) { throw new ArgumentException(String.Format(CultureInfo.InvariantCulture, "The specified branch name '{0}' appears to be a ref name and not a branch name because it starts with the string 'refs/heads'. Either specify just the branch name or use the Create method if you need to specify the full ref name", branchName), "branchName"); } var baseBranch = await referencesClient.Get(owner, name, "heads/master"); return(await referencesClient.Create(owner, name, new NewReference("refs/heads/" + branchName, baseBranch.Object.Sha))); }