From a125cf6876e0edc5a2498df57a9df06d60b1f572 Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Thu, 02 Jun 2011 22:40:23 -0400 Subject: [PATCH] Unit testing. Start of git-notes display feature. --- tests/com/gitblit/tests/JGitUtilsTest.java | 202 ++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 171 insertions(+), 31 deletions(-) diff --git a/tests/com/gitblit/tests/JGitUtilsTest.java b/tests/com/gitblit/tests/JGitUtilsTest.java index f1dcaac..6afa38b 100644 --- a/tests/com/gitblit/tests/JGitUtilsTest.java +++ b/tests/com/gitblit/tests/JGitUtilsTest.java @@ -17,24 +17,40 @@ import java.io.File; import java.io.FileOutputStream; +import java.util.Arrays; import java.util.Date; import java.util.List; +import java.util.Map; import junit.framework.TestCase; +import org.eclipse.jgit.diff.DiffEntry.ChangeType; import org.eclipse.jgit.lib.Constants; +import org.eclipse.jgit.lib.FileMode; +import org.eclipse.jgit.lib.ObjectId; +import org.eclipse.jgit.lib.PersonIdent; import org.eclipse.jgit.lib.Repository; -import org.eclipse.jgit.revwalk.RevBlob; import org.eclipse.jgit.revwalk.RevCommit; -import org.eclipse.jgit.revwalk.RevObject; -import org.eclipse.jgit.revwalk.RevTree; import com.gitblit.GitBlit; +import com.gitblit.Keys; +import com.gitblit.models.PathModel; import com.gitblit.models.PathModel.PathChangeModel; import com.gitblit.models.RefModel; import com.gitblit.utils.JGitUtils; +import com.gitblit.utils.JGitUtils.SearchType; public class JGitUtilsTest extends TestCase { + + public void testDisplayName() throws Exception { + assertTrue(JGitUtils.getDisplayName(new PersonIdent("Napoleon Bonaparte", "")).equals( + "Napoleon Bonaparte")); + assertTrue(JGitUtils.getDisplayName(new PersonIdent("", "someone@somewhere.com")).equals( + "<someone@somewhere.com>")); + assertTrue(JGitUtils.getDisplayName( + new PersonIdent("Napoleon Bonaparte", "someone@somewhere.com")).equals( + "Napoleon Bonaparte <someone@somewhere.com>")); + } public void testFindRepositories() { List<String> list = JGitUtils.getRepositoryList(null, true, true); @@ -53,7 +69,7 @@ public void testFirstCommit() throws Exception { assertTrue(JGitUtils.getFirstChange(null, null).equals(new Date(0))); - + Repository repository = GitBlitSuite.getHelloworldRepository(); RevCommit commit = JGitUtils.getFirstCommit(repository, null); Date firstChange = JGitUtils.getFirstChange(repository, null); @@ -63,18 +79,16 @@ commit.getName().equals("f554664a346629dc2b839f7292d06bad2db4aece")); assertTrue(firstChange.equals(new Date(commit.getCommitTime() * 1000L))); } - + public void testLastCommit() throws Exception { assertTrue(JGitUtils.getLastChange(null).equals(new Date(0))); - + Repository repository = GitBlitSuite.getHelloworldRepository(); assertTrue(JGitUtils.getCommit(repository, null) != null); Date date = JGitUtils.getLastChange(repository); repository.close(); assertTrue("Could not get last repository change date!", date != null); } - - public void testCreateRepository() throws Exception { String[] repositories = { "NewTestRepository.git", "NewTestRepository" }; @@ -84,17 +98,16 @@ repositoryName, isBare); File folder; if (isBare) { - folder = new File(GitBlitSuite.REPOSITORIES, repositoryName); + folder = new File(GitBlitSuite.REPOSITORIES, repositoryName); } else { folder = new File(GitBlitSuite.REPOSITORIES, repositoryName + "/.git"); - } + } assertTrue(repository != null); assertFalse(JGitUtils.hasCommits(repository)); assertTrue(JGitUtils.getFirstCommit(repository, null) == null); assertTrue(JGitUtils.getFirstChange(repository, null).getTime() == folder .lastModified()); - assertTrue(JGitUtils.getLastChange(repository).getTime() == folder - .lastModified()); + assertTrue(JGitUtils.getLastChange(repository).getTime() == folder.lastModified()); assertTrue(JGitUtils.getCommit(repository, null) == null); repository.close(); assertTrue(GitBlit.self().deleteRepository(repositoryName)); @@ -102,6 +115,13 @@ } public void testRefs() throws Exception { + Repository repository = GitBlitSuite.getTicgitRepository(); + Map<ObjectId, List<String>> map = JGitUtils.getAllRefs(repository); + repository.close(); + assertTrue(map.size() > 0); + } + + public void testBranches() throws Exception { Repository repository = GitBlitSuite.getTicgitRepository(); for (RefModel model : JGitUtils.getLocalBranches(repository, -1)) { assertTrue(model.getName().startsWith(Constants.R_HEADS)); @@ -119,6 +139,12 @@ + model.getName().hashCode()); assertTrue(model.getShortLog().equals(model.commit.getShortMessage())); } + assertTrue(JGitUtils.getRemoteBranches(repository, 10).size() == 10); + repository.close(); + } + + public void testTags() throws Exception { + Repository repository = GitBlitSuite.getTicgitRepository(); for (RefModel model : JGitUtils.getTags(repository, -1)) { if (model.getObjectId().getName().equals("283035e4848054ff1803cb0e690270787dc92399")) { assertTrue("Not an annotated tag!", model.isAnnotatedTag()); @@ -133,23 +159,26 @@ repository.close(); } - public void testRetrieveRevObject() throws Exception { - Repository repository = GitBlitSuite.getHelloworldRepository(); - RevCommit commit = JGitUtils.getCommit(repository, Constants.HEAD); - RevTree tree = commit.getTree(); - RevObject object = JGitUtils.getRevObject(repository, tree, "java.java"); - repository.close(); - assertTrue("Object is null!", object != null); + public void testCommitNotes() throws Exception { +// Repository repository = new FileRepository(new File("c:/projects/git/jgit.git/.git")); +// RevCommit commit = JGitUtils.getCommit(repository, +// "ada903085d1b4ef8c79e3e2d91f49fee7e188f53"); +// List<GitNote> list = JGitUtils.getNotesOnCommit(repository, commit); +// repository.close(); +// assertTrue(list.size() > 0); } - public void testRetrieveStringContent() throws Exception { + public void testStringContent() throws Exception { Repository repository = GitBlitSuite.getHelloworldRepository(); + String contentA = JGitUtils.getRawContentAsString(repository, null, "java.java"); RevCommit commit = JGitUtils.getCommit(repository, Constants.HEAD); - RevTree tree = commit.getTree(); - RevBlob blob = (RevBlob) JGitUtils.getRevObject(repository, tree, "java.java"); - String content = JGitUtils.getRawContentAsString(repository, blob); + String contentB = JGitUtils.getRawContentAsString(repository, commit, "java.java"); + String contentC = JGitUtils.getRawContentAsString(repository, commit, "missing.txt"); repository.close(); - assertTrue("Content is null!", content != null && content.length() > 0); + assertTrue("ContentA is null!", contentA != null && contentA.length() > 0); + assertTrue("ContentB is null!", contentB != null && contentB.length() > 0); + assertTrue(contentA.equals(contentB)); + assertTrue(contentC == null); } public void testFilesInCommit() throws Exception { @@ -157,6 +186,15 @@ RevCommit commit = JGitUtils.getCommit(repository, "1d0c2933a4ae69c362f76797d42d6bd182d05176"); List<PathChangeModel> paths = JGitUtils.getFilesInCommit(repository, commit); + + commit = JGitUtils.getCommit(repository, "af0e9b2891fda85afc119f04a69acf7348922830"); + List<PathChangeModel> deletions = JGitUtils.getFilesInCommit(repository, commit); + + commit = JGitUtils.getFirstCommit(repository, null); + List<PathChangeModel> additions = JGitUtils.getFilesInCommit(repository, commit); + + List<PathChangeModel> latestChanges = JGitUtils.getFilesInCommit(repository, null); + repository.close(); assertTrue("No changed paths found!", paths.size() == 1); for (PathChangeModel path : paths) { @@ -165,17 +203,119 @@ assertTrue("PathChangeModel equals itself failed!", path.equals(path)); assertFalse("PathChangeModel equals string failed!", path.equals("")); } + assertTrue(deletions.get(0).changeType.equals(ChangeType.DELETE)); + assertTrue(additions.get(0).changeType.equals(ChangeType.ADD)); + assertTrue(latestChanges.size() > 0); + } + + public void testFilesInPath() throws Exception { + assertTrue(JGitUtils.getFilesInPath(null, null, null).size() == 0); + Repository repository = GitBlitSuite.getHelloworldRepository(); + List<PathModel> files = JGitUtils.getFilesInPath(repository, null, null); + repository.close(); + assertTrue(files.size() > 10); + } + + public void testDocuments() throws Exception { + Repository repository = GitBlitSuite.getTicgitRepository(); + List<String> extensions = GitBlit.getStrings(Keys.web.markdownExtensions); + List<PathModel> markdownDocs = JGitUtils.getDocuments(repository, extensions); + List<PathModel> markdownDocs2 = JGitUtils.getDocuments(repository, + Arrays.asList(new String[] { ".mkd", ".md" })); + List<PathModel> allFiles = JGitUtils.getDocuments(repository, null); + repository.close(); + assertTrue(markdownDocs.size() > 0); + assertTrue(markdownDocs2.size() > 0); + assertTrue(allFiles.size() > markdownDocs.size()); + } + + public void testFileModes() throws Exception { + assertTrue(JGitUtils.getPermissionsFromMode(FileMode.TREE.getBits()).equals("drwxr-xr-x")); + assertTrue(JGitUtils.getPermissionsFromMode(FileMode.REGULAR_FILE.getBits()).equals( + "-rw-r--r--")); + assertTrue(JGitUtils.getPermissionsFromMode(FileMode.EXECUTABLE_FILE.getBits()).equals( + "-rwxr-xr-x")); + assertTrue(JGitUtils.getPermissionsFromMode(FileMode.SYMLINK.getBits()).equals("symlink")); + assertTrue(JGitUtils.getPermissionsFromMode(FileMode.GITLINK.getBits()).equals("gitlink")); + assertTrue(JGitUtils.getPermissionsFromMode(FileMode.MISSING.getBits()).equals("missing")); + } + + public void testRevlog() throws Exception { + List<RevCommit> commits = JGitUtils.getRevLog(null, 10); + assertTrue(commits.size() == 0); + + Repository repository = GitBlitSuite.getHelloworldRepository(); + // get most recent 10 commits + commits = JGitUtils.getRevLog(repository, 10); + assertTrue(commits.size() == 10); + + // test paging and offset by getting the 10th most recent commit + RevCommit lastCommit = JGitUtils.getRevLog(repository, null, 9, 1).get(0); + assertTrue(commits.get(9).equals(lastCommit)); + + // grab the two most recent commits to java.java + commits = JGitUtils.getRevLog(repository, null, "java.java", 0, 2); + assertTrue(commits.size() == 2); + repository.close(); + } + + public void testSearchTypes() throws Exception { + assertTrue(SearchType.forName("commit").equals(SearchType.COMMIT)); + assertTrue(SearchType.forName("committer").equals(SearchType.COMMITTER)); + assertTrue(SearchType.forName("author").equals(SearchType.AUTHOR)); + assertTrue(SearchType.forName("unknown").equals(SearchType.COMMIT)); + + assertTrue(SearchType.COMMIT.toString().equals("commit")); + assertTrue(SearchType.COMMITTER.toString().equals("committer")); + assertTrue(SearchType.AUTHOR.toString().equals("author")); + } + + public void testSearchRevlogs() throws Exception { + List<RevCommit> results = JGitUtils.searchRevlogs(null, null, "java", SearchType.COMMIT, 0, + 3); + assertTrue(results.size() == 0); + + // test commit message search + Repository repository = GitBlitSuite.getHelloworldRepository(); + results = JGitUtils.searchRevlogs(repository, null, "java", SearchType.COMMIT, 0, 3); + assertTrue(results.size() == 3); + + // test author search + results = JGitUtils.searchRevlogs(repository, null, "timothy", SearchType.AUTHOR, 0, -1); + assertTrue(results.size() == 1); + + // test committer search + results = JGitUtils.searchRevlogs(repository, null, "mike", SearchType.COMMITTER, 0, 10); + assertTrue(results.size() == 10); + + // test paging and offset + RevCommit commit = JGitUtils.searchRevlogs(repository, null, "mike", SearchType.COMMITTER, + 9, 1).get(0); + assertTrue(results.get(9).equals(commit)); + + repository.close(); } public void testZip() throws Exception { + assertFalse(JGitUtils.zip(null, null, null, null)); Repository repository = GitBlitSuite.getHelloworldRepository(); - File zipFile = new File(GitBlitSuite.REPOSITORIES, "helloworld.zip"); - FileOutputStream fos = new FileOutputStream(zipFile); - boolean success = JGitUtils.zip(repository, null, Constants.HEAD, fos); - assertTrue("Failed to generate zip file!", success); - assertTrue(zipFile.length() > 0); - fos.close(); - zipFile.delete(); + File zipFileA = new File(GitBlitSuite.REPOSITORIES, "helloworld.zip"); + FileOutputStream fosA = new FileOutputStream(zipFileA); + boolean successA = JGitUtils.zip(repository, null, Constants.HEAD, fosA); + fosA.close(); + + File zipFileB = new File(GitBlitSuite.REPOSITORIES, "helloworld-java.zip"); + FileOutputStream fosB = new FileOutputStream(zipFileB); + boolean successB = JGitUtils.zip(repository, "java.java", Constants.HEAD, fosB); + fosB.close(); + repository.close(); + assertTrue("Failed to generate zip file!", successA); + assertTrue(zipFileA.length() > 0); + zipFileA.delete(); + + assertTrue("Failed to generate zip file!", successB); + assertTrue(zipFileB.length() > 0); + zipFileB.delete(); } } \ No newline at end of file -- Gitblit v1.9.1