*/
package org.opendaylight.yangtools.yang2sources.plugin.it;
+import static org.hamcrest.CoreMatchers.containsString;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.fail;
-import static org.junit.matchers.JUnitMatchers.containsString;
+import com.google.common.base.Joiner;
+import com.google.common.io.Resources;
import java.io.File;
-import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.URISyntaxException;
import java.net.URL;
-import java.util.List;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.util.Arrays;
+import java.util.Optional;
import java.util.Properties;
-
import org.apache.maven.it.VerificationException;
import org.apache.maven.it.Verifier;
-import org.junit.BeforeClass;
import org.junit.Test;
public class YangToSourcesPluginTestIT {
- private static final String SRC_PROPERTIES = "target/it-project.properties";
- private static final String VERSION_PROP = "it-project.version";
- private static Properties props;
// TODO Test yang files in transitive dependencies
@Test
- public void testYangRootNotExist() throws URISyntaxException {
- try {
- setUp("YangRootNotExist/", false);
- } catch (VerificationException e) {
- assertVerificationException(e,
- "[ERROR] yang-to-sources: Unable to parse yang files from ");
- assertVerificationException(
- e,
- "Caused by: org.apache.maven.plugin.MojoExecutionException: yang-to-sources: Unable to parse yang files from ");
- return;
- }
-
- fail("Verification exception should have been thrown");
+ public void testYangRootNotExist() throws Exception {
+ setUp("test-parent/YangRootNotExist/", false)
+ .verifyTextInLog("[WARNING] yang-to-sources: YANG source directory");
}
@Test
- public void testCorrect() throws Exception {
- Verifier v = setUp("Correct/", false);
- verifyCorrectLog(v);
+ public void testCorrect() throws VerificationException, URISyntaxException, IOException {
+ verifyCorrectLog(setUp("test-parent/Correct/", false));
}
@Test
public void testAdditionalConfiguration() throws Exception {
- Verifier v = setUp("AdditionalConfig/", false);
- v.verifyTextInLog("[DEBUG] yang-to-sources: Additional configuration picked up for : org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl: {nm1=abcd=a.b.c.d, nm2=abcd2=a.b.c.d.2}");
- v.verifyTextInLog("[DEBUG] yang-to-sources: Additional configuration picked up for : org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl: {c1=config}");
- v.verifyTextInLog(File.separator
- + "files marked as resources: META-INF/yang");
- v.verifyTextInLog("target"
- + File.separator
- + "generated-resources marked as resources for generator: org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl");
+ Verifier vrf = setUp("test-parent/AdditionalConfig/", false);
+ vrf.verifyTextInLog("[DEBUG] yang-to-sources: Additional configuration picked up for : "
+ + "org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl: "
+ + "{nm1=abcd=a.b.c.d, nm2=abcd2=a.b.c.d.2}");
+ vrf.verifyTextInLog("[DEBUG] yang-to-sources: Additional configuration picked up for : "
+ + "org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl: {c1=config}");
+ vrf.verifyTextInLog("[DEBUG] yang-to-sources: YANG files marked as resources:");
+ vrf.verifyTextInLog(Joiner.on(File.separator).join(Arrays.asList("target", "generated-sources", "spi"))
+ + " marked as resources for generator: org.opendaylight.yangtools.yang2sources.spi."
+ + "CodeGeneratorTestImpl");
}
@Test
public void testMissingYangInDep() throws Exception {
try {
- setUp("MissingYangInDep/", false);
+ setUp("test-parent/MissingYangInDep/", false);
+ fail("Verification exception should have been thrown");
} catch (VerificationException e) {
- assertVerificationException(
- e,
- "org.opendaylight.yangtools.yang.parser.util.YangValidationException: Not existing module imported:unknownDep:2013-02-27 by:private:2013-02-27");
- return;
+ assertVerificationException(e, "Imported module [unknownDep] was not found.");
}
-
- fail("Verification exception should have been thrown");
}
- @Test
- public void testNamingConflict() throws Exception {
- Verifier v = setUp("NamingConflict/", false);
- v.verifyErrorFreeLog();
- String baseDir = v.getBasedir();
- String fileName = v.getLogFileName();
- List<String> lines = v.loadFile(baseDir, fileName, false);
- for (String s : lines) {
- if (s.contains("conflict")) {
- System.err.println(s);
- }
- }
- v.verifyTextInLog("[WARNING] Naming conflict for type 'org.opendaylight.yang.gen.v1.urn.yang.test.rev140303.NetworkTopologyRef': file with same name already exists and will not be generated.");
- }
-
- static void verifyCorrectLog(Verifier v) throws VerificationException {
- v.verifyErrorFreeLog();
- v.verifyTextInLog("[INFO] yang-to-sources: YANG files parsed from");
- v.verifyTextInLog("[INFO] yang-to-sources: Code generator instantiated from org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl");
- v.verifyTextInLog("[INFO] yang-to-sources: Sources generated by org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl: null");
+ static void verifyCorrectLog(final Verifier vrf) throws VerificationException {
+ vrf.verifyErrorFreeLog();
+ vrf.verifyTextInLog("[INFO] yang-to-sources: Project model files found: ");
+ vrf.verifyTextInLog("[INFO] yang-to-sources: Code generator instantiated from "
+ + "org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl");
+ vrf.verifyTextInLog("[INFO] yang-to-sources: Sources generated by "
+ + "org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl: 0");
}
@Test
public void testNoGenerators() throws Exception {
- Verifier v = setUp("NoGenerators/", false);
- v.verifyErrorFreeLog();
- v.verifyTextInLog("[WARNING] yang-to-sources: No code generators provided");
+ Verifier vrf = setUp("test-parent/NoGenerators/", false);
+ vrf.verifyErrorFreeLog();
+ vrf.verifyTextInLog("[WARNING] yang-to-sources: No code generators provided");
}
@Test
public void testInvalidVersion() throws Exception {
- Verifier v = setUp("InvalidVersion/", false);
- v.verifyErrorFreeLog();
- v.verifyTextInLog("[WARNING] yang-to-sources: Dependency resolution conflict:");
+ Verifier vrf = setUp("test-parent/InvalidVersion/", false);
+ vrf.verifyErrorFreeLog();
+ vrf.verifyTextInLog("[WARNING] yang-to-sources: Dependency resolution conflict:");
}
@Test
public void testUnknownGenerator() throws Exception {
- Verifier v = setUp("UnknownGenerator/", true);
- v.verifyTextInLog("[ERROR] yang-to-sources: Unable to generate sources with unknown generator");
- v.verifyTextInLog("java.lang.ClassNotFoundException: unknown");
- v.verifyTextInLog("[INFO] yang-to-sources: Code generator instantiated from org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl");
- v.verifyTextInLog("[INFO] yang-to-sources: Sources generated by org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl: null");
- v.verifyTextInLog("[ERROR] yang-to-sources: One or more code generators failed, including failed list(generatorClass=exception) {unknown=java.lang.ClassNotFoundException}");
+ Verifier vrf = setUp("test-parent/UnknownGenerator/", true);
+ vrf.verifyTextInLog("[INFO] yang-to-sources: Code generator instantiated from "
+ + "org.opendaylight.yangtools.yang2sources.spi.CodeGeneratorTestImpl");
+ vrf.verifyTextInLog("Failed to instantiate code generator unknown");
+ vrf.verifyTextInLog("java.lang.ClassNotFoundException: unknown");
}
@Test
public void testNoYangFiles() throws Exception {
- Verifier v = setUp("NoYangFiles/", false);
- v.verifyTextInLog("[INFO] yang-to-sources: No input files found");
+ setUp("test-parent/NoYangFiles/", false).verifyTextInLog("[INFO] yang-to-sources: No input files found");
}
- static void assertVerificationException(VerificationException e,
- String string) {
- assertThat(e.getMessage(), containsString(string));
+ static void assertVerificationException(final VerificationException ex, final String string) {
+ assertThat(ex.getMessage(), containsString(string));
}
- @BeforeClass
- public static void generateProps() throws IOException {
- final Properties sp = new Properties();
- try (InputStream is = new FileInputStream(new File(SRC_PROPERTIES))) {
- sp.load(is);
+ static Verifier setUp(final String project, final boolean ignoreF)
+ throws VerificationException, URISyntaxException, IOException {
+ final URL path = YangToSourcesPluginTestIT.class.getResource("/" + project + "pom.xml");
+ final Verifier verifier = new Verifier(new File(path.toURI()).getParent());
+ if (ignoreF) {
+ verifier.addCliOption("-fn");
}
- props = new Properties(System.getProperties());
- props.put(VERSION_PROP, sp.getProperty(VERSION_PROP));
- }
-
- static Verifier setUp(String project, boolean ignoreF)
- throws VerificationException, URISyntaxException {
- final URL path = YangToSourcesPluginTestIT.class.getResource("/"
- + project + "pom.xml");
- File parent = new File(path.toURI());
- Verifier verifier = new Verifier(parent.getParent());
- if (ignoreF)
- verifier.addCliOption("-fn");
+ final Optional<String> maybeSettings = getEffectiveSettingsXML();
+ if (maybeSettings.isPresent()) {
+ verifier.addCliOption("-gs");
+ verifier.addCliOption(maybeSettings.get());
+ }
verifier.setMavenDebug(true);
- verifier.setSystemProperties(props);
verifier.executeGoal("generate-sources");
return verifier;
}
@Test
public void testNoOutputDir() throws Exception {
- Verifier v = YangToSourcesPluginTestIT.setUp("NoOutputDir/", false);
- verifyCorrectLog(v);
+ verifyCorrectLog(YangToSourcesPluginTestIT.setUp("test-parent/NoOutputDir/", false));
}
@Test
public void testFindResourceOnCp() throws Exception {
- Verifier v1 = new Verifier(new File(getClass().getResource(
- "/GenerateTest1/pom.xml").toURI()).getParent());
- v1.setSystemProperties(props);
+ Verifier v1 = setUp("test-parent/GenerateTest1/", false);
v1.executeGoal("clean");
v1.executeGoal("package");
- v1.assertFilePresent("target/classes/META-INF/yang/testfile1.yang");
- v1.assertFilePresent("target/classes/META-INF/yang/testfile2.yang");
- v1.assertFilePresent("target/classes/META-INF/yang/testfile3.yang");
- Verifier v2 = YangToSourcesPluginTestIT.setUp("GenerateTest2/", false);
+ String buildDir = getMavenBuildDirectory(v1);
+ v1.assertFilePresent(buildDir + "/classes/META-INF/yang/types1@2013-02-27.yang");
+ v1.assertFilePresent(buildDir + "/classes/META-INF/yang/types2@2013-02-27.yang");
+ v1.assertFilePresent(buildDir + "/classes/META-INF/yang/types3@2013-02-27.yang");
+
+ Verifier v2 = setUp("test-parent/GenerateTest2/", false);
v2.executeGoal("clean");
v2.executeGoal("package");
- v2.assertFilePresent("target/classes/META-INF/yang/private.yang");
- v2.assertFileNotPresent("target/classes/META-INF/yang/testfile1.yang");
- v2.assertFileNotPresent("target/classes/META-INF/yang/testfile2.yang");
- v2.assertFileNotPresent("target/classes/META-INF/yang/testfile3.yang");
+
+ buildDir = getMavenBuildDirectory(v2);
+ v2.assertFilePresent(buildDir + "/classes/META-INF/yang/private@2013-02-27.yang");
+ v2.assertFileNotPresent(buildDir + "/classes/META-INF/yang/types1@2013-02-27.yang");
+ v2.assertFileNotPresent(buildDir + "/classes/META-INF/yang/types2@2013-02-27.yang");
+ v2.assertFileNotPresent(buildDir + "/classes/META-INF/yang/types3@2013-02-27.yang");
+ }
+
+ private static String getMavenBuildDirectory(final Verifier verifier) throws IOException {
+ final Properties sp = new Properties();
+ final Path path = new File(verifier.getBasedir() + "/it-project.properties").toPath();
+ try (InputStream is = Files.newInputStream(path)) {
+ sp.load(is);
+ }
+ return sp.getProperty("target.dir");
+ }
+
+ private static Optional<String> getEffectiveSettingsXML() throws URISyntaxException, VerificationException,
+ IOException {
+ final URL path = Resources.getResource(YangToSourcesPluginTestIT.class, "/test-parent/pom.xml");
+ final File buildDir = new File(path.toURI()).getParentFile().getParentFile().getParentFile();
+ final File effectiveSettingsXML = new File(buildDir, "effective-settings.xml");
+ if (effectiveSettingsXML.exists()) {
+ return Optional.of(effectiveSettingsXML.getAbsolutePath());
+ }
+
+ fail(effectiveSettingsXML.getAbsolutePath());
+ return Optional.empty();
}
}