| | |
| | |
|
| | | import java.io.File;
|
| | | import java.util.concurrent.Executors;
|
| | |
|
| | | import junit.extensions.TestSetup;
|
| | | import junit.framework.Test;
|
| | | import junit.framework.TestSuite;
|
| | | import java.util.concurrent.atomic.AtomicBoolean;
|
| | |
|
| | | import org.eclipse.jgit.lib.Repository;
|
| | | import org.eclipse.jgit.storage.file.FileRepository;
|
| | | import org.junit.AfterClass;
|
| | | import org.junit.BeforeClass;
|
| | | import org.junit.runner.RunWith;
|
| | | import org.junit.runners.Suite;
|
| | | import org.junit.runners.Suite.SuiteClasses;
|
| | |
|
| | | import com.gitblit.FileSettings;
|
| | | import com.gitblit.FileUserService;
|
| | | import com.gitblit.GitBlit;
|
| | | import com.gitblit.GitBlitException;
|
| | | import com.gitblit.GitBlitServer;
|
| | | import com.gitblit.models.RepositoryModel;
|
| | | import com.gitblit.utils.JGitUtils;
|
| | |
|
| | | public class GitBlitSuite extends TestSetup {
|
| | | /**
|
| | | * The GitBlitSuite uses test-gitblit.properties and test-users.conf. The suite
|
| | | * is fairly comprehensive for all lower-level functionality. Wicket pages are
|
| | | * currently not unit-tested.
|
| | | * |
| | | * This suite starts a Gitblit server instance within the same JVM instance as
|
| | | * the unit tests. This allows the unit tests to access the GitBlit static
|
| | | * singleton while also being able to communicate with the instance via tcp/ip
|
| | | * for testing rpc requests, federation requests, and git servlet operations.
|
| | | * |
| | | * @author James Moger
|
| | | * |
| | | */
|
| | | @RunWith(Suite.class)
|
| | | @SuiteClasses({ ArrayUtilsTest.class, FileUtilsTest.class, TimeUtilsTest.class,
|
| | | StringUtilsTest.class, Base64Test.class, JsonUtilsTest.class, ByteFormatTest.class,
|
| | | ObjectCacheTest.class, UserServiceTest.class, MarkdownUtilsTest.class, JGitUtilsTest.class,
|
| | | SyndicationUtilsTest.class, DiffUtilsTest.class, MetricUtilsTest.class,
|
| | | TicgitUtilsTest.class, GitBlitTest.class, FederationTests.class, RpcTests.class,
|
| | | GitServletTest.class, GroovyScriptTest.class })
|
| | | public class GitBlitSuite {
|
| | |
|
| | | public static final File REPOSITORIES = new File("git");
|
| | |
|
| | |
| | | public static String account = "admin";
|
| | | public static String password = "admin";
|
| | |
|
| | | private GitBlitSuite(TestSuite suite) {
|
| | | super(suite);
|
| | | }
|
| | |
|
| | | public static Test suite() {
|
| | | TestSuite suite = new TestSuite();
|
| | | suite.addTestSuite(FileUtilsTest.class);
|
| | | suite.addTestSuite(TimeUtilsTest.class);
|
| | | suite.addTestSuite(StringUtilsTest.class);
|
| | | suite.addTestSuite(Base64Test.class);
|
| | | suite.addTestSuite(JsonUtilsTest.class);
|
| | | suite.addTestSuite(ByteFormatTest.class);
|
| | | suite.addTestSuite(ObjectCacheTest.class);
|
| | | suite.addTestSuite(MarkdownUtilsTest.class);
|
| | | suite.addTestSuite(JGitUtilsTest.class);
|
| | | suite.addTestSuite(SyndicationUtilsTest.class);
|
| | | suite.addTestSuite(DiffUtilsTest.class);
|
| | | suite.addTestSuite(MetricUtilsTest.class);
|
| | | suite.addTestSuite(TicgitUtilsTest.class);
|
| | | suite.addTestSuite(GitBlitTest.class);
|
| | | suite.addTestSuite(RpcTests.class);
|
| | | return new GitBlitSuite(suite);
|
| | | }
|
| | | private static AtomicBoolean started = new AtomicBoolean(false);
|
| | |
|
| | | public static Repository getHelloworldRepository() throws Exception {
|
| | | return new FileRepository(new File(REPOSITORIES, "helloworld.git"));
|
| | |
| | | return new FileRepository(new File(REPOSITORIES, "test/bluez-gnome.git"));
|
| | | }
|
| | |
|
| | | public static void startGitblit() throws Exception {
|
| | | public static Repository getAmbitionRepository() throws Exception {
|
| | | return new FileRepository(new File(REPOSITORIES, "test/ambition.git"));
|
| | | }
|
| | |
|
| | | public static Repository getTheoreticalPhysicsRepository() throws Exception {
|
| | | return new FileRepository(new File(REPOSITORIES, "test/theoretical-physics.git"));
|
| | | }
|
| | |
|
| | | public static boolean startGitblit() throws Exception {
|
| | | if (started.get()) {
|
| | | // already started
|
| | | return false;
|
| | | }
|
| | | // Start a Gitblit instance
|
| | | Executors.newSingleThreadExecutor().execute(new Runnable() {
|
| | | public void run() {
|
| | | GitBlitServer.main("--httpPort", "" + port, "--httpsPort", "0", "--shutdownPort",
|
| | | "" + shutdownPort, "--repositoriesFolder",
|
| | | "\"" + GitBlitSuite.REPOSITORIES.getAbsolutePath() + "\"", "--userService",
|
| | | "distrib/users.properties");
|
| | | "test-users.conf", "--settings", "test-gitblit.properties");
|
| | | }
|
| | | });
|
| | |
|
| | | // Wait a few seconds for it to be running
|
| | | Thread.sleep(2500);
|
| | |
|
| | | started.set(true);
|
| | | return true;
|
| | | }
|
| | |
|
| | | public static void stopGitblit() throws Exception {
|
| | |
| | | Thread.sleep(2500);
|
| | | }
|
| | |
|
| | | @Override
|
| | | protected void setUp() throws Exception {
|
| | | FileSettings settings = new FileSettings("distrib/gitblit.properties");
|
| | | GitBlit.self().configureContext(settings, true);
|
| | | FileUserService loginService = new FileUserService(new File("distrib/users.properties"));
|
| | | GitBlit.self().setUserService(loginService);
|
| | | @BeforeClass
|
| | | public static void setUp() throws Exception {
|
| | | startGitblit();
|
| | |
|
| | | if (REPOSITORIES.exists() || REPOSITORIES.mkdirs()) {
|
| | | cloneOrFetch("helloworld.git", "https://github.com/git/hello-world.git");
|
| | |
| | | "https://git.kernel.org/pub/scm/bluetooth/bluez-gnome.git");
|
| | | cloneOrFetch("test/jgit.git", "https://github.com/eclipse/jgit.git");
|
| | | cloneOrFetch("test/helloworld.git", "https://github.com/git/hello-world.git");
|
| | |
|
| | | cloneOrFetch("test/ambition.git", "https://github.com/defunkt/ambition.git");
|
| | | cloneOrFetch("test/theoretical-physics.git", "https://github.com/certik/theoretical-physics.git");
|
| | | |
| | | enableTickets("ticgit.git");
|
| | | enableDocs("ticgit.git");
|
| | | showRemoteBranches("ticgit.git");
|
| | | showRemoteBranches("test/jgit.git");
|
| | | }
|
| | |
|
| | | startGitblit();
|
| | | }
|
| | |
|
| | | @Override
|
| | | protected void tearDown() throws Exception {
|
| | | @AfterClass
|
| | | public static void tearDown() throws Exception {
|
| | | stopGitblit();
|
| | | }
|
| | |
|
| | | private void cloneOrFetch(String name, String fromUrl) throws Exception {
|
| | | private static void cloneOrFetch(String name, String fromUrl) throws Exception {
|
| | | System.out.print("Fetching " + name + "... ");
|
| | | JGitUtils.cloneRepository(REPOSITORIES, name, fromUrl);
|
| | | System.out.println("done.");
|
| | | }
|
| | |
|
| | | private void enableTickets(String repositoryName) {
|
| | | private static void enableTickets(String repositoryName) {
|
| | | try {
|
| | | RepositoryModel model = GitBlit.self().getRepositoryModel(repositoryName);
|
| | | model.useTickets = true;
|
| | |
| | | }
|
| | | }
|
| | |
|
| | | private void enableDocs(String repositoryName) {
|
| | | private static void enableDocs(String repositoryName) {
|
| | | try {
|
| | | RepositoryModel model = GitBlit.self().getRepositoryModel(repositoryName);
|
| | | model.useDocs = true;
|
| | |
| | | }
|
| | | }
|
| | |
|
| | | private void showRemoteBranches(String repositoryName) {
|
| | | private static void showRemoteBranches(String repositoryName) {
|
| | | try {
|
| | | RepositoryModel model = GitBlit.self().getRepositoryModel(repositoryName);
|
| | | model.showRemoteBranches = true;
|