From 4ab2d971baf5d14b401eab728705e4c3fb1f4293 Mon Sep 17 00:00:00 2001 From: Robert Stoll Date: Wed, 22 Aug 2018 19:02:31 +0200 Subject: [PATCH 1/2] prepare regression test for #69 add test cases where a project with a parent has properties as version --- .../pomexplorer/AnalyzerTest.java | 100 +++++++++++++----- .../testSets/pomWithPropertyAsVersion/a.pom | 15 +++ .../testSets/pomWithPropertyAsVersion/b.pom | 14 +++ .../pomWithTwoPropertiesAsVersion/a.pom | 16 +++ .../pomWithTwoPropertiesAsVersion/b.pom | 14 +++ 5 files changed, 131 insertions(+), 28 deletions(-) create mode 100644 pom-explorer-core/testSets/pomWithPropertyAsVersion/a.pom create mode 100644 pom-explorer-core/testSets/pomWithPropertyAsVersion/b.pom create mode 100644 pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/a.pom create mode 100644 pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/b.pom diff --git a/pom-explorer-core/src/test/java/fr/lteconsulting/pomexplorer/AnalyzerTest.java b/pom-explorer-core/src/test/java/fr/lteconsulting/pomexplorer/AnalyzerTest.java index ed9f9cfa..9c6ea16d 100644 --- a/pom-explorer-core/src/test/java/fr/lteconsulting/pomexplorer/AnalyzerTest.java +++ b/pom-explorer-core/src/test/java/fr/lteconsulting/pomexplorer/AnalyzerTest.java @@ -51,7 +51,7 @@ public void test02() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/set02"); + PomAnalysis pomAnalysis = runFullRecursiveAnalysis( session, "testSets/set02" ); //assert assertProjects(session, 5); assertDependencies(session, PROJECT_A, new GavIsSelfManaged( PROJECT_B, true )); @@ -66,7 +66,7 @@ public void test02() ); assertDependencies(session, PROJECT_D, 0); assertDependencies(session, PROJECT_E, 0); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @Test @@ -75,7 +75,7 @@ public void test03() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/set03"); + PomAnalysis pomAnalysis =runFullRecursiveAnalysis(session, "testSets/set03"); //assert assertProjects(session, 4); assertDependencies(session, PROJECT_A, @@ -86,7 +86,7 @@ public void test03() assertDependenciesManagement(session, PROJECT_B, new GavIsSelfManaged( PROJECT_D, true )); assertDependencies(session, PROJECT_C, new GavIsSelfManaged( PROJECT_D, true )); assertDependencies(session, PROJECT_D, 0); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @Test @@ -95,7 +95,7 @@ public void test04() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/set04"); + PomAnalysis pomAnalysis =runFullRecursiveAnalysis(session, "testSets/set04"); //assert assertProjects(session, 4); assertDependencies(session, PROJECT_A, @@ -106,7 +106,7 @@ public void test04() assertDependenciesManagement(session, PROJECT_B, new GavIsSelfManaged( PROJECT_D, true )); assertDependencies(session, PROJECT_C, new GavIsSelfManaged( "fr.lteconsulting:toto:1.4-SNAPSHOT", true )); assertDependencies(session, PROJECT_D, 0); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @Test @@ -115,7 +115,7 @@ public void dependencyWithExclusion() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/dependencyWithExclusion"); + PomAnalysis pomAnalysis =runFullRecursiveAnalysis(session, "testSets/dependencyWithExclusion"); //assert assertProjects(session, 4); assertDependencies(session, PROJECT_A, @@ -126,7 +126,7 @@ public void dependencyWithExclusion() assertDependenciesManagement(session, PROJECT_B, new GavIsSelfManaged( PROJECT_D, true )); assertDependencies(session, PROJECT_C, new GavIsSelfManaged( "fr.lteconsulting:toto:1.4-SNAPSHOT", true )); assertDependencies(session, PROJECT_D, 1); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); assertDependencyHasExclusion(session, PROJECT_A, PROJECT_B, PROJECT_D); assertThat(session.projects().forGav(Gav.parse(PROJECT_D)).getUnresolvedProperties()).containsExactly( "unknown" ); @@ -138,7 +138,7 @@ public void dependencyManagementWithExclusion() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/dependencyManagementWithExclusion"); + PomAnalysis pomAnalysis =runFullRecursiveAnalysis(session, "testSets/dependencyManagementWithExclusion"); //assert assertProjects(session, 4); assertDependencies(session, PROJECT_A, @@ -149,7 +149,7 @@ public void dependencyManagementWithExclusion() assertDependenciesManagement(session, PROJECT_B, new GavIsSelfManaged( PROJECT_D, true )); assertDependencies(session, PROJECT_C, new GavIsSelfManaged( "fr.lteconsulting:toto:1.4-SNAPSHOT", true )); assertDependencies(session, PROJECT_D, 0); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); assertDependencyManagementHasExclusion(session, PROJECT_A, PROJECT_B, PROJECT_D); } @@ -289,7 +289,7 @@ public void multiModule() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/multiModule_inSubfolders"); + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/multiModule_inSubfolders"); //assert assertProjects(session, 6); assertDependencies(session, PROJECT_A, 0); @@ -320,7 +320,7 @@ public void multiModule() assertParentDependency(session, PROJECT_D, PROJECT_A); assertDependencies(session, PROJECT_E, new GavIsSelfManaged( PROJECT_F, true )); assertDependencies(session, PROJECT_F, 0); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @@ -330,7 +330,7 @@ public void getSubmodules_submodulesInSubFolders() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/multiModule_inSubfolders"); + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/multiModule_inSubfolders"); //assert assertProjects(session, 6); assertSubmodules(session, PROJECT_A, @@ -338,6 +338,7 @@ public void getSubmodules_submodulesInSubFolders() PROJECT_C, PROJECT_D ); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @@ -347,7 +348,7 @@ public void getSubmodules_submodulesInSameFolder() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/multiModule_inSameFolder"); + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/multiModule_inSameFolder"); //assert assertProjects(session, 6); assertSubmodules(session, PROJECT_A, @@ -355,6 +356,7 @@ public void getSubmodules_submodulesInSameFolder() PROJECT_C, PROJECT_D ); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @Test @@ -363,11 +365,12 @@ public void getSubmodules_submoduleIsAlsoMultiModule() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/multiModule_nested"); + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/multiModule_nested"); //assert assertProjects(session, 6); assertSubmodules(session, PROJECT_A, PROJECT_B, PROJECT_C ); assertSubmodules(session, PROJECT_B, PROJECT_D ); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @Test @@ -376,7 +379,7 @@ public void pomDependency() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/pomDependency"); + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/pomDependency"); //assert assertProjects(session, 6); assertDependencies(session, PROJECT_A, 0); @@ -389,7 +392,7 @@ public void pomDependency() assertParentDependency(session, PROJECT_D, PROJECT_A); assertDependencies(session, PROJECT_E, 1); assertDependencies(session, PROJECT_F, 0); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @Test @@ -398,14 +401,14 @@ public void bomDependency() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/bomDependency"); + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/bomDependency"); //assert assertProjects(session, 3); assertDependencies(session, PROJECT_A, 0); assertDependencies(session, PROJECT_B, new GavIsSelfManaged(PROJECT_A, false)); assertDependenciesManagement(session, PROJECT_B, new GavIsSelfManaged(PROJECT_C, true)); assertDependenciesManagement(session, PROJECT_C, new GavIsSelfManaged(PROJECT_A, true)); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @Test @@ -414,14 +417,14 @@ public void bomDependencyProjectVersion() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/bomDependencyProjectVersion"); + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/bomDependencyProjectVersion"); //assert assertProjects(session, 3); assertDependencies(session, PROJECT_A, 0); assertDependencies(session, PROJECT_B_2, new GavIsSelfManaged(PROJECT_A_3, false)); assertDependenciesManagement(session, PROJECT_B_2, new GavIsSelfManaged(PROJECT_C_3, true)); assertDependenciesManagement(session, PROJECT_C_3, new GavIsSelfManaged(PROJECT_A_3, true)); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @Test @@ -430,14 +433,14 @@ public void bomDependency_dependencyToItself() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/bomDependencyWithSelfDependency"); + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/bomDependencyWithSelfDependency"); //assert assertProjects(session, 3); assertDependencies(session, PROJECT_A, 0); assertDependencies(session, PROJECT_B, new GavIsSelfManaged(PROJECT_A, false)); assertDependenciesManagement(session, PROJECT_B, new GavIsSelfManaged(PROJECT_C, true)); assertDependenciesManagement(session, PROJECT_C, new GavIsSelfManaged(PROJECT_A, true)); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @Test @@ -446,7 +449,7 @@ public void bomDependencyInParent() //arrange Session session = new Session(); //act - runFullRecursiveAnalysis(session, "testSets/bomDependencyInParent"); + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/bomDependencyInParent"); //assert assertProjects(session, 4); assertDependencies(session, PROJECT_A, 0); @@ -454,7 +457,7 @@ public void bomDependencyInParent() assertDependenciesManagement(session, PROJECT_B, new GavIsSelfManaged(PROJECT_C, true)); assertDependenciesManagement(session, PROJECT_C, new GavIsSelfManaged(PROJECT_A, true)); assertDependenciesManagement(session, PROJECT_D, new GavIsSelfManaged(PROJECT_A, false)); - assertNoNullGavs(session); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @Test @@ -463,7 +466,7 @@ public void versionInUnresolvedParent() //arrange Session session = new Session(); //act - PomAnalysis.runFullRecursiveAnalysis("testSets/versionInUnresolvedParent", session, new DefaultPomFileLoader( session, false ), null, true, System.out::println); + PomAnalysis pomAnalysis = PomAnalysis.runFullRecursiveAnalysis("testSets/versionInUnresolvedParent", session, new DefaultPomFileLoader( session, false ), null, true, System.out::println); //assert assertProjects(session, 3); assertDependencies(session, PROJECT_A, 0); @@ -477,7 +480,8 @@ public void versionInUnresolvedParent() new GavIsSelfManaged("fr.lteconsulting:b:null", false), new GavIsSelfManaged("fr.lteconsulting:b:null", false) ); - assertNullGavs(session, 1); + assertNullGavs( session, 1 ); + assertNoErronousPomFiles( pomAnalysis); } @Test @@ -546,6 +550,36 @@ public void pomWithoutVersion() } + @Ignore("Regressiontest for #69") + @Test + public void pomWithPropertyAsVersion() + { + //arrange + Session session = new Session(); + //act + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/pomWithPropertyAsVersion"); + //assert + assertProjects(session, 1); + assertDependencies(session, PROJECT_A, 0); + assertParentDependency(session, PROJECT_B, PROJECT_A); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); + } + + @Ignore("Regressiontest for #69") + @Test + public void pomWithTwoPropertiesAsVersion() + { + //arrange + Session session = new Session(); + //act + PomAnalysis pomAnalysis = runFullRecursiveAnalysis(session, "testSets/pomWithTwoPropertiesAsVersion"); + //assert + assertProjects(session, 1); + assertDependencies(session, PROJECT_A, 0); + assertParentDependency(session, PROJECT_B, PROJECT_A); + assertNoNullGavsNoErroneousPoms(session, pomAnalysis); + } + @Test public void localTest1() { @@ -696,7 +730,17 @@ private void assertBuildDependencies(Session session, String gavString, int numb private void assertParentDependency(Session session, String gavString, String parentGav) { Gav parent = session.graph().read().parent(Gav.parse(gavString)); - assertEquals("parent dependency of " + gavString, parent, Gav.parse(parentGav)); + assertEquals("parent dependency of " + gavString, Gav.parse(parentGav), parent); + } + + private void assertNoNullGavsNoErroneousPoms( Session session, PomAnalysis pomAnalysis ){ + assertNoNullGavs( session ); + assertNoErronousPomFiles( pomAnalysis ); + } + + private void assertNoErronousPomFiles( PomAnalysis pomAnalysis ) + { + assertThat(pomAnalysis.getErroneousPomFiles()).isEmpty(); } private void assertNoNullGavs(Session session) diff --git a/pom-explorer-core/testSets/pomWithPropertyAsVersion/a.pom b/pom-explorer-core/testSets/pomWithPropertyAsVersion/a.pom new file mode 100644 index 00000000..04102286 --- /dev/null +++ b/pom-explorer-core/testSets/pomWithPropertyAsVersion/a.pom @@ -0,0 +1,15 @@ + + + + 4.0.0 + + fr.lteconsulting + b + 1.0 + + + 1.1 + + + + \ No newline at end of file diff --git a/pom-explorer-core/testSets/pomWithPropertyAsVersion/b.pom b/pom-explorer-core/testSets/pomWithPropertyAsVersion/b.pom new file mode 100644 index 00000000..854da2bc --- /dev/null +++ b/pom-explorer-core/testSets/pomWithPropertyAsVersion/b.pom @@ -0,0 +1,14 @@ + + + + 4.0.0 + + + fr.lteconsulting + a + 1.0-SNAPSHOT + + b + ${xxx.version} + + \ No newline at end of file diff --git a/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/a.pom b/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/a.pom new file mode 100644 index 00000000..4dd42fe2 --- /dev/null +++ b/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/a.pom @@ -0,0 +1,16 @@ + + + + 4.0.0 + + fr.lteconsulting + b + 1.0 + + + 1 + 2 + + + + \ No newline at end of file diff --git a/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/b.pom b/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/b.pom new file mode 100644 index 00000000..fc0e9dcc --- /dev/null +++ b/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/b.pom @@ -0,0 +1,14 @@ + + + + 4.0.0 + + + fr.lteconsulting + a + 1.0-SNAPSHOT + + b + ${major.version}.${minor.version} + + \ No newline at end of file From f9603a73371ef19cd484b0791d2b52171bbdddc2 Mon Sep 17 00:00:00 2001 From: Robert Stoll Date: Wed, 22 Aug 2018 19:07:57 +0200 Subject: [PATCH 2/2] adjust versions of the regression tests --- .../java/fr/lteconsulting/pomexplorer/AnalyzerTest.java | 4 ++-- pom-explorer-core/testSets/pomWithPropertyAsVersion/a.pom | 4 ++-- .../testSets/pomWithTwoPropertiesAsVersion/a.pom | 7 ++++--- .../testSets/pomWithTwoPropertiesAsVersion/b.pom | 2 +- 4 files changed, 9 insertions(+), 8 deletions(-) diff --git a/pom-explorer-core/src/test/java/fr/lteconsulting/pomexplorer/AnalyzerTest.java b/pom-explorer-core/src/test/java/fr/lteconsulting/pomexplorer/AnalyzerTest.java index 9c6ea16d..5cc03b54 100644 --- a/pom-explorer-core/src/test/java/fr/lteconsulting/pomexplorer/AnalyzerTest.java +++ b/pom-explorer-core/src/test/java/fr/lteconsulting/pomexplorer/AnalyzerTest.java @@ -561,7 +561,7 @@ public void pomWithPropertyAsVersion() //assert assertProjects(session, 1); assertDependencies(session, PROJECT_A, 0); - assertParentDependency(session, PROJECT_B, PROJECT_A); + assertParentDependency(session, PROJECT_B_2, PROJECT_A); assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } @@ -576,7 +576,7 @@ public void pomWithTwoPropertiesAsVersion() //assert assertProjects(session, 1); assertDependencies(session, PROJECT_A, 0); - assertParentDependency(session, PROJECT_B, PROJECT_A); + assertParentDependency(session, PROJECT_B_2, PROJECT_A); assertNoNullGavsNoErroneousPoms(session, pomAnalysis); } diff --git a/pom-explorer-core/testSets/pomWithPropertyAsVersion/a.pom b/pom-explorer-core/testSets/pomWithPropertyAsVersion/a.pom index 04102286..c4dd7c5b 100644 --- a/pom-explorer-core/testSets/pomWithPropertyAsVersion/a.pom +++ b/pom-explorer-core/testSets/pomWithPropertyAsVersion/a.pom @@ -5,10 +5,10 @@ fr.lteconsulting b - 1.0 + 1.0-SNAPSHOT - 1.1 + 2.0-SNAPSHOT diff --git a/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/a.pom b/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/a.pom index 4dd42fe2..b7f9994e 100644 --- a/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/a.pom +++ b/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/a.pom @@ -5,11 +5,12 @@ fr.lteconsulting b - 1.0 + 1.0-SNAPSHOT - 1 - 2 + 2 + 0 + -SNAPSHOT diff --git a/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/b.pom b/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/b.pom index fc0e9dcc..8dc43d69 100644 --- a/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/b.pom +++ b/pom-explorer-core/testSets/pomWithTwoPropertiesAsVersion/b.pom @@ -9,6 +9,6 @@ 1.0-SNAPSHOT b - ${major.version}.${minor.version} + ${major.version}.${minor.version}${version.suffix} \ No newline at end of file