From eecaad8b8e2c447429c31a01d49260ddd6b4ee03 Mon Sep 17 00:00:00 2001
From: Paul Martin <paul@paulsputer.com>
Date: Sat, 16 Apr 2016 17:35:32 -0400
Subject: [PATCH] Proof of concept #1026

---
 src/test/java/com/gitblit/tests/GitBlitTest.java |   80 +++++++++++++++++++--------------------
 1 files changed, 39 insertions(+), 41 deletions(-)

diff --git a/src/test/java/com/gitblit/tests/GitBlitTest.java b/src/test/java/com/gitblit/tests/GitBlitTest.java
index c7ec939..e873ced 100644
--- a/src/test/java/com/gitblit/tests/GitBlitTest.java
+++ b/src/test/java/com/gitblit/tests/GitBlitTest.java
@@ -15,11 +15,7 @@
  */
 package com.gitblit.tests;
 
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
-import static org.junit.Assert.assertTrue;
-
+import java.io.File;
 import java.util.List;
 
 import org.eclipse.jgit.lib.Repository;
@@ -27,63 +23,63 @@
 
 import com.gitblit.Constants.AccessRestrictionType;
 import com.gitblit.FileSettings;
-import com.gitblit.GitBlit;
 import com.gitblit.models.RepositoryModel;
 import com.gitblit.models.UserModel;
+import com.gitblit.utils.FileUtils;
 
