Skip to content

Commit

Permalink
TechnologyBrewery#146 copying transitive dependencies functionality f…
Browse files Browse the repository at this point in the history
…or containerize-dependencies goal
  • Loading branch information
Cho-William committed Jun 23, 2024
1 parent fdfe8f1 commit a873be2
Show file tree
Hide file tree
Showing 28 changed files with 943 additions and 38 deletions.
46 changes: 42 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -162,6 +162,43 @@ For example, developers may use this feature to bind a Habushu module's `compile
</plugin>
```

### Leveraging the containerize-dependencies Goal to Prepare a Containerized Virtual Environment ###
If the execution is specified (does not run by default), the `containerize-dependencies` goal will collect a single `habushu` dependency specified the project's `pom.xml`, including all transitive habushu-packaged dependencies. After collecting the set of necessary dependencies, Habushu will copy the project files to the build directory under `venv-support`, while preserving the original structure of the dependency modules to ensure that any path-based dependencies can be leveraged as-is. This directory can then be copied onto a Docker container and used to create a virtual environment capable of running the target Habushu project.

```xml
<plugin>
<groupId>org.technologybrewery.habushu</groupId>
<artifactId>habushu-maven-plugin</artifactId>
<configuration>
...
</configuration>
<executions>
<execution>
<id>containerize-deps</id>
<phase>validate</phase>
<goals>
<goal>containerize-dependencies</goal>
</goals>
</execution>
</executions>
</plugin>
```

The plugin will only examine dependencies that are of the type `habushu` in the dependencies block of the `pom.xml` file.

```xml
<dependencies>
<dependency>
<groupId>your-group-id</groupId>
<artifactId>your-artifact-id</artifactId>
<version>your-version</version>
<type>habushu</type>
</dependency>
</dependencies>
```

Any transitive monorepo dependencie shoud also use this convention to ensure they are captured by the plugin.

### Leveraging Maven Build Cache for Faster Builds ###

Habushu enables support for faster builds via
Expand Down Expand Up @@ -682,13 +719,15 @@ Folder in which Python test files are located - should align with Poetry's proje

Default: `${project.basedir}/tests`

#### cacheWheels ####
#### cacheWheels (deprecated) ####
The `cache-wheels` goal has been `deprecated`, please see the `containerize-dependencies` goal instead.

Enables or Disables the copying of wheels into Poetry cache.

Default: `false`

#### wheelDependencies ####
#### wheelDependencies (deprecated) ####
The `retrieve-wheels` goal has been `deprecated`, please see the `containerize-dependencies` goal instead.

Optional set of wheel dependencies to retrieve from poetry cache. This allows previously cached external
wheel dependencies to be copied into a given target directory if it exists in poetry cache. This logic
Expand Down Expand Up @@ -876,8 +915,7 @@ Uses [behave](https://github.com/behave/behave) to execute BDD scenarios that ar
Builds the `sdist` and `wheel` archives of this project using `poetry build`. It also generates a `requirements.txt` file which is useful when installing the package in a Docker container where you may want to install the dependencies in a specific Docker layer to optimize caching.

##### install #####
Publishes the `pom.xml` for the module into your local Maven Repository (`~/.m2/repository`). If the **cacheWheels** configuration is set to True, the `wheel` archive will be copied to the poetry cache directory (`~/{poetry-cache-dir}/cache/repositories/wheels/{artifact-id}/`). The **cacheWheels** configuration default behavior is not to cache the `wheel` archive. If the **wheelDependencies** list is set, each specified wheel dependency will be
retrieve and placed into the given target directory.
Publishes the `pom.xml` for the module into your local Maven Repository (`~/.m2/repository`).

##### deploy #####

Expand Down
18 changes: 18 additions & 0 deletions habushu-maven-plugin/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -152,6 +152,24 @@
<artifactId>cucumber-junit-platform-engine</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.apache.maven</groupId>
<artifactId>maven-compat</artifactId>
<version>${version.maven}</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.apache.maven.plugin-testing</groupId>
<artifactId>maven-plugin-testing-harness</artifactId>
<version>4.0.0-alpha-2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.junit.platform</groupId>
<artifactId>junit-platform-suite</artifactId>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,9 @@
* wheel files in poetry.
*
* @throws HabushuException
* @deprecated This mojo is deprecated, use the containerize-dependencies goal instead
*/
@Deprecated
@Mojo(name = "cache-wheels", defaultPhase = LifecyclePhase.INSTALL)
public class CacheWheelsMojo extends AbstractHabushuMojo {
/**
Expand All @@ -31,6 +33,8 @@ public class CacheWheelsMojo extends AbstractHabushuMojo {

@Override
public void doExecute() throws MojoExecutionException, MojoFailureException {
getLog().warn("The cache-wheels goal has been deperecated," +
"please see the containerize-dependencies goal instead." );
if (cacheWheels) {
cacheWheels();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@
import java.io.File;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

/**
Expand Down Expand Up @@ -122,8 +121,10 @@ private void clean() throws MojoExecutionException {
List<Fileset> filesetsToDelete = new ArrayList<>();
boolean removeVenvManually = false;

String virtualEnvFullPath = findCurrentVirtualEnvironmentFullPath();
virtualEnvFullPath = getCleanVirtualEnvironmentPath(virtualEnvFullPath);
String virtualEnvFullPath = HabushuUtil.findCurrentVirtualEnvironmentFullPath(
pythonVersion, usePyenv, patchInstallScript,
workingDirectory, rewriteLocalPathDepsInArchives, getLog());
virtualEnvFullPath = HabushuUtil.getCleanVirtualEnvironmentPath(virtualEnvFullPath);

String inVirtualEnvironmentPath = HabushuUtil.getInProjectVirtualEnvironmentPath(this.workingDirectory);
File venv = new File(inVirtualEnvironmentPath);
Expand Down Expand Up @@ -188,33 +189,7 @@ private void clean() throws MojoExecutionException {
super.execute();
}

/**
* Removes (Activated) from path in 1.3.x and higher versions.
*
* @param virtualEnvFullPath path to clean
* @return cleaned path
*/
private static String getCleanVirtualEnvironmentPath(String virtualEnvFullPath) {
return StringUtils.replace(virtualEnvFullPath, " (Activated)", StringUtils.EMPTY);

}

private String findCurrentVirtualEnvironmentFullPath() throws MojoExecutionException {
String virtualEnvFullPath = null;
PyenvAndPoetrySetup configureTools = new PyenvAndPoetrySetup(pythonVersion, usePyenv,
patchInstallScript, workingDirectory, rewriteLocalPathDepsInArchives, getLog());
configureTools.execute();

try {
PoetryCommandHelper poetryHelper = new PoetryCommandHelper(this.workingDirectory);
virtualEnvFullPath = poetryHelper.execute(Arrays.asList("env", "list", "--full-path"));
} catch (RuntimeException e) {
getLog().debug("Could not retrieve Poetry-managed virtual environment path - it likely does not exist",
e);
}

return virtualEnvFullPath;
}

/**
* Creates a new {@link Fileset} that may be used to identify a set of files
Expand Down
Loading

0 comments on commit a873be2

Please sign in to comment.