Skip to content
This repository has been archived by the owner on Oct 14, 2020. It is now read-only.

add dev mode IT #401

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open

add dev mode IT #401

wants to merge 1 commit into from

Conversation

awisniew90
Copy link
Member

Notes:

  1. The framework for this IT was taken from the LMP's dev mode test
  2. The IT project test-liberty-dev-mode is just a shell project with test classes. The test classes create and build a boost project from "resources/basic-dev-project".
  3. There are several Thread.sleep() calls. Due to the nature of testing dev mode, we occasionally need to wait for the process to fully complete before moving on to another test.

@awisniew90 awisniew90 force-pushed the devIT branch 2 times, most recently from b00eac7 to cf50809 Compare September 27, 2019 00:22
</includes>
<systemPropertyVariables>
<mavenPluginVersion>@pom.version@</mavenPluginVersion>
<runtimeVersion>${runtimeVersion}</runtimeVersion>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Where is this runtimeVersion value coming from? (Our ITs are mostly not parameterized w/ runtime version)

Comment on lines +24 to +28
<dependency>
<groupId>io.openliberty.tools</groupId>
<artifactId>liberty-maven-plugin</artifactId>
<version>3.0.1</version>
</dependency>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We really have LMP as a dependency? That seems surprising.. Is the version meaningful (e.g used to run the child POM in the test) or is this just like a "recent-enough version to compile against"?

</plugins>
</build>

<profiles>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I guess if it's probably easier to leave these in though you'd think we'll only use 'ol'

<dependency>
<groupId>org.microshed.boost.boms</groupId>
<artifactId>mp14-bom</artifactId>
<version>RUNTIME_VERSION</version>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So that @pom.version@ thing doesn't work here? (I still haven't found the doc for that mechanism)

private static void startDevMode(String devModeParams)
throws IOException, InterruptedException, FileNotFoundException {
// run dev mode on project
StringBuilder command = new StringBuilder("mvn io.openliberty.tools:liberty-maven-plugin:3.0.1:dev");
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seems like we should extract the version: "3.0.1" into a property somehow that could be set in the POM and potentially the invoker plugin.

Comment on lines +141 to +146
String os = System.getProperty("os.name");
if (os != null && os.toLowerCase().startsWith("windows")) {
builder.command("CMD", "/C", processCommand);
} else {
builder.command("bash", "-c", processCommand);
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You probalby copied from ci.maven..

Noting it's quite a bit different from:

I'll have to try on windows.

@@ -172,8 +177,13 @@ private void generateServerConfig(List<AbstractBoosterConfig> boosterConfigs) th
}

/**
<<<<<<< HEAD
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

merge conflict (though just in comment)

import org.junit.BeforeClass;
import org.junit.Test;

public class DevHotTestingTest extends BaseDevTest {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you think there's value in testing the "hotTests" path in boost specifically? If not maybe we could simplify by collapsing this into one class and reducing one moving part.

}

public LibertyRuntime(RuntimeParams runtimeParams) {
this.log = BoostLogger.getSystemStreamLogger();
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

formatting

// the server is already running. If we do, the app will be deployed to
// dropins
// which is not what we want.
if (!isServerRunning()) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I"m confused if we're doing this as a workaround to the ci.maven issue or permanently?

Copy link
Contributor

@scottkurz scottkurz left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Comments attached.

* Invoke the liberty-maven-plugin to package the server into a runnable Liberty
* JAR
* Invoke the liberty-maven-plugin to package the server into a runnable
* Liberty JAR
*/
private void createUberJar() throws MojoExecutionException {
executeMojo(getPlugin(), goal("package"),
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we skip creating the runnable JAR if we're in dev mode? Is a running server a good proxy/test for this condition?

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants