Пример #1
0
        public void ReadInitialCommitTest()
        {
            // This commit has no parents
            using (var repository = new GitRepository(Path.Combine(RepositoryPath, "fork1")))
                using (var commitStream = repository.GetObjectBySha(GitObjectId.Parse("8fdf0975b4bb82f4a10e3b9f0426b1c29dec5ed6"), "commit"))
                {
                    var commit = GitCommitReader.Read(commitStream, GitObjectId.Parse("8fdf0975b4bb82f4a10e3b9f0426b1c29dec5ed6"));

                    Assert.Empty(commit.Parents);
                }
        }
Пример #2
0
        public void ReadStandardCommitTest()
        {
            // This commit has no parents
            using (var repository = new GitRepository(Path.Combine(RepositoryPath, "upstream")))
                using (var commitStream = repository.GetObjectBySha(GitObjectId.Parse("0867525d2ef57e38c20cc1bec4068d01d9c74310"), "commit"))
                {
                    var commit = GitCommitReader.Read(commitStream, GitObjectId.Parse("0867525d2ef57e38c20cc1bec4068d01d9c74310"));

                    Assert.Single(commit.Parents, GitObjectId.Parse("3ac48e11b5e3c011f0bec13adef2fbd1ba63f03a"));
                }
        }
Пример #3
0
        public void ReadCommitWithThreeParents()
        {
            using (Stream stream = TestUtilities.GetEmbeddedResource(@"ManagedGit\commit-ab39e8acac105fa0db88514f259341c9f0201b22"))
            {
                var commit = GitCommitReader.Read(stream, GitObjectId.Parse("ab39e8acac105fa0db88514f259341c9f0201b22"), readAuthor: true);

                Assert.Equal(3, commit.Parents.Count());

                Assert.Collection(
                    commit.Parents,
                    c => Assert.Equal("e0b4d66ef7915417e04e88d5fa173185bb940029", c.ToString()),
                    c => Assert.Equal("10e67ce38fbee44b3f5584d4f9df6de6c5f4cc5c", c.ToString()),
                    c => Assert.Equal("a7fef320334121af85dce4b9b731f6c9a9127cfd", c.ToString()));
            }
        }
Пример #4
0
        public void ReadMergeCommitTest()
        {
            // This commit has two parents
            using (var compressedFile = File.OpenRead(Path.Combine(RepositoryPath, "fork1/.git/objects/22/abd96d9c295c43ba96c60d2f44b52697c07586")))
                using (var commitStream = GitObjectStream.Create(compressedFile, -1))
                {
                    commitStream.ReadObjectTypeAndLength("commit");

                    var commit = GitCommitReader.Read(commitStream, GitObjectId.Parse("22abd96d9c295c43ba96c60d2f44b52697c07586"));

                    Assert.Collection(
                        commit.Parents,
                        c => Assert.Equal("ad86ad89e56fdf14a307d06af6efa7930218abba", c.ToString()),
                        c => Assert.Equal("01d33864bd1a114e619f9e7c22f448cca6123b34", c.ToString()));
                }
        }
Пример #5
0
        public void ReadTest()
        {
            using (Stream stream = TestUtilities.GetEmbeddedResource(@"ManagedGit\commit-d56dc3ed179053abef2097d1120b4507769bcf1a"))
            {
                var commit = GitCommitReader.Read(stream, GitObjectId.Parse("d56dc3ed179053abef2097d1120b4507769bcf1a"), readAuthor: true);

                Assert.Equal("d56dc3ed179053abef2097d1120b4507769bcf1a", commit.Sha.ToString());
                Assert.Equal("f914b48023c7c804a4f3be780d451f31aef74ac1", commit.Tree.ToString());

                Assert.Collection(
                    commit.Parents,
                    c => Assert.Equal("4497b0eaaa89abf0e6d70961ad5f04fd3a49cbc6", c.ToString()),
                    c => Assert.Equal("0989e8fe0cd0e0900173b26decdfb24bc0cc8232", c.ToString()));

                var author = commit.Author.Value;

                Assert.Equal("Andrew Arnott", author.Name);
                Assert.Equal(new DateTimeOffset(2020, 10, 6, 13, 40, 09, TimeSpan.FromHours(-6)), author.Date);
                Assert.Equal("*****@*****.**", author.Email);

                // Committer and commit message are not read
            }
        }