/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.brooklyn.entity.basic;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.testng.Assert;
import org.testng.annotations.Test;
import org.apache.brooklyn.api.entity.Application;
import org.apache.brooklyn.api.entity.Entity;
import org.apache.brooklyn.core.entity.trait.Startable;
import org.apache.brooklyn.entity.software.base.SoftwareProcess;
import org.apache.brooklyn.launcher.SimpleYamlLauncherForTests;
import org.apache.brooklyn.launcher.camp.SimpleYamlLauncher;
import org.apache.brooklyn.test.Asserts;
import org.apache.brooklyn.util.core.ResourceUtils;
import org.apache.brooklyn.util.os.Os;
import org.apache.brooklyn.util.text.Strings;
import com.google.common.collect.Iterables;
public class VanillaSoftwareYamlTest {
private static final Logger log = LoggerFactory.getLogger(VanillaSoftwareYamlTest.class);
@Test(groups="Integration")
public void testVanillaSoftwareYaml() {
SimpleYamlLauncher l = new SimpleYamlLauncherForTests();
try {
Application app = l.launchAppYaml("vanilla-software-blueprint.yaml");
log.info("started "+app);
String runDir = Iterables.getOnlyElement(app.getChildren()).getAttribute(SoftwareProcess.RUN_DIR);
final String filePath = Os.mergePaths(runDir, "DATE");
String fileContents = new ResourceUtils(this).getResourceAsString(filePath);
Long d1 = Long.parseLong( Strings.getFirstWordAfter(fileContents, "utc") );
Assert.assertTrue( Math.abs(d1*1000-System.currentTimeMillis())<15000, "Time UTC does not match system; "+d1+" v "+System.currentTimeMillis() );
Asserts.succeedsEventually(new Runnable() {
public void run() {
String fileContents = new ResourceUtils(this).getResourceAsString(filePath);
Assert.assertTrue(fileContents.contains("checkRunning"));
}
});
app.invoke(Startable.STOP, null).getUnchecked();
Asserts.succeedsEventually(new Runnable() {
public void run() {
String fileContents = new ResourceUtils(this).getResourceAsString(filePath);
Assert.assertTrue(fileContents.contains("stop"));
}
});
} finally {
l.destroyAll();
}
log.info("DONE");
}
/** yaml variant of VanillaSoftwareProcessAndChildrenIntegrationTest */
@Test(groups="Integration")
public void testVanillaSoftwareYamlWithChildStartedAfter() {
SimpleYamlLauncher l = new SimpleYamlLauncherForTests();
try {
Application app = l.launchAppYaml("vanilla-software-with-child-blueprint.yaml");
log.info("started "+app);
Entity p1 = Iterables.getOnlyElement( app.getChildren() );
Long d1 = Long.parseLong( Strings.getFirstWordAfter(new ResourceUtils(this).getResourceAsString(Os.mergePaths(p1.getAttribute(SoftwareProcess.RUN_DIR), "DATE")), "utc") );
Entity p2 = Iterables.getOnlyElement( p1.getChildren() );
Long d2 = Long.parseLong( Strings.getFirstWordAfter(new ResourceUtils(this).getResourceAsString(Os.mergePaths(p2.getAttribute(SoftwareProcess.RUN_DIR), "DATE")), "utc") );
Assert.assertTrue( d2-d1 > 2 && d2-d1 < 10, "p2 should have started 3s after parent, but it did not ("+(d2-d1)+"s difference" );
} finally {
l.destroyAll();
}
log.info("DONE");
}
}