From f66e89662c091e082bd1d2feb6ac91513ccff273 Mon Sep 17 00:00:00 2001
From: Rafael Cavazin <rafaelcavazin@gmail.com>
Date: Sun, 21 Jul 2013 09:59:00 -0400
Subject: [PATCH] Merge branch 'master' of https://github.com/gitblit/gitblit

---
 src/test/java/de/akquinet/devops/GitblitRunnable.java |  133 ++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 133 insertions(+), 0 deletions(-)

diff --git a/src/test/java/de/akquinet/devops/GitblitRunnable.java b/src/test/java/de/akquinet/devops/GitblitRunnable.java
new file mode 100644
index 0000000..32983d8
--- /dev/null
+++ b/src/test/java/de/akquinet/devops/GitblitRunnable.java
@@ -0,0 +1,133 @@
+/*
+ * Copyright 2013 akquinet tech@spree GmbH
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *     http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package de.akquinet.devops;
+
+import java.net.InetAddress;
+import java.net.ServerSocket;
+
+import com.gitblit.tests.GitBlitSuite;
+
+/**
+ * This is a runnable implementation, that is used to run a gitblit server in a
+ * separate thread (e.g. alongside test cases)
+ * 
+ * @author saheba
+ * 
+ */
+public class GitblitRunnable implements Runnable {
+
+	private int httpPort, httpsPort, shutdownPort;
+	private String userPropertiesPath, gitblitPropertiesPath;
+	private boolean startFailed = false;
+
+	/**
+	 * constructor with reduced set of start params
+	 * 
+	 * @param httpPort
+	 * @param httpsPort
+	 * @param shutdownPort
+	 * @param gitblitPropertiesPath
+	 * @param userPropertiesPath
+	 */
+	public GitblitRunnable(int httpPort, int httpsPort, int shutdownPort,
+			String gitblitPropertiesPath, String userPropertiesPath) {
+		this.httpPort = httpPort;
+		this.httpsPort = httpsPort;
+		this.shutdownPort = shutdownPort;
+		this.userPropertiesPath = userPropertiesPath;
+		this.gitblitPropertiesPath = gitblitPropertiesPath;
+	}
+
+	/*
+	 * (non-Javadoc)
+	 * 
+	 * @see java.lang.Runnable#run()
+	 */
+	public void run() {
+		boolean portsFree = false;
+		long lastRun = -1;
+		while (!portsFree) {
+			long current = System.currentTimeMillis();
+			if (lastRun == -1 || lastRun + 100 < current) {
+				portsFree = areAllPortsFree(new int[] { httpPort, httpsPort,
+						shutdownPort }, "127.0.0.1");
+			}
+			lastRun = current;
+
+		}
+		try {
+			GitBlitServer4UITests.main("--httpPort", "" + httpPort, "--httpsPort", ""
+					+ httpsPort, "--shutdownPort", "" + shutdownPort,
+					"--repositoriesFolder",
+					"\"" + GitBlitSuite.REPOSITORIES.getAbsolutePath() + "\"",
+					"--userService", userPropertiesPath, "--settings",
+					gitblitPropertiesPath);
+			setStartFailed(false);
+		} catch (Exception iex) {
+			System.out.println("Gitblit server start failed");
+			setStartFailed(true);
+		}
+	}
+
+	/**
+	 * Method used to ensure that all ports are free, if the runnable is used
+	 * JUnit test classes. Be aware that JUnit's setUpClass and tearDownClass
+	 * methods, which are executed before and after a test class (consisting of
+	 * several test cases), may be executed parallely if they are part of a test
+	 * suite consisting of several test classes. Therefore the run method of
+	 * this class calls areAllPortsFree to check port availability before
+	 * starting another gitblit instance.
+	 * 
+	 * @param ports
+	 * @param inetAddress
+	 * @return
+	 */
+	public static boolean areAllPortsFree(int[] ports, String inetAddress) {
+		System.out
+				.println("\n"
+						+ System.currentTimeMillis()
+						+ " ----------------------------------- testing if all ports are free ...");
+		String blockedPorts = "";
+		for (int i = 0; i < ports.length; i++) {
+			ServerSocket s;
+			try {
+				s = new ServerSocket(ports[i], 1,
+						InetAddress.getByName(inetAddress));
+				s.close();
+			} catch (Exception e) {
+				if (!blockedPorts.equals("")) {
+					blockedPorts += ", ";
+				}
+			}
+		}
+		if (blockedPorts.equals("")) {
+			System.out
+					.println(" ----------------------------------- ... verified");
+			return true;
+		}
+		System.out.println(" ----------------------------------- ... "
+				+ blockedPorts + " are still blocked");
+		return false;
+	}
+
+	private void setStartFailed(boolean startFailed) {
+		this.startFailed = startFailed;
+	}
+
+	public boolean isStartFailed() {
+		return startFailed;
+	}
+}

--
Gitblit v1.9.1