diff options
2 files changed, 43 insertions, 9 deletions
diff --git a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/ShowArtifactAction.java b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/ShowArtifactAction.java index 4d87e7203..d44348934 100644 --- a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/ShowArtifactAction.java +++ b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/ShowArtifactAction.java @@ -150,16 +150,19 @@ public class ShowArtifactAction // TODO: eventually, move to just use the metadata directly, with minimal JSP changes, mostly for Maven specifics model = new ArchivaProjectModel(); MavenProjectFacet projectFacet = (MavenProjectFacet) versionMetadata.getFacet( MavenProjectFacet.FACET_ID ); - model.setGroupId( projectFacet.getGroupId() ); - model.setArtifactId( projectFacet.getArtifactId() ); - model.setPackaging( projectFacet.getPackaging() ); - if ( projectFacet.getParent() != null ) + if ( projectFacet != null ) { - VersionedReference parent = new VersionedReference(); - parent.setGroupId( projectFacet.getParent().getGroupId() ); - parent.setArtifactId( projectFacet.getParent().getArtifactId() ); - parent.setVersion( projectFacet.getParent().getVersion() ); - model.setParentProject( parent ); + model.setGroupId( projectFacet.getGroupId() ); + model.setArtifactId( projectFacet.getArtifactId() ); + model.setPackaging( projectFacet.getPackaging() ); + if ( projectFacet.getParent() != null ) + { + VersionedReference parent = new VersionedReference(); + parent.setGroupId( projectFacet.getParent().getGroupId() ); + parent.setArtifactId( projectFacet.getParent().getArtifactId() ); + parent.setVersion( projectFacet.getParent().getVersion() ); + model.setParentProject( parent ); + } } model.setVersion( versionMetadata.getId() ); diff --git a/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/ShowArtifactActionTest.java b/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/ShowArtifactActionTest.java index 5d4ab0853..82ef07e0c 100644 --- a/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/ShowArtifactActionTest.java +++ b/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/ShowArtifactActionTest.java @@ -308,6 +308,37 @@ public class ShowArtifactActionTest assertTrue( action.getSnapshotVersions().isEmpty() ); } + public void testGetArtifactNoMavenFacet() + { + ProjectVersionMetadata versionMetadata = new ProjectVersionMetadata(); + versionMetadata.setId( TEST_VERSION ); + versionMetadata.setUrl( TEST_URL ); + versionMetadata.setName( TEST_NAME ); + versionMetadata.setDescription( TEST_DESCRIPTION ); + + metadataResolver.setProjectVersion( TEST_REPO, TEST_GROUP_ID, TEST_ARTIFACT_ID, versionMetadata ); + + setActionParameters(); + + String result = action.artifact(); + + assertActionSuccess( action, result ); + + assertActionParameters( action ); + ArchivaProjectModel model = action.getModel(); + assertEquals( TEST_VERSION, model.getVersion() ); + assertEquals( TEST_URL, model.getUrl() ); + assertEquals( TEST_NAME, model.getName() ); + assertEquals( TEST_DESCRIPTION, model.getDescription() ); + + assertEquals( TEST_REPO, action.getRepositoryId() ); + + assertNull( action.getDependees() ); + assertNull( action.getDependencies() ); + assertNull( action.getMailingLists() ); + assertTrue( action.getSnapshotVersions().isEmpty() ); + } + private void assertNoOutputFields() { assertNull( action.getModel() ); |