-public class GitBlitTest {
+public class GitBlitTest extends GitblitUnitTest {
 
 	@Test
 	public void testRepositoryModel() throws Exception {
-		List<String> repositories = GitBlit.self().getRepositoryList();
+		List<String> repositories = repositories().getRepositoryList();
 		assertTrue("Repository list is empty!", repositories.size() > 0);
 		assertTrue(
 				"Missing Helloworld repository!",
 				repositories.contains(GitBlitSuite.getHelloworldRepository().getDirectory()
 						.getName()));
 		Repository r = GitBlitSuite.getHelloworldRepository();
-		RepositoryModel model = GitBlit.self().getRepositoryModel(r.getDirectory().getName());
+		RepositoryModel model = repositories().getRepositoryModel(r.getDirectory().getName());
 		assertTrue("Helloworld model is null!", model != null);
 		assertEquals(GitBlitSuite.getHelloworldRepository().getDirectory().getName(), model.name);
-		assertTrue(GitBlit.self().updateLastChangeFields(r, model) > 22000L);
+		assertTrue(repositories().updateLastChangeFields(r, model) > 22000L);
 		r.close();
 	}
 
 	@Test
 	public void testUserModel() throws Exception {
-		List<String> users = GitBlit.self().getAllUsernames();
+		List<String> users = users().getAllUsernames();
 		assertTrue("No users found!", users.size() > 0);
 		assertTrue("Admin not found", users.contains("admin"));
-		UserModel user = GitBlit.self().getUserModel("admin");
+		UserModel user = users().getUserModel("admin");
 		assertEquals("admin", user.toString());
 		assertTrue("Admin missing #admin role!", user.canAdmin);
 		user.canAdmin = false;
 		assertFalse("Admin should not have #admin!", user.canAdmin);
 		String repository = GitBlitSuite.getHelloworldRepository().getDirectory().getName();
-		RepositoryModel repositoryModel = GitBlit.self().getRepositoryModel(repository);
+		RepositoryModel repositoryModel = repositories().getRepositoryModel(repository);
 		repositoryModel.accessRestriction = AccessRestrictionType.VIEW;
 		assertFalse("Admin can still access repository!",
 				user.canView(repositoryModel));
 		user.addRepositoryPermission(repository);
 		assertTrue("Admin can't access repository!", user.canView(repositoryModel));
-		assertEquals(GitBlit.self().getRepositoryModel(user, "pretend"), null);
-		assertNotNull(GitBlit.self().getRepositoryModel(user, repository));
-		assertTrue(GitBlit.self().getRepositoryModels(user).size() > 0);
+		assertEquals(repositories().getRepositoryModel(user, "pretend"), null);
+		assertNotNull(repositories().getRepositoryModel(user, repository));
+		assertTrue(repositories().getRepositoryModels(user).size() > 0);
 	}
-	
+
 	@Test
 	public void testUserModelVerification() throws Exception {
 		UserModel user = new UserModel("james");
 		user.displayName = "James Moger";
-		
-		assertTrue(user.is("James", null));
-		assertTrue(user.is("James", ""));
-		assertTrue(user.is("JaMeS", "anything"));
-		
-		assertTrue(user.is("james moger", null));
-		assertTrue(user.is("james moger", ""));
-		assertTrue(user.is("james moger", "anything"));
-		
+
+		assertFalse(user.is("James", null));
+		assertFalse(user.is("James", ""));
+		assertFalse(user.is("JaMeS", "anything"));
+
+		assertFalse(user.is("james moger", null));
+		assertFalse(user.is("james moger", ""));
+		assertFalse(user.is("james moger", "anything"));
+
 		assertFalse(user.is("joe", null));
 		assertFalse(user.is("joe", ""));
 		assertFalse(user.is("joe", "anything"));
@@ -94,7 +90,7 @@
 		assertFalse(user.is("James", null));
 		assertFalse(user.is("James", ""));
 		assertFalse(user.is("JaMeS", "anything"));
-		
+
 		assertFalse(user.is("james moger", null));
 		assertFalse(user.is("james moger", ""));
 		assertFalse(user.is("james moger", "anything"));
@@ -156,34 +152,36 @@
 	@Test
 	public void testGitblitSettings() throws Exception {
 		// These are already tested by above test method.
-		assertTrue(GitBlit.getBoolean("missing", true));
-		assertEquals("default", GitBlit.getString("missing", "default"));
-		assertEquals(10, GitBlit.getInteger("missing", 10));
-		assertEquals(5, GitBlit.getInteger("realm.userService", 5));
+		assertTrue(settings().getBoolean("missing", true));
+		assertEquals("default", settings().getString("missing", "default"));
+		assertEquals(10, settings().getInteger("missing", 10));
+		assertEquals(5, settings().getInteger("realm.userService", 5));
 
-		assertTrue(GitBlit.getBoolean("git.enableGitServlet", false));
-		assertEquals(GitBlitSuite.USERSCONF.getAbsolutePath(), GitBlit.getString("realm.userService", null));
-		assertEquals(5, GitBlit.getInteger("realm.minPasswordLength", 0));
-		List<String> mdExtensions = GitBlit.getStrings("web.markdownExtensions");
+		assertTrue(settings().getBoolean("git.enableGitServlet", false));
+		File userDir = new File(System.getProperty("user.dir"));
+		File userService = new File(settings().getString("realm.userService", null));
+		assertEquals("src/test/config/test-users.conf", FileUtils.getRelativePath(userDir, userService));
+		assertEquals(5, settings().getInteger("realm.minPasswordLength", 0));
+		List<String> mdExtensions = settings().getStrings("web.markdownExtensions");
 		assertTrue(mdExtensions.size() > 0);
 		assertTrue(mdExtensions.contains("md"));
 
-		List<String> keys = GitBlit.getAllKeys("server");
+		List<String> keys = settings().getAllKeys("server");
 		assertTrue(keys.size() > 0);
 		assertTrue(keys.contains("server.httpsPort"));
 
-		assertTrue(GitBlit.getChar("web.forwardSlashCharacter", ' ') == '/');
-		assertFalse(GitBlit.isDebugMode());
+		assertTrue(settings().getChar("web.forwardSlashCharacter", ' ') == '/');
+		assertFalse(runtime().isDebugMode());
 	}
 
 	@Test
 	public void testAuthentication() throws Exception {
-		assertTrue(GitBlit.self().authenticate("admin", "admin".toCharArray()) != null);
+		assertTrue(authentication().authenticate("admin", "admin".toCharArray(), null) != null);
 	}
 
 	@Test
 	public void testRepositories() throws Exception {
-		assertTrue(GitBlit.self().getRepository("missing") == null);
-		assertTrue(GitBlit.self().getRepositoryModel("missing") == null);
+		assertTrue(repositories().getRepository("missing") == null);
+		assertTrue(repositories().getRepositoryModel("missing") == null);
 	}
 }

--
Gitblit v1.9.1