This commit is contained in:
Nunzio Andrea Galante 2017-05-10 09:31:28 +00:00
parent e136299fb9
commit a325272b18
5 changed files with 196 additions and 203 deletions

View File

@ -204,82 +204,82 @@ public class AnsibleBridge {
***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED***
public AnsibleWorker applyAlgorithmSetToCluster(AlgorithmSet as, Cluster cluster, /*boolean updateSVN,*/ boolean test) throws IOException, InterruptedException, SVNException { ***REMOVED*** public AnsibleWorker applyAlgorithmSetToCluster(AlgorithmSet as, Cluster cluster, /*boolean updateSVN,*/ boolean test) throws IOException, InterruptedException, SVNException {
***REMOVED***
***REMOVED***
return applyAlgorithmSetToCluster (as,cluster,UUID.randomUUID().toString(),/*updateSVN,*/ test); ***REMOVED*** return applyAlgorithmSetToCluster (as,cluster,UUID.randomUUID().toString(),/*updateSVN,*/ test);
***REMOVED*** ***REMOVED*** ***REMOVED***
public AnsibleWorker applyAlgorithmSetToCluster(AlgorithmSet as, Cluster cluster,String uuid, /*boolean updateSVN,*/ boolean test) throws IOException, InterruptedException, SVNException { ***REMOVED*** public AnsibleWorker applyAlgorithmSetToCluster(AlgorithmSet as, Cluster cluster,String uuid, /*boolean updateSVN,*/ boolean test) throws IOException, InterruptedException, SVNException {
AnsibleWorker worker = new AnsibleWorker(new File(this.getWorkDir(), uuid)); ***REMOVED*** AnsibleWorker worker = new AnsibleWorker(new File(this.getWorkDir(), uuid));
***REMOVED***
***REMOVED***
List<Role> algoRoles = new Vector<>(); ***REMOVED*** List<Role> algoRoles = new Vector<>();
***REMOVED***
***REMOVED*** add algorithms and dependencies to the worker ***REMOVED*** ***REMOVED*** add algorithms and dependencies to the worker
for (Algorithm a : as.getAlgorithms()) { ***REMOVED*** for (Algorithm a : as.getAlgorithms()) {
for (Role r : this.generateRoles(a)) { ***REMOVED*** for (Role r : this.generateRoles(a)) {
algoRoles.add(r); ***REMOVED*** algoRoles.add(r);
worker.addRole(r); ***REMOVED*** worker.addRole(r);
***REMOVED*** ***REMOVED*** ***REMOVED***
***REMOVED***to comment the for in case of just install algo ***REMOVED*** ***REMOVED***to comment the for in case of just install algo
if(test){ ***REMOVED*** if(test){
for (Dependency d : a.getDependencies()) { ***REMOVED*** for (Dependency d : a.getDependencies()) {
for (Role r : this.generateRoles(d)) { ***REMOVED*** for (Role r : this.generateRoles(d)) {
worker.addRole(r); ***REMOVED*** worker.addRole(r);
***REMOVED*** ***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED*** ***REMOVED***
***REMOVED***
***REMOVED*** add static roles ***REMOVED*** ***REMOVED*** add static roles
for(Role r:this.getStaticRoleManager().getStaticRoles()) { ***REMOVED*** for(Role r:this.getStaticRoleManager().getStaticRoles()) {
worker.addRole(r); ***REMOVED*** worker.addRole(r);
***REMOVED*** ***REMOVED*** ***REMOVED***
***REMOVED***
***REMOVED*** generate the inventory ***REMOVED*** ***REMOVED*** generate the inventory
Inventory inventory = new Inventory(); ***REMOVED*** Inventory inventory = new Inventory();
for (Host h : cluster.getHosts()) { ***REMOVED*** for (Host h : cluster.getHosts()) {
AnsibleHost ah = new AnsibleHost(h.getName()); ***REMOVED*** AnsibleHost ah = new AnsibleHost(h.getName());
inventory.addHost(ah, "universe"); ***REMOVED*** inventory.addHost(ah, "universe");
inventory.addHost(ah, "d4science"); ***REMOVED*** inventory.addHost(ah, "d4science");
***REMOVED*** ***REMOVED*** ***REMOVED***
worker.setInventory(inventory); ***REMOVED*** worker.setInventory(inventory);
***REMOVED***
***REMOVED*** generate the playbook ***REMOVED*** ***REMOVED*** generate the playbook
Playbook playbook = new Playbook(); ***REMOVED*** Playbook playbook = new Playbook();
if(test){ ***REMOVED*** if(test){
playbook.setRemote_user("root");***REMOVED*** ***REMOVED*** playbook.setRemote_user("root");***REMOVED***
playbook.setRemote_user("gcube"); ***REMOVED*** playbook.setRemote_user("gcube");
playbook.applyTo("universe"); ***REMOVED*** playbook.applyTo("universe");
for(Role r:algoRoles) { ***REMOVED*** for(Role r:algoRoles) {
***REMOVED*** add only 'add' roles ***REMOVED*** ***REMOVED*** add only 'add' roles
if(!r.getName().endsWith("remove")) { ***REMOVED*** if(!r.getName().endsWith("remove")) {
playbook.addRole(r.getName()); ***REMOVED*** playbook.addRole(r.getName());
***REMOVED*** ***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED*** ***REMOVED***
***REMOVED***
worker.setPlaybook(playbook); ***REMOVED*** worker.setPlaybook(playbook);
***REMOVED***
***REMOVED*** execute and save log locally ***REMOVED*** ***REMOVED*** execute and save log locally
***REMOVED***PrintStream console = System.out; ***REMOVED*** ***REMOVED***PrintStream console = System.out;
File path = new File(worker.getWorkdir() + File.separator + "logs"); ***REMOVED*** File path = new File(worker.getWorkdir() + File.separator + "logs");
path.mkdirs(); ***REMOVED*** path.mkdirs();
File n = new File(path + File.separator + worker.getWorkerId()); ***REMOVED*** File n = new File(path + File.separator + worker.getWorkerId());
FileOutputStream fos = new FileOutputStream(n); ***REMOVED*** FileOutputStream fos = new FileOutputStream(n);
PrintStream ps = new PrintStream(fos); ***REMOVED*** PrintStream ps = new PrintStream(fos);
***REMOVED***
***REMOVED***System.setErr(console); ***REMOVED*** ***REMOVED***System.setErr(console);
***REMOVED***
worker.apply(as,ps,test); ***REMOVED*** worker.apply(as,ps,test);
***REMOVED***System.setOut(console); ***REMOVED*** ***REMOVED***System.setOut(console);
***REMOVED***worker.apply(); ***REMOVED*** ***REMOVED***worker.apply();
System.out.println("Log stored to to " + n.getAbsolutePath()); ***REMOVED*** System.out.println("Log stored to to " + n.getAbsolutePath());
***REMOVED***
***REMOVED*** destroy the worker ***REMOVED*** ***REMOVED*** destroy the worker
worker.destroy(); ***REMOVED*** worker.destroy();
return worker; ***REMOVED*** return worker;
***REMOVED*** ***REMOVED*** ***REMOVED***

View File

@ -172,70 +172,70 @@ public class DataminerPoolManager {
return bufferScript; return bufferScript;
***REMOVED*** ***REMOVED***
public String addAlgorithmToVRE(Algorithm algorithm, final String vre, /*final boolean updateSVN*/ final boolean test) throws IOException { ***REMOVED*** public String addAlgorithmToVRE(Algorithm algorithm, final String vre, /*final boolean updateSVN*/ final boolean test) throws IOException {
***REMOVED*** create a fake algorithm set ***REMOVED*** ***REMOVED*** create a fake algorithm set
final AlgorithmSet algoSet = new AlgorithmSet(); ***REMOVED*** final AlgorithmSet algoSet = new AlgorithmSet();
algoSet.setName("fake"); ***REMOVED*** algoSet.setName("fake");
algoSet.addAlgorithm(algorithm); ***REMOVED*** algoSet.addAlgorithm(algorithm);
final String uuid = UUID.randomUUID().toString(); ***REMOVED*** final String uuid = UUID.randomUUID().toString();
new Thread(new Runnable() {
@Override
public void run() {
***REMOVED*** TODO Auto-generated method stub
try {
try {
addAlgorithmsToVRE(algoSet, vre, uuid, /*updateSVN*/test);
***REMOVED*** catch (SVNException e) {
***REMOVED*** TODO Auto-generated catch block
e.printStackTrace();
***REMOVED***
***REMOVED*** catch (IOException e) {
***REMOVED*** TODO Auto-generated catch block
e.printStackTrace();
***REMOVED*** catch (InterruptedException e) {
***REMOVED*** TODO Auto-generated catch block
e.printStackTrace();
***REMOVED***
***REMOVED***
***REMOVED***).start();
***REMOVED*** this line will execute immediately, not waiting for task to
***REMOVED*** complete
System.out.println(uuid);
return uuid;
***REMOVED*** ***REMOVED***
***REMOVED*** new Thread(new Runnable() {
***REMOVED*** @Override
***REMOVED*** public void run() {
***REMOVED*** ***REMOVED*** TODO Auto-generated method stub
***REMOVED*** try {
***REMOVED*** try {
***REMOVED*** addAlgorithmsToVRE(algoSet, vre, uuid, /*updateSVN*/test);
***REMOVED*** ***REMOVED*** catch (SVNException e) {
***REMOVED*** ***REMOVED*** TODO Auto-generated catch block
***REMOVED*** e.printStackTrace();
***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED*** catch (IOException e) {
***REMOVED*** ***REMOVED*** TODO Auto-generated catch block
***REMOVED*** e.printStackTrace();
***REMOVED*** ***REMOVED*** catch (InterruptedException e) {
***REMOVED*** ***REMOVED*** TODO Auto-generated catch block
***REMOVED*** e.printStackTrace();
***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED***).start();
***REMOVED*** ***REMOVED*** this line will execute immediately, not waiting for task to
***REMOVED*** ***REMOVED*** complete
***REMOVED*** System.out.println(uuid);
***REMOVED*** return uuid;
***REMOVED******REMOVED***
public String addAlgorithmToHost(Algorithm algorithm, final String hostname, /*final boolean updateSVN*/ final boolean test) throws IOException { ***REMOVED*** public String addAlgorithmToHost(Algorithm algorithm, final String hostname, /*final boolean updateSVN*/ final boolean test) throws IOException {
***REMOVED*** create a fake algorithm set ***REMOVED*** ***REMOVED*** create a fake algorithm set
final AlgorithmSet algoSet = new AlgorithmSet(); ***REMOVED*** final AlgorithmSet algoSet = new AlgorithmSet();
algoSet.setName("fake"); ***REMOVED*** algoSet.setName("fake");
algoSet.addAlgorithm(algorithm); ***REMOVED*** algoSet.addAlgorithm(algorithm);
final String uuid = UUID.randomUUID().toString(); ***REMOVED*** final String uuid = UUID.randomUUID().toString();
new Thread(new Runnable() {
@Override
public void run() {
***REMOVED*** TODO Auto-generated method stub
try {
if(test){
addAlgorithmsToStagingHost(algoSet, hostname, uuid, /*updateSVN,*/test);***REMOVED***
***REMOVED*** catch (IOException e) {
***REMOVED*** TODO Auto-generated catch block
e.printStackTrace();
***REMOVED*** catch (InterruptedException e) {
***REMOVED*** TODO Auto-generated catch block
e.printStackTrace();
***REMOVED*** catch (SVNException e) {
***REMOVED*** TODO Auto-generated catch block
e.printStackTrace();
***REMOVED***
***REMOVED***
***REMOVED***).start();
***REMOVED*** this line will execute immediately, not waiting for your task to
***REMOVED*** complete
System.out.println(uuid);
return uuid;
***REMOVED*** ***REMOVED***
***REMOVED*** new Thread(new Runnable() {
***REMOVED*** @Override
***REMOVED*** public void run() {
***REMOVED*** ***REMOVED*** TODO Auto-generated method stub
***REMOVED*** try {
***REMOVED*** if(test){
***REMOVED*** addAlgorithmsToStagingHost(algoSet, hostname, uuid, /*updateSVN,*/test);***REMOVED***
***REMOVED*** ***REMOVED*** catch (IOException e) {
***REMOVED*** ***REMOVED*** TODO Auto-generated catch block
***REMOVED*** e.printStackTrace();
***REMOVED*** ***REMOVED*** catch (InterruptedException e) {
***REMOVED*** ***REMOVED*** TODO Auto-generated catch block
***REMOVED*** e.printStackTrace();
***REMOVED*** ***REMOVED*** catch (SVNException e) {
***REMOVED*** ***REMOVED*** TODO Auto-generated catch block
***REMOVED*** e.printStackTrace();
***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED***).start();
***REMOVED*** ***REMOVED*** this line will execute immediately, not waiting for your task to
***REMOVED*** ***REMOVED*** complete
***REMOVED*** System.out.println(uuid);
***REMOVED*** return uuid;
***REMOVED******REMOVED***
public URL getURLfromWorkerLog(String a) throws MalformedURLException, UnknownHostException { public URL getURLfromWorkerLog(String a) throws MalformedURLException, UnknownHostException {
@ -249,52 +249,52 @@ public class DataminerPoolManager {
return new File(n.getPath()).toURI().toURL(); return new File(n.getPath()).toURI().toURL();
***REMOVED*** ***REMOVED***
public String addAlgorithmsToVRE(AlgorithmSet algorithms, String vre, String uuid, /*boolean updateSVN,*/ boolean test) throws IOException, InterruptedException, SVNException { ***REMOVED*** public String addAlgorithmsToVRE(AlgorithmSet algorithms, String vre, String uuid, /*boolean updateSVN,*/ boolean test) throws IOException, InterruptedException, SVNException {
***REMOVED*** create the cluster (dataminers in the vre)
Cluster cluster = new Cluster();
for (Host h : new HAProxy().listDataMinersByCluster()) {
***REMOVED***for (Host h : new ISClient().listDataminersInVRE()) {
cluster.addHost(h);
***REMOVED***
***REMOVED*** apply the changes
AnsibleBridge a = new AnsibleBridge();
return a.applyAlgorithmSetToCluster(algorithms, cluster, uuid, /*updateSVN,*/ test).getWorkerId();
***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED*** create the cluster (dataminers in the vre)
public String addAlgorithmsToHost(AlgorithmSet algorithms, String hostname, String uuid, /*boolean updateSVN,*/boolean test) ***REMOVED*** Cluster cluster = new Cluster();
throws IOException, InterruptedException, SVNException { ***REMOVED*** for (Host h : new HAProxy().listDataMinersByCluster()) {
***REMOVED*** ***REMOVED***for (Host h : new ISClient().listDataminersInVRE()) {
***REMOVED*** create the cluster (dataminers in the vre) ***REMOVED*** cluster.addHost(h);
Cluster cluster = new Cluster(); ***REMOVED*** ***REMOVED***
for (Host h : new HAProxy().listDataMinersByCluster()) {
if (h.getName().equals(hostname)) {
cluster.addHost(h);
***REMOVED***
***REMOVED***
***REMOVED*** if(ISClient.getHProxy().equals(hostname)){
***REMOVED*** cluster.addHost(new ISClient().getDataminer(hostname));
***REMOVED*** ***REMOVED***
***REMOVED*** apply the changes
AnsibleBridge a = new AnsibleBridge();
return a.applyAlgorithmSetToCluster(algorithms, cluster, uuid, /*updateSVN,*/test).getWorkerId();
***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED*** apply the changes
***REMOVED*** AnsibleBridge a = new AnsibleBridge();
***REMOVED*** return a.applyAlgorithmSetToCluster(algorithms, cluster, uuid, /*updateSVN,*/ test).getWorkerId();
***REMOVED***
***REMOVED******REMOVED***
***REMOVED*** public String addAlgorithmsToHost(AlgorithmSet algorithms, String hostname, String uuid, /*boolean updateSVN,*/boolean test)
***REMOVED*** throws IOException, InterruptedException, SVNException {
***REMOVED***
***REMOVED*** ***REMOVED*** create the cluster (dataminers in the vre)
***REMOVED*** Cluster cluster = new Cluster();
***REMOVED*** for (Host h : new HAProxy().listDataMinersByCluster()) {
***REMOVED*** if (h.getName().equals(hostname)) {
***REMOVED*** cluster.addHost(h);
***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED*** if(ISClient.getHProxy().equals(hostname)){
***REMOVED*** ***REMOVED*** cluster.addHost(new ISClient().getDataminer(hostname));
***REMOVED*** ***REMOVED*** ***REMOVED***
***REMOVED*** ***REMOVED*** apply the changes
***REMOVED*** AnsibleBridge a = new AnsibleBridge();
***REMOVED*** return a.applyAlgorithmSetToCluster(algorithms, cluster, uuid, /*updateSVN,*/test).getWorkerId();
***REMOVED***
***REMOVED******REMOVED***
***REMOVED***
public String addAlgorithmsToStagingHost(AlgorithmSet algorithms, String hostname, String uuid, /*boolean updateSVN,*/boolean test) ***REMOVED*** public String addAlgorithmsToStagingHost(AlgorithmSet algorithms, String hostname, String uuid, /*boolean updateSVN,*/boolean test)
throws IOException, InterruptedException, SVNException { ***REMOVED*** throws IOException, InterruptedException, SVNException {
Cluster cluster = new Cluster(); ***REMOVED*** Cluster cluster = new Cluster();
Host h = new Host(); ***REMOVED*** Host h = new Host();
h.setName(hostname); ***REMOVED*** h.setName(hostname);
cluster.addHost(h); ***REMOVED*** cluster.addHost(h);
***REMOVED***
AnsibleBridge a = new AnsibleBridge(); ***REMOVED*** AnsibleBridge a = new AnsibleBridge();
return a.applyAlgorithmSetToCluster(algorithms, cluster, uuid, /*updateSVN,*/test).getWorkerId(); ***REMOVED*** return a.applyAlgorithmSetToCluster(algorithms, cluster, uuid, /*updateSVN,*/test).getWorkerId();
***REMOVED*** ***REMOVED***
***REMOVED******REMOVED***
***REMOVED*** 2017 March 29 ***REMOVED*** 2017 March 29

View File

@ -23,29 +23,22 @@ public class AlgorithmBuilder {
if(category != null){ if(category != null){
algo.setCategory(category); algo.setCategory(category);
***REMOVED*** ***REMOVED***
if(algorithmType != null){
***REMOVED***FIXME: do the same done for category algo.setAlgorithmType(algorithmType);
if (algo.getAlgorithmType() == null) { ***REMOVED***
algo.setAlgorithmType(algorithmType); if(skipJava != null){
***REMOVED*** else algo.setSkipJava(skipJava);
algo.setAlgorithmType(algo.getCategory()); ***REMOVED***
if(skipJava != null){
if (algo.getSkipJava() == null) { algo.setSkipJava(skipJava);
algo.setSkipJava(skipJava); ***REMOVED***
***REMOVED*** else if(name != null){
algo.setSkipJava(algo.getSkipJava()); algo.setName(name);
***REMOVED***
if (algo.getName() == null) { if(description != null){
algo.setName(name); algo.setDescription(description);
***REMOVED*** else ***REMOVED***
algo.setName(algo.getName());
if (algo.getDescription() == null) {
algo.setDescription(description);
;
***REMOVED*** else
algo.setDescription(algo.getDescription());
return algo; return algo;
***REMOVED*** ***REMOVED***

View File

@ -220,7 +220,7 @@ public class DataminerPoolManagerTest {
ensemble.addDependency(d); ensemble.addDependency(d);
algorithms.addAlgorithm(ensemble); algorithms.addAlgorithm(ensemble);
new DataminerPoolManager().addAlgorithmsToVRE(algorithms, "/gcube/devNext/NextNext", "test"+UUID.randomUUID(), false); ***REMOVED***new DataminerPoolManager().addAlgorithmsToVRE(algorithms, "/gcube/devNext/NextNext", "test"+UUID.randomUUID(), false);
***REMOVED*** ***REMOVED***

View File

@ -220,7 +220,7 @@ public class DataminerPoolManagerTest {
ensemble.addDependency(d); ensemble.addDependency(d);
algorithms.addAlgorithm(ensemble); algorithms.addAlgorithm(ensemble);
new DataminerPoolManager().addAlgorithmsToVRE(algorithms, "/gcube/devNext/NextNext", "test"+UUID.randomUUID(), false); ***REMOVED***new DataminerPoolManager().addAlgorithmsToVRE(algorithms, "/gcube/devNext/NextNext", "test"+UUID.randomUUID(), false);
***REMOVED*** ***REMOVED***