Skip to content

Commit

Permalink
Add test case for OptionalDependenciesPlugin (com.netflix.nebula:grad…
Browse files Browse the repository at this point in the history
…le-extra-configurations-plugin plugin migration) (opensearch-project#7995)

Signed-off-by: Andriy Redko <[email protected]>
  • Loading branch information
reta authored Jun 9, 2023
1 parent 28d5948 commit 5ebfbcd
Show file tree
Hide file tree
Showing 2 changed files with 124 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
/*
* SPDX-License-Identifier: Apache-2.0
*
* The OpenSearch Contributors require contributions made to
* this file be licensed under the Apache-2.0 license or a
* compatible open source license.
*/

package org.opensearch.gradle.plugin;

import org.apache.maven.model.Dependency;
import org.apache.maven.model.Model;
import org.apache.maven.model.io.xpp3.MavenXpp3Reader;
import org.codehaus.plexus.util.xml.pull.XmlPullParserException;
import org.gradle.testkit.runner.BuildResult;
import org.gradle.testkit.runner.GradleRunner;
import org.junit.After;
import org.junit.Before;
import org.junit.rules.TemporaryFolder;
import org.opensearch.gradle.test.GradleUnitTestCase;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Optional;

import static org.gradle.testkit.runner.TaskOutcome.SUCCESS;
import static org.hamcrest.CoreMatchers.is;

public class OptionalDependenciesPluginTests extends GradleUnitTestCase {
private TemporaryFolder projectDir;

@Before
public void setUp() throws Exception {
projectDir = new TemporaryFolder();
projectDir.create();
}

@After
public void tearDown() {
projectDir.delete();
}

public void testApply() throws FileNotFoundException, IOException, XmlPullParserException {
final File mavenRepoDir = new File(projectDir.getRoot(), "mavenrepo");

try (InputStream in = getClass().getClassLoader().getResourceAsStream("plugin/optional-dependencies.gradle")) {
try (OutputStream out = new FileOutputStream(projectDir.newFile("build.gradle"))) {
in.transferTo(out);
}
}

GradleRunner runner = GradleRunner.create()
.forwardOutput()
.withPluginClasspath()
.withArguments("publish", "-PrepoUrl=" + mavenRepoDir.toURI().toURL())
.withProjectDir(projectDir.getRoot());

BuildResult result = runner.build();
assertEquals(SUCCESS, result.task(":" + "publish").getOutcome());

final String name = projectDir.getRoot().getName();
assertDependency(mavenRepoDir, name);
}

private void assertDependency(File repoUrl, String name) throws FileNotFoundException, IOException, XmlPullParserException {
final File pom = new File(repoUrl, "org/custom/group/" + name + "/1.0.0/" + name + "-1.0.0.pom");
assertThat(pom.exists(), is(true));

final MavenXpp3Reader reader = new MavenXpp3Reader();
final Model model = reader.read(new FileReader(pom));

final Optional<Dependency> dependecyOpt = model.getDependencies()
.stream()
.filter(d -> d.getArtifactId().equals("commons-lang3"))
.findAny();

assertThat(dependecyOpt.isPresent(), is(true));
assertThat(dependecyOpt.get().isOptional(), is(true));
}
}
39 changes: 39 additions & 0 deletions buildSrc/src/test/resources/plugin/optional-dependencies.gradle
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
/*
* SPDX-License-Identifier: Apache-2.0
*
* The OpenSearch Contributors require contributions made to
* this file be licensed under the Apache-2.0 license or a
* compatible open source license.
*
* Modifications Copyright OpenSearch Contributors. See
* GitHub history for details.
*/

plugins {
id 'java'
id 'maven-publish'
id 'opensearch.optional-dependencies'
}
group = "org.custom.group"
version = '1.0.0'

repositories {
mavenCentral()
}

dependencies {
implementation 'org.apache.commons:commons-lang3:3.3.2', optional
}

publishing {
publications {
mavenJava(MavenPublication) {
from components.java
}
}
repositories {
maven {
url "${repoUrl}"
}
}
}

0 comments on commit 5ebfbcd

Please sign in to comment.