org.gradle.integtests.resolve.maven.BadPomFileResolveIntegrationTest.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2011 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.gradle.integtests.resolve.maven
import org.gradle.integtests.fixtures.AbstractHttpDependencyResolutionTest
import spock.lang.Issue
import spock.lang.Unroll
class BadPomFileResolveIntegrationTest extends AbstractHttpDependencyResolutionTest {
@Issue("https://issues.gradle.org/browse/GRADLE-1005")
def "can handle self referencing dependency"() {
given:
mavenRepo().module('group', 'artifact', '1.0').dependsOn('group', 'artifact', '1.0').publish()
and:
buildFile << """
repositories {
maven { url "${mavenRepo().uri}" }
}
configurations { compile }
dependencies {
compile "group:artifact:1.0"
}
task libs { doLast { assert configurations.compile.files.collect {it.name} == ['artifact-1.0.jar'] } }
"""
expect:
succeeds ":libs"
}
public void "reports POM that cannot be parsed"() {
given:
buildFile << """
repositories {
maven {
url "${mavenHttpRepo.uri}"
}
}
configurations { compile }
dependencies {
compile 'group:projectA:1.2'
}
task showBroken { doLast { println configurations.compile.files } }
"""
and:
def module = mavenHttpRepo.module('group', 'projectA', '1.2').publish()
module.pomFile.text = " "
when:
module.pom.expectGet()
then:
fails "showBroken"
failure.assertResolutionFailure(":compile")
.assertHasCause("Could not parse POM ${module.pom.uri}")
.assertHasCause("Missing required attribute: groupId")
}
def "reports local POM that cannot be parsed"() {
given:
buildFile << """
repositories {
maven {
url "${mavenRepo.uri}"
}
}
configurations { compile }
dependencies {
compile 'group:projectA:1.2'
}
task showBroken { doLast { println configurations.compile.files } }
"""
and:
def module = mavenRepo.module('group', 'projectA', '1.2').publish()
module.pomFile.text = " "
when:
fails "showBroken"
then:
failure.assertResolutionFailure(":compile")
.assertHasCause("Could not parse POM ${module.pomFile}")
.assertHasCause("Missing required attribute: groupId")
}
def "reports missing parent POM"() {
given:
def parent = mavenHttpRepo.module("org", "parent", "1.0")
def child = mavenHttpRepo.module("org", "child", "1.0")
child.parent("org", "parent", "1.0")
child.publish()
buildFile << """
repositories {
maven { url '${mavenHttpRepo.uri}' }
}
configurations { compile }
dependencies { compile 'org:child:1.0' }
task showBroken { doLast { println configurations.compile.files } }
"""
when:
child.pom.expectGet()
parent.pom.expectGetMissing()
// Will always check for a default artifact with a module with 'pom' packaging
// TODO - should not make this request
parent.artifact.expectHeadMissing()
and:
fails 'showBroken'
then:
failure.assertResolutionFailure(':compile')
.assertHasCause("Could not parse POM ${child.pom.uri}")
.assertHasCause("""Could not find org:parent:1.0.
Searched in the following locations:
- ${parent.pom.uri}
- ${parent.artifact.uri}""")
}
def "reports parent POM that cannot be parsed"() {
given:
def parent = mavenHttpRepo.module("org", "parent", "1.0").publish()
parent.pomFile.text = " "
def child = mavenHttpRepo.module("org", "child", "1.0")
child.parent("org", "parent", "1.0")
child.publish()
buildFile << """
repositories {
maven { url '${mavenHttpRepo.uri}' }
}
configurations { compile }
dependencies { compile 'org:child:1.0' }
task showBroken { doLast { println configurations.compile.files } }
"""
when:
child.pom.expectGet()
parent.pom.expectGet()
and:
fails 'showBroken'
then:
failure.assertResolutionFailure(":compile")
.assertHasCause("Could not parse POM ${child.pom.uri}")
.assertHasCause("Could not parse POM ${parent.pom.uri}")
.assertHasCause("Missing required attribute: groupId")
}
@Unroll
def "reports failure to parse POM due to missing dependency #attribute attribute"() {
given:
buildFile << """
repositories {
maven {
url "${mavenRepo.uri}"
}
}
configurations { compile }
dependencies {
compile 'group:projectA:1.2'
}
task showBroken { doLast { println configurations.compile.files } }
"""
and:
def module = mavenHttpRepo.module('group', 'projectA', '1.2').dependsOn("other-groupId", "other-artifactId", "1.0").publish()
def elementToReplace = "<$attribute>other-$attribute$attribute>"
module.pomFile.text = module.pomFile.text.replace(elementToReplace, "")
when:
fails "showBroken"
then:
failure.assertResolutionFailure(":compile")
.assertHasCause("Could not parse POM ${module.pomFile}")
.assertHasCause("Missing required attribute: dependency $attribute")
where:
attribute << ["groupId", "artifactId"]
}
@Issue("https://github.com/gradle/gradle/issues/3065")
def "handles broken packaging type gracefully"() {
given:
buildFile << """
repositories {
maven {
url "${mavenHttpRepo.uri}"
}
}
configurations { compile }
dependencies {
compile 'group:projectA:1.2'
}
task resolve { doLast { configurations.compile.resolve() } }
"""
and:
def module = mavenHttpRepo.module('group', 'projectA', '1.2').publish()
module.pomFile.text = """
4.0.0
group
projectA
1.2
\${package.type}
"""
when:
module.pom.expectGet()
module.artifact.expectGet()
then:
succeeds("resolve")
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